blob: e8a63f016ea17a20d5b00e383fa672ec27bb1c9e [file] [log] [blame]
/*
* Copyright (C) 2019 MediaTek Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See http://www.gnu.org/licenses/gpl-2.0.html for more details.
*/
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/err.h>
#include <linux/device.h>
#include "rt5509.h"
#ifdef CONFIG_RT_REGMAP
/* ---------------------------------------------------------------------
* Create RT5509 register map
*
* RT_REG_DECL(_addr, _reg_length, _reg_type, _mask_...)
* @ _addr : reigster address
* @ _reg_length : register byte length
* @ _reg_type : reigster type (RT_NORMAL, RT_VOLATILE, RT_WBITS)
* @ _mask : register write bits mask
*/
/* WBITS will and mask, to check the writable bits */
/* NORMAL ignore mask */
/* VOLATILE directly write through */
RT_REG_DECL(RT5509_REG_CHIPREV, 1, RT_VOLATILE, {0x00});
RT_REG_DECL(RT5509_REG_EVENTINFO, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DMGFLAG, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CHIPEN, 1, RT_VOLATILE, {0x3f});
RT_REG_DECL(RT5509_REG_AUDFMT, 1, RT_VOLATILE, {0x1f});
RT_REG_DECL(RT5509_REG_AUDSR, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_I2SSEL, 1, RT_VOLATILE, {0x0f});
RT_REG_DECL(RT5509_REG_I2SDOLRSEL, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_I2SDOSEL, 1, RT_VOLATILE, {0x03});
RT_REG_DECL(RT5509_REG_FUNCEN, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_CLIP_THR, 1, RT_VOLATILE, {0x07});
RT_REG_DECL(RT5509_REG_CLIP_CTRL, 1, RT_VOLATILE, {0xbf});
RT_REG_DECL(RT5509_REG_CLIP_SLOPE, 2, RT_VOLATILE, {0x03, 0xff});
RT_REG_DECL(RT5509_REG_CLIP_VOMIN, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CLIP_SIGMAX, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_AMPCONF, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DACRNKGAIN, 1, RT_VOLATILE, {0xcf});
RT_REG_DECL(RT5509_REG_SAMPOFFS, 1, RT_VOLATILE, {0x07});
RT_REG_DECL(RT5509_REG_SAMPCONF, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_DAGAIN, 2, RT_VOLATILE, {0x07, 0xff});
RT_REG_DECL(RT5509_REG_FFGAIN, 2, RT_VOLATILE, {0x03, 0xff});
RT_REG_DECL(RT5509_REG_VBATGAIN, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_RLDCOEF1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_RLDCOEF2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BST_MODE, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BST_TH1, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BST_TH2, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BST_TH3, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BST_CONF1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BST_SIG_GAIN, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BST_CONF2, 1, RT_VOLATILE, {0xf3});
RT_REG_DECL(RT5509_REG_BST_CONF3, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_OCPOTPEN, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_IDAC1TST, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_IDAC2TST, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_IDAC3TST, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_IDACTSTEN, 1, RT_VOLATILE, {0x87});
RT_REG_DECL(RT5509_REG_CCMAX, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_OCPMAX, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_INTERRUPT, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_INTRMASK, 2, RT_VOLATILE, {0x07, 0xff});
RT_REG_DECL(RT5509_REG_DEGLITCH, 2, RT_VOLATILE, {0x0F, 0xff});
RT_REG_DECL(RT5509_REG_SICRTNSTHACT, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_TIMEDET, 1, RT_VOLATILE, {0x3f});
RT_REG_DECL(RT5509_REG_TDELAY, 2, RT_VOLATILE, {0x01, 0xff});
RT_REG_DECL(RT5509_REG_TATKSEL, 1, RT_VOLATILE, {0x03});
RT_REG_DECL(RT5509_REG_TREL, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_THOLDREL, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_STHLMT, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_XTHLMT, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_STHALC, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_XTHALC, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_INITUDT, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_UDT, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DNHALFT, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ALCGAIN, 1, RT_VOLATILE, {0xf7});
RT_REG_DECL(RT5509_REG_ADAPTCONF, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_INITIMPLDMU, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_IMPLDMU, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_GPILOT, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PILOTEN, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PILOTNISENSE, 1, RT_VOLATILE, {0x7f});
RT_REG_DECL(RT5509_REG_ISENSEGAIN, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_RAPP, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DCR_MAX, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DCR_KD, 2, RT_VOLATILE, {0x07, 0xff});
RT_REG_DECL(RT5509_REG_DCR_KP, 2, RT_VOLATILE, {0x03, 0xff});
RT_REG_DECL(RT5509_REG_DCR_KI, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_INITDCRIDMU, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DCRIDMU, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_DCR, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_BL, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_CTRL, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_REQ, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_GAIN, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_OUT0, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_OUT1, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_XTHLMTDAM, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_RMAXDAM, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_TSCALEDAM, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_RECOVERT, 1, RT_VOLATILE, {0x0f});
RT_REG_DECL(RT5509_REG_SETRESFREQ, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_GETRESFREQ, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VOLCTL, 1, RT_VOLATILE, {0x07});
RT_REG_DECL(RT5509_REG_VOLUME, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_OUTX, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CALIB_OUTY, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ1, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ2, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ3, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ4, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ5, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ6, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ7, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ8, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ9, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BQ10, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ1, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ2, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ3, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ4, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ5, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ6, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ7, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ8, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBBQ9, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBFCN, 24, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN1, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN2, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN3, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN4, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN5, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN6, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN7, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN8, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN9, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBGAIN10, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_SLOPCONST, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BWCOEFF, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_SWRESET, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_SPKGAIN, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKCONF1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKCONF2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKCONF3, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKCONF4, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKVMID, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKZCBOOST, 1, RT_VOLATILE, {0x1f});
RT_REG_DECL(RT5509_REG_ISENSE_CTRL, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DIMADC, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKEN1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBATDATA, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VTHRMDATA, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBATSENSE, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_IDACTSTNINFO, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_IDACBOOST, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKEN2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKIBCONF1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKIBCONF2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKIBCONF3, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKCONF5, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DSPKCONF6, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_OVPUVPCTRL, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PLLCONF1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PLLCONF2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PLLCONF3, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PLLCONF4, 1, RT_VOLATILE, {0x3f});
RT_REG_DECL(RT5509_REG_PLLINFO, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PLLDIVISOR, 4, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ZCCONF, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DCADJ, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_I2CBCKLRCKCONF, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_TDEN, 1, RT_VOLATILE, {0x38});
RT_REG_DECL(RT5509_REG_ALPHACONF, 1, RT_VOLATILE, {0x3f});
RT_REG_DECL(RT5509_REG_SPKRPTSEL, 1, RT_VOLATILE, {0x3f});
RT_REG_DECL(RT5509_REG_SPKRPT, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_NDELAY, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DELAYRES, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PHI1, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PHI2, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PHI3, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PHI4, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PHI5, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ADAPTB0, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ADAPTB1, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ADAPTB2, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ADAPTB3, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ADAPTB4, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ADAPTB5, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_COEFSIERA, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_COEFHPF, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MIMATC_CTRL, 1, RT_VOLATILE, {0x1f});
RT_REG_DECL(RT5509_REG_TDM_CTRL, 1, RT_VOLATILE, {0x3f});
RT_REG_DECL(RT5509_REG_ECO_CTRL, 1, RT_VOLATILE, {0x01});
RT_REG_DECL(RT5509_REG_BSTTM, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_ALCMINGAIN, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_RESVECO0, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_OTPCONF, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_OTPDIN, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VBG_TRIM, 1, RT_VOLATILE, {0x1f});
RT_REG_DECL(RT5509_REG_VTEMP_TRIM, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_TCOEFF, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_SPSCONF, 1, RT_VOLATILE, {0x87});
RT_REG_DECL(RT5509_REG_SPSTHR, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_VTHERMBATEN, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DBGADS, 2, RT_VOLATILE, {0x1f, 0x1f});
RT_REG_DECL(RT5509_REG_TESTDAC, 3, RT_VOLATILE, {0xcf, 0xff, 0xff});
RT_REG_DECL(RT5509_REG_SPKDCS, 2, RT_VOLATILE, {0x80, 0xff});
RT_REG_DECL(RT5509_REG_MSKFLAG, 1, RT_VOLATILE, {0x3f});
RT_REG_DECL(RT5509_REG_DRCMINGAIN, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRC_SEL, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRC_ATTACK, 16, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRC_PARAM, 7, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ1, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ2, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ3, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ4, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ5, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ6, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ7, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ8, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ9, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ10, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ11, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCBQ12, 20, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_DRCEN, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW3, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW4, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW5, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW6, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW7, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW8, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOW9, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOWA, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOWB, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOWC, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOWD, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOWE, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_MTPFLOWF, 3, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_TESTMODE1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_RAMIND1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_RAMIND2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_SCANMODE, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CLKEN1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_CLKEN2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_PADDRV, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_TESTMODE2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_SLEWRATE1, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_SLEWRATE2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BIASRESISTOR, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_SPKDRV, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BLOCKREF1, 2, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BLOCKREF2, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BIASCURRENT, 1, RT_VOLATILE, {});
RT_REG_DECL(RT5509_REG_BIASOPTION, 1, RT_VOLATILE, {});
static const rt_register_map_t rt5509_regmap[] = {
RT_REG(RT5509_REG_CHIPREV),
RT_REG(RT5509_REG_EVENTINFO),
RT_REG(RT5509_REG_DMGFLAG),
RT_REG(RT5509_REG_CHIPEN),
RT_REG(RT5509_REG_AUDFMT),
RT_REG(RT5509_REG_AUDSR),
RT_REG(RT5509_REG_I2SSEL),
RT_REG(RT5509_REG_I2SDOLRSEL),
RT_REG(RT5509_REG_I2SDOSEL),
RT_REG(RT5509_REG_FUNCEN),
RT_REG(RT5509_REG_CLIP_THR),
RT_REG(RT5509_REG_CLIP_CTRL),
RT_REG(RT5509_REG_CLIP_SLOPE),
RT_REG(RT5509_REG_CLIP_VOMIN),
RT_REG(RT5509_REG_CLIP_SIGMAX),
RT_REG(RT5509_REG_AMPCONF),
RT_REG(RT5509_REG_DACRNKGAIN),
RT_REG(RT5509_REG_SAMPOFFS),
RT_REG(RT5509_REG_SAMPCONF),
RT_REG(RT5509_REG_DAGAIN),
RT_REG(RT5509_REG_FFGAIN),
RT_REG(RT5509_REG_VBATGAIN),
RT_REG(RT5509_REG_RLDCOEF1),
RT_REG(RT5509_REG_RLDCOEF2),
RT_REG(RT5509_REG_BST_MODE),
RT_REG(RT5509_REG_BST_TH1),
RT_REG(RT5509_REG_BST_TH2),
RT_REG(RT5509_REG_BST_TH3),
RT_REG(RT5509_REG_BST_CONF1),
RT_REG(RT5509_REG_BST_SIG_GAIN),
RT_REG(RT5509_REG_BST_CONF2),
RT_REG(RT5509_REG_BST_CONF3),
RT_REG(RT5509_REG_OCPOTPEN),
RT_REG(RT5509_REG_IDAC1TST),
RT_REG(RT5509_REG_IDAC2TST),
RT_REG(RT5509_REG_IDAC3TST),
RT_REG(RT5509_REG_IDACTSTEN),
RT_REG(RT5509_REG_CCMAX),
RT_REG(RT5509_REG_OCPMAX),
RT_REG(RT5509_REG_INTERRUPT),
RT_REG(RT5509_REG_INTRMASK),
RT_REG(RT5509_REG_DEGLITCH),
RT_REG(RT5509_REG_SICRTNSTHACT),
RT_REG(RT5509_REG_TIMEDET),
RT_REG(RT5509_REG_TDELAY),
RT_REG(RT5509_REG_TATKSEL),
RT_REG(RT5509_REG_TREL),
RT_REG(RT5509_REG_THOLDREL),
RT_REG(RT5509_REG_STHLMT),
RT_REG(RT5509_REG_XTHLMT),
RT_REG(RT5509_REG_STHALC),
RT_REG(RT5509_REG_XTHALC),
RT_REG(RT5509_REG_INITUDT),
RT_REG(RT5509_REG_UDT),
RT_REG(RT5509_REG_DNHALFT),
RT_REG(RT5509_REG_ALCGAIN),
RT_REG(RT5509_REG_ADAPTCONF),
RT_REG(RT5509_REG_INITIMPLDMU),
RT_REG(RT5509_REG_IMPLDMU),
RT_REG(RT5509_REG_GPILOT),
RT_REG(RT5509_REG_PILOTEN),
RT_REG(RT5509_REG_PILOTNISENSE),
RT_REG(RT5509_REG_ISENSEGAIN),
RT_REG(RT5509_REG_RAPP),
RT_REG(RT5509_REG_DCR_MAX),
RT_REG(RT5509_REG_DCR_KD),
RT_REG(RT5509_REG_DCR_KP),
RT_REG(RT5509_REG_DCR_KI),
RT_REG(RT5509_REG_INITDCRIDMU),
RT_REG(RT5509_REG_DCRIDMU),
RT_REG(RT5509_REG_CALIB_DCR),
RT_REG(RT5509_REG_CALIB_BL),
RT_REG(RT5509_REG_CALIB_CTRL),
RT_REG(RT5509_REG_CALIB_REQ),
RT_REG(RT5509_REG_CALIB_GAIN),
RT_REG(RT5509_REG_CALIB_OUT0),
RT_REG(RT5509_REG_CALIB_OUT1),
RT_REG(RT5509_REG_XTHLMTDAM),
RT_REG(RT5509_REG_RMAXDAM),
RT_REG(RT5509_REG_TSCALEDAM),
RT_REG(RT5509_REG_RECOVERT),
RT_REG(RT5509_REG_SETRESFREQ),
RT_REG(RT5509_REG_GETRESFREQ),
RT_REG(RT5509_REG_VOLCTL),
RT_REG(RT5509_REG_VOLUME),
RT_REG(RT5509_REG_CALIB_OUTX),
RT_REG(RT5509_REG_CALIB_OUTY),
RT_REG(RT5509_REG_BQ1),
RT_REG(RT5509_REG_BQ2),
RT_REG(RT5509_REG_BQ3),
RT_REG(RT5509_REG_BQ4),
RT_REG(RT5509_REG_BQ5),
RT_REG(RT5509_REG_BQ6),
RT_REG(RT5509_REG_BQ7),
RT_REG(RT5509_REG_BQ8),
RT_REG(RT5509_REG_BQ9),
RT_REG(RT5509_REG_BQ10),
RT_REG(RT5509_REG_VBBQ1),
RT_REG(RT5509_REG_VBBQ2),
RT_REG(RT5509_REG_VBBQ3),
RT_REG(RT5509_REG_VBBQ4),
RT_REG(RT5509_REG_VBBQ5),
RT_REG(RT5509_REG_VBBQ6),
RT_REG(RT5509_REG_VBBQ7),
RT_REG(RT5509_REG_VBBQ8),
RT_REG(RT5509_REG_VBBQ9),
RT_REG(RT5509_REG_VBFCN),
RT_REG(RT5509_REG_VBGAIN1),
RT_REG(RT5509_REG_VBGAIN2),
RT_REG(RT5509_REG_VBGAIN3),
RT_REG(RT5509_REG_VBGAIN4),
RT_REG(RT5509_REG_VBGAIN5),
RT_REG(RT5509_REG_VBGAIN6),
RT_REG(RT5509_REG_VBGAIN7),
RT_REG(RT5509_REG_VBGAIN8),
RT_REG(RT5509_REG_VBGAIN9),
RT_REG(RT5509_REG_VBGAIN10),
RT_REG(RT5509_REG_SLOPCONST),
RT_REG(RT5509_REG_BWCOEFF),
RT_REG(RT5509_REG_SWRESET),
RT_REG(RT5509_REG_SPKGAIN),
RT_REG(RT5509_REG_DSPKCONF1),
RT_REG(RT5509_REG_DSPKCONF2),
RT_REG(RT5509_REG_DSPKCONF3),
RT_REG(RT5509_REG_DSPKCONF4),
RT_REG(RT5509_REG_DSPKVMID),
RT_REG(RT5509_REG_DSPKZCBOOST),
RT_REG(RT5509_REG_ISENSE_CTRL),
RT_REG(RT5509_REG_DIMADC),
RT_REG(RT5509_REG_DSPKEN1),
RT_REG(RT5509_REG_VBATDATA),
RT_REG(RT5509_REG_VTHRMDATA),
RT_REG(RT5509_REG_VBATSENSE),
RT_REG(RT5509_REG_IDACTSTNINFO),
RT_REG(RT5509_REG_IDACBOOST),
RT_REG(RT5509_REG_DSPKEN2),
RT_REG(RT5509_REG_DSPKIBCONF1),
RT_REG(RT5509_REG_DSPKIBCONF2),
RT_REG(RT5509_REG_DSPKIBCONF3),
RT_REG(RT5509_REG_DSPKCONF5),
RT_REG(RT5509_REG_DSPKCONF6),
RT_REG(RT5509_REG_OVPUVPCTRL),
RT_REG(RT5509_REG_PLLCONF1),
RT_REG(RT5509_REG_PLLCONF2),
RT_REG(RT5509_REG_PLLCONF3),
RT_REG(RT5509_REG_PLLCONF4),
RT_REG(RT5509_REG_PLLINFO),
RT_REG(RT5509_REG_PLLDIVISOR),
RT_REG(RT5509_REG_ZCCONF),
RT_REG(RT5509_REG_DCADJ),
RT_REG(RT5509_REG_I2CBCKLRCKCONF),
RT_REG(RT5509_REG_TDEN),
RT_REG(RT5509_REG_ALPHACONF),
RT_REG(RT5509_REG_SPKRPTSEL),
RT_REG(RT5509_REG_SPKRPT),
RT_REG(RT5509_REG_NDELAY),
RT_REG(RT5509_REG_DELAYRES),
RT_REG(RT5509_REG_PHI1),
RT_REG(RT5509_REG_PHI2),
RT_REG(RT5509_REG_PHI3),
RT_REG(RT5509_REG_PHI4),
RT_REG(RT5509_REG_PHI5),
RT_REG(RT5509_REG_ADAPTB0),
RT_REG(RT5509_REG_ADAPTB1),
RT_REG(RT5509_REG_ADAPTB2),
RT_REG(RT5509_REG_ADAPTB3),
RT_REG(RT5509_REG_ADAPTB4),
RT_REG(RT5509_REG_ADAPTB5),
RT_REG(RT5509_REG_COEFSIERA),
RT_REG(RT5509_REG_COEFHPF),
RT_REG(RT5509_REG_MIMATC_CTRL),
RT_REG(RT5509_REG_TDM_CTRL),
RT_REG(RT5509_REG_ECO_CTRL),
RT_REG(RT5509_REG_BSTTM),
RT_REG(RT5509_REG_ALCMINGAIN),
RT_REG(RT5509_REG_RESVECO0),
RT_REG(RT5509_REG_OTPCONF),
RT_REG(RT5509_REG_OTPDIN),
RT_REG(RT5509_REG_VBG_TRIM),
RT_REG(RT5509_REG_VTEMP_TRIM),
RT_REG(RT5509_REG_TCOEFF),
RT_REG(RT5509_REG_SPSCONF),
RT_REG(RT5509_REG_SPSTHR),
RT_REG(RT5509_REG_VTHERMBATEN),
RT_REG(RT5509_REG_DBGADS),
RT_REG(RT5509_REG_TESTDAC),
RT_REG(RT5509_REG_SPKDCS),
RT_REG(RT5509_REG_MSKFLAG),
RT_REG(RT5509_REG_DRCMINGAIN),
RT_REG(RT5509_REG_DRC_SEL),
RT_REG(RT5509_REG_DRC_ATTACK),
RT_REG(RT5509_REG_DRC_PARAM),
RT_REG(RT5509_REG_DRCBQ1),
RT_REG(RT5509_REG_DRCBQ2),
RT_REG(RT5509_REG_DRCBQ3),
RT_REG(RT5509_REG_DRCBQ4),
RT_REG(RT5509_REG_DRCBQ5),
RT_REG(RT5509_REG_DRCBQ6),
RT_REG(RT5509_REG_DRCBQ7),
RT_REG(RT5509_REG_DRCBQ8),
RT_REG(RT5509_REG_DRCBQ9),
RT_REG(RT5509_REG_DRCBQ10),
RT_REG(RT5509_REG_DRCBQ11),
RT_REG(RT5509_REG_DRCBQ12),
RT_REG(RT5509_REG_DRCEN),
RT_REG(RT5509_REG_MTPFLOW1),
RT_REG(RT5509_REG_MTPFLOW2),
RT_REG(RT5509_REG_MTPFLOW3),
RT_REG(RT5509_REG_MTPFLOW4),
RT_REG(RT5509_REG_MTPFLOW5),
RT_REG(RT5509_REG_MTPFLOW6),
RT_REG(RT5509_REG_MTPFLOW7),
RT_REG(RT5509_REG_MTPFLOW8),
RT_REG(RT5509_REG_MTPFLOW9),
RT_REG(RT5509_REG_MTPFLOWA),
RT_REG(RT5509_REG_MTPFLOWB),
RT_REG(RT5509_REG_MTPFLOWC),
RT_REG(RT5509_REG_MTPFLOWD),
RT_REG(RT5509_REG_MTPFLOWE),
RT_REG(RT5509_REG_MTPFLOWF),
RT_REG(RT5509_REG_TESTMODE1),
RT_REG(RT5509_REG_RAMIND1),
RT_REG(RT5509_REG_RAMIND2),
RT_REG(RT5509_REG_SCANMODE),
RT_REG(RT5509_REG_CLKEN1),
RT_REG(RT5509_REG_CLKEN2),
RT_REG(RT5509_REG_PADDRV),
RT_REG(RT5509_REG_TESTMODE2),
RT_REG(RT5509_REG_SLEWRATE1),
RT_REG(RT5509_REG_SLEWRATE2),
RT_REG(RT5509_REG_BIASRESISTOR),
RT_REG(RT5509_REG_SPKDRV),
RT_REG(RT5509_REG_BLOCKREF1),
RT_REG(RT5509_REG_BLOCKREF2),
RT_REG(RT5509_REG_BIASCURRENT),
RT_REG(RT5509_REG_BIASOPTION),
};
#define REGISTER_NUM ARRAY_SIZE(rt5509_regmap)
static struct rt_regmap_properties rt5509_regmap_props = {
.register_num = REGISTER_NUM,
.rm = rt5509_regmap,
.rt_regmap_mode = RT_MULTI_BYTE | RT_CACHE_DISABLE | RT_DBG_SPECIAL,
.aliases = "rt5509",
};
#if RT5509_SIMULATE_DEVICE
int rt5509_calculate_offset(int reg)
{
int i = 0;
int offset = 0;
int ret = -EINVAL;
for (i = 0; i < REGISTER_NUM; i++,
offset += (rt5509_regmap[i]->size)) {
if (rt5509_regmap[i]->addr == reg) {
ret = offset;
break;
}
}
return ret;
}
EXPORT_SYMBOL(rt5509_calculate_offset);
int rt5509_calculate_total_size(void)
{
int i = 0;
int ret = 0;
for (i = 0; i < REGISTER_NUM; i++)
ret += rt5509_regmap[i]->size;
return ret;
}
EXPORT_SYMBOL(rt5509_calculate_total_size);
#endif /* #if RT5509_SIMULATE_DEVICE */
#endif /* #ifdef CONFIG_RT_REGMAP */
/* ---------------------------------------------------------------------
* RT5509 register map related function
*
*/
struct rt_regmap_device *rt5509_regmap_register(
struct rt_regmap_fops *regmap_ops,
struct device *parent, void *client, void *drvdata)
{
#ifdef CONFIG_RT_REGMAP
rt5509_regmap_props.name = kasprintf(GFP_KERNEL,
"rt5509.%s", dev_name(parent));
return rt_regmap_device_register(
&rt5509_regmap_props, regmap_ops, parent, client, drvdata);
#else
return 0;
#endif /* #ifdef CONFIG_RT_REGMAP */
}
EXPORT_SYMBOL_GPL(rt5509_regmap_register);