/* * Copyright (C) 2017 Semtech Corporation. All rights reserved. * * Copyright (C) 2013 Samsung Electronics. All rights reserved. * * 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 the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA */ #ifndef _SX9330_I2C_REG_H_ #define _SX9330_I2C_REG_H_ /* * I2C Registers */ #define SX9330_HOSTIRQSRC_REG 0x4000 #define SX9330_HOSTIRQMSK_REG 0x4004 #define SX9330_HOSTIRQCTRL_REG 0x4008 #define SX9330_PAUSESTAT_REG 0x4010 #define SX9330_AFECTRL_REG 0x4054 #define SX9330_PWM_REG 0x4080 #define SX9330_CLKGEN_REG 0x4200 #define SX9330_I2CADDR_REG 0x41C4 #define SX9330_RESET_REG 0x4240 #define SX9330_CMD_REG 0x4280 #define SX9330_TOPSTAT0_REG 0x4284 #define SX9330_PINCFG_REG 0x42C0 #define SX9330_PINDOUT_REG 0x42C4 #define SX9330_PINDIN_REG 0x42C8 #define SX9330_INFO_REG 0x42D8 #define SX9330_STAT0_REG 0x8000 #define SX9330_STAT1_REG 0x8004 #define SX9330_STAT2_REG 0x8008 #define SX9330_IRQCFG0_REG 0x800C #define SX9330_IRQCFG1_REG 0x8010 #define SX9330_IRQCFG2_REG 0x8014 #define SX9330_IRQCFG3_REG 0x8018 #define SX9330_SCANPERIOD_REG 0x801C #define SX9330_GNRLCTRL2_REG 0x8020 #define SX9330_AFEPARAMSPH0_REG 0x8024 #define SX9330_AFEPHPH0_REG 0x8028 #define SX9330_AFEPARAMSPH1_REG 0x802C #define SX9330_AFEPHPH1_REG 0x8030 #define SX9330_AFEPARAMSPH2_REG 0x8034 #define SX9330_AFEPHPH2_REG 0x8038 #define SX9330_AFEPARAMSPH3_REG 0x803C #define SX9330_AFEPHPH3_REG 0x8040 #define SX9330_AFEPARAMSPH4_REG 0x8044 #define SX9330_AFEPHPH4_REG 0x8048 #define SX9330_AFEPARAMSPH5_REG 0x804c #define SX9330_AFEPHPH5_REG 0x8050 #define SX9330_AFEPARAMSPH6_REG 0x8054 #define SX9330_AFEPHPH6_REG 0x8058 #define SX9330_AFEPARAMSPH7_REG 0x805c #define SX9330_AFEPHPH7_REG 0x8060 #define SX9330_ADCFILTPH0_REG 0x8064 #define SX9330_AVGBFILTPH0_REG 0x8068 #define SX9330_AVGAFILTPH0_REG 0x806C #define SX9330_ADVDIG0PH0_REG 0x8070 #define SX9330_ADVDIG1PH0_REG 0x8074 #define SX9330_ADVDIG2PH0_REG 0x8078 #define SX9330_ADVDIG3PH0_REG 0x807C #define SX9330_ADVDIG4PH0_REG 0x8080 #define SX9330_ADCFILTPH1_REG 0x8084 #define SX9330_AVGBFILTPH1_REG 0x8088 #define SX9330_AVGAFILTPH1_REG 0x808C #define SX9330_ADVDIG0PH1_REG 0x8090 #define SX9330_ADVDIG1PH1_REG 0x8094 #define SX9330_ADVDIG2PH1_REG 0x8098 #define SX9330_ADVDIG3PH1_REG 0x809C #define SX9330_ADVDIG4PH1_REG 0x80A0 #define SX9330_ADCFILTPH2_REG 0x80A4 #define SX9330_AVGBFILTPH2_REG 0x80A8 #define SX9330_AVGAFILTPH2_REG 0x80AC #define SX9330_ADVDIG0PH2_REG 0x80B0 #define SX9330_ADVDIG1PH2_REG 0x80B4 #define SX9330_ADVDIG2PH2_REG 0x80B8 #define SX9330_ADVDIG3PH2_REG 0x80BC #define SX9330_ADVDIG4PH2_REG 0x80C0 #define SX9330_ADCFILTPH3_REG 0x80C4 #define SX9330_AVGBFILTPH3_REG 0x80C8 #define SX9330_AVGAFILTPH3_REG 0x80CC #define SX9330_ADVDIG0PH3_REG 0x80D0 #define SX9330_ADVDIG1PH3_REG 0x80D4 #define SX9330_ADVDIG2PH3_REG 0x80D8 #define SX9330_ADVDIG3PH3_REG 0x80DC #define SX9330_ADVDIG4PH3_REG 0x80E0 #define SX9330_ADCFILTPH4_REG 0x80E4 #define SX9330_AVGBFILTPH4_REG 0x80E8 #define SX9330_AVGAFILTPH4_REG 0x80EC #define SX9330_ADVDIG0PH4_REG 0x80F0 #define SX9330_ADVDIG1PH4_REG 0x80F4 #define SX9330_ADVDIG2PH4_REG 0x80F8 #define SX9330_ADVDIG3PH4_REG 0x80FC #define SX9330_ADVDIG4PH4_REG 0x8100 #define SX9330_ADCFILTPH5_REG 0x8104 #define SX9330_AVGBFILTPH5_REG 0x8108 #define SX9330_AVGAFILTPH5_REG 0x810C #define SX9330_ADVDIG0PH5_REG 0x8110 #define SX9330_ADVDIG1PH5_REG 0x8114 #define SX9330_ADVDIG2PH5_REG 0x8118 #define SX9330_ADVDIG3PH5_REG 0x811C #define SX9330_ADVDIG4PH5_REG 0x8120 #define SX9330_ADCFILTPH6_REG 0x8124 #define SX9330_AVGBFILTPH6_REG 0x8128 #define SX9330_AVGAFILTPH6_REG 0x812C #define SX9330_ADVDIG0PH6_REG 0x8130 #define SX9330_ADVDIG1PH6_REG 0x8134 #define SX9330_ADVDIG2PH6_REG 0x8138 #define SX9330_ADVDIG3PH6_REG 0x813C #define SX9330_ADVDIG4PH6_REG 0x8140 #define SX9330_ADCFILTPH7_REG 0x8144 #define SX9330_AVGBFILTPH7_REG 0x8148 #define SX9330_AVGAFILTPH7_REG 0x814C #define SX9330_ADVDIG0PH7_REG 0x8150 #define SX9330_ADVDIG1PH7_REG 0x8154 #define SX9330_ADVDIG2PH7_REG 0x8158 #define SX9330_ADVDIG3PH7_REG 0x815C #define SX9330_ADVDIG4PH7_REG 0x8160 #define SX9330_STEPCANCEL0A_REG 0x8164 #define SX9330_STEPCANCEL1A_REG 0x8168 #define SX9330_STEPCANCEL0B_REG 0x816C #define SX9330_STEPCANCEL1B_REG 0x8170 #define SX9330_REFCORRA_REG 0x8174 #define SX9330_REFCORRB_REG 0x8178 #define SX9330_SMARTSAR0A_REG 0x817C #define SX9330_SMARTSAR1A_REG 0x8180 #define SX9330_SMARTSAR2A_REG 0x8184 #define SX9330_SMARTSAR3A_REG 0x8188 #define SX9330_SMARTSAR4A_REG 0x818C #define SX9330_SMARTSAR0B_REG 0x8190 #define SX9330_SMARTSAR1B_REG 0x8194 #define SX9330_SMARTSAR2B_REG 0x8198 #define SX9330_SMARTSAR3B_REG 0x819C #define SX9330_SMARTSAR4B_REG 0x81A0 #define SX9330_PROX2PWMA_REG 0x81A4 #define SX9330_AUTOFREQ0_REG 0x81AC #define SX9330_AUTOFREQ1_REG 0x81B0 #define SX9330_USEPH0_REG 0x81B4 #define SX9330_USEPH1_REG 0x81B8 #define SX9330_USEPH2_REG 0x81BC #define SX9330_USEPH3_REG 0x81C0 #define SX9330_USEPH4_REG 0x81C4 #define SX9330_USEPH5_REG 0x81C8 #define SX9330_USEPH6_REG 0x81CC #define SX9330_USEPH7_REG 0x81D0 #define SX9330_AVGPH0_REG 0x81D4 #define SX9330_AVGPH1_REG 0x81D8 #define SX9330_AVGPH2_REG 0x81DC #define SX9330_AVGPH3_REG 0x81E0 #define SX9330_AVGPH4_REG 0x81E4 #define SX9330_AVGPH5_REG 0x81E8 #define SX9330_AVGPH6_REG 0x81EC #define SX9330_AVGPH7_REG 0x81F0 #define SX9330_DIFFPH0_REG 0x81F4 #define SX9330_DIFFPH1_REG 0x81F8 #define SX9330_DIFFPH2_REG 0x81FC #define SX9330_DIFFPH3_REG 0x8200 #define SX9330_DIFFPH4_REG 0x8204 #define SX9330_DIFFPH5_REG 0x8208 #define SX9330_DIFFPH6_REG 0x820C #define SX9330_DIFFPH7_REG 0x8210 #define SX9330_DBGVARSEL_REG 0X8214 #define SX9330_OFFSETPH0_REG SX9330_AFEPHPH0_REG //bit14:0 #define SX9330_OFFSETPH1_REG SX9330_AFEPHPH1_REG //bit14:0 #define SX9330_OFFSETPH2_REG SX9330_AFEPHPH2_REG //bit14:0 #define SX9330_OFFSETPH3_REG SX9330_AFEPHPH3_REG //bit14:0 #define SX9330_OFFSETPH4_REG SX9330_AFEPHPH4_REG //bit14:0 #define SX9330_OFFSETPH5_REG SX9330_AFEPHPH5_REG //bit14:0 #define SX9330_OFFSETPH6_REG SX9330_AFEPHPH6_REG //bit14:0 #define SX9330_OFFSETPH7_REG SX9330_AFEPHPH7_REG //bit14:0 //i2c register bit mask #define MSK_IRQSTAT_RESET 0x00000080 #define MSK_IRQSTAT_TOUCH 0x00000040 #define MSK_IRQSTAT_RELEASE 0x00000020 #define MSK_IRQSTAT_COMP 0x00000010 #define MSK_IRQSTAT_CONV 0x00000008 #define MSK_IRQSTAT_PROG2IRQ 0x00000004 #define MSK_IRQSTAT_PROG1IRQ 0x00000002 #define MSK_IRQSTAT_PROG0IRQ 0x00000001 #define I2C_SOFTRESET_VALUE 0x000000DE #define I2C_REGCMD_PHEN 0x0000000F #define I2C_REGCMD_COMPEN 0x0000000E #define I2C_REGCMD_EN_SLEEP 0x0000000D #define I2C_REGCMD_EX_SLEEP 0x0000000C #define I2C_REGGNRLCTRL2_PHEN_MSK 0x000000FF #define I2C_REGGNRLCTRL2_COMPEN_MSK 0x00ff0000 #define MSK_TOPSTAT0_CMDBUSY 0x0001 #define MSK_STAT1_CONVSTAT ((long int)0x01<<7) #define MSK_REGSTAT0_STEADYSTAT7 0x80 #define MSK_REGSTAT0_STEADYSTAT6 0x40 #define MSK_REGSTAT0_STEADYSTAT5 0x20 #define MSK_REGSTAT0_STEADYSTAT4 0x10 #define MSK_REGSTAT0_STEADYSTAT3 0x08 #define MSK_REGSTAT0_STEADYSTAT2 0x04 #define MSK_REGSTAT0_STEADYSTAT1 0x02 #define MSK_REGSTAT0_STEADYSTAT0 0x01 #define MSK_REGSTAT0_BODYSTAT7 ((long int)0x80<<8) #define MSK_REGSTAT0_BODYSTAT6 ((long int)0x40<<8) #define MSK_REGSTAT0_BODYSTAT5 ((long int)0x20<<8) #define MSK_REGSTAT0_BODYSTAT4 ((long int)0x10<<8) #define MSK_REGSTAT0_BODYSTAT3 ((long int)0x08<<8) #define MSK_REGSTAT0_BODYSTAT2 ((long int)0x04<<8) #define MSK_REGSTAT0_BODYSTAT1 ((long int)0x02<<8) #define MSK_REGSTAT0_BODYSTAT0 ((long int)0x01<<8) #define MSK_REGSTAT0_TABLESTAT7 ((long int)0x80<<16) #define MSK_REGSTAT0_TABLESTAT6 ((long int)0x40<<16) #define MSK_REGSTAT0_TABLESTAT5 ((long int)0x20<<16) #define MSK_REGSTAT0_TABLESTAT4 ((long int)0x10<<16) #define MSK_REGSTAT0_TABLESTAT3 ((long int)0x08<<16) #define MSK_REGSTAT0_TABLESTAT2 ((long int)0x04<<16) #define MSK_REGSTAT0_TABLESTAT1 ((long int)0x02<<16) #define MSK_REGSTAT0_TABLESTAT0 ((long int)0x01<<16) #define MSK_REGSTAT0_PROXSTAT7 ((long int)0x80<<24) #define MSK_REGSTAT0_PROXSTAT6 ((long int)0x40<<24) #define MSK_REGSTAT0_PROXSTAT5 ((long int)0x20<<24) #define MSK_REGSTAT0_PROXSTAT4 ((long int)0x10<<24) #define MSK_REGSTAT0_PROXSTAT3 ((long int)0x08<<24) #define MSK_REGSTAT0_PROXSTAT2 ((long int)0x04<<24) #define MSK_REGSTAT0_PROXSTAT1 ((long int)0x02<<24) #define MSK_REGSTAT0_PROXSTAT0 ((long int)0x01<<24) #define MSK_REGSTAT1_FAILSTAT7 ((long int)0x80<<24) #define MSK_REGSTAT1_FAILSTAT6 ((long int)0x40<<24) #define MSK_REGSTAT1_FAILSTAT5 ((long int)0x20<<24) #define MSK_REGSTAT1_FAILSTAT4 ((long int)0x10<<24) #define MSK_REGSTAT1_FAILSTAT3 ((long int)0x08<<24) #define MSK_REGSTAT1_FAILSTAT2 ((long int)0x04<<24) #define MSK_REGSTAT1_FAILSTAT1 ((long int)0x02<<24) #define MSK_REGSTAT1_FAILSTAT0 ((long int)0x01<<24) #define MSK_REGSTAT1_COMPSTAT7 ((long int)0x80<<16) #define MSK_REGSTAT1_COMPSTAT6 ((long int)0x40<<16) #define MSK_REGSTAT1_COMPSTAT5 ((long int)0x20<<16) #define MSK_REGSTAT1_COMPSTAT4 ((long int)0x10<<16) #define MSK_REGSTAT1_COMPSTAT3 ((long int)0x08<<16) #define MSK_REGSTAT1_COMPSTAT2 ((long int)0x04<<16) #define MSK_REGSTAT1_COMPSTAT1 ((long int)0x02<<16) #define MSK_REGSTAT1_COMPSTAT0 ((long int)0x01<<16) #define MSK_REGSTAT1_SATSTAT7 ((long int)0x80<<8) #define MSK_REGSTAT1_SATSTAT6 ((long int)0x40<<8) #define MSK_REGSTAT1_SATSTAT5 ((long int)0x20<<8) #define MSK_REGSTAT1_SATSTAT4 ((long int)0x10<<8) #define MSK_REGSTAT1_SATSTAT3 ((long int)0x08<<8) #define MSK_REGSTAT1_SATSTAT2 ((long int)0x04<<8) #define MSK_REGSTAT1_SATSTAT1 ((long int)0x02<<8) #define MSK_REGSTAT1_SATSTAT0 ((long int)0x01<<8) #define MSK_REGSTAT1_STEPSTATB ((long int)0x02<<5) #define MSK_REGSTAT1_STEPSTATA ((long int)0x01<<5) #define MSK_REGSTAT2_STARTUPSTAT7 ((long int)0x80) #define MSK_REGSTAT2_STARTUPSTAT6 ((long int)0x40) #define MSK_REGSTAT2_STARTUPSTAT5 ((long int)0x20) #define MSK_REGSTAT2_STARTUPSTAT4 ((long int)0x10) #define MSK_REGSTAT2_STARTUPSTAT3 ((long int)0x08) #define MSK_REGSTAT2_STARTUPSTAT2 ((long int)0x04) #define MSK_REGSTAT2_STARTUPSTAT1 ((long int)0x02) #define MSK_REGSTAT2_STARTUPSTAT0 ((long int)0x01) #define MSK_REGSTAT1_STEADYSTATALL 0x02 #define MSK_REG_STEP_CANCEL0_A_PH ((long int)0x07<<26) #define MSK_REG_STEP_CANCEL0_B_PH ((long int)0x07<<26) #define SX9330_STAT0_PROXSTAT_PH7_FLAG 0x80 #define SX9330_STAT0_PROXSTAT_PH6_FLAG 0x40 #define SX9330_STAT0_PROXSTAT_PH5_FLAG 0x20 #define SX9330_STAT0_PROXSTAT_PH4_FLAG 0x10 #define SX9330_STAT0_PROXSTAT_PH3_FLAG 0x08 #define SX9330_STAT0_PROXSTAT_PH2_FLAG 0x04 #define SX9330_STAT0_PROXSTAT_PH1_FLAG 0x02 #define SX9330_STAT0_PROXSTAT_PH0_FLAG 0x01 struct smtc_reg_data { unsigned short reg; unsigned int val; }; enum { SX9330_SCANPERIOD_REG_IDX = 10, SX9330_GNRLCTRL2_REG_IDX = 11, SX9330_AFEPARAMSPH0_REG_IDX = 12, SX9330_AFEPHPH0_REG_IDX = 13, SX9330_ADCFILTPH0_REG_IDX = 28, SX9330_AVGBFILTPH0_REG_IDX = 29, SX9330_AVGAFILTPH0_REG_IDX = 30, SX9330_ADVDIG3PH0_REG_IDX = 34, SX9330_ADVDIG4PH0_REG_IDX = 35, SX9330_REFCORRA_REG_IDX = 96 }; /* for device tree parse */ #define SX9330_SCANPERIOD "sx9330,scanperiod_reg" #define SX9330_GNRLCTRL2 "sx9330,gnrlctrl2_reg" #define SX9330_AFEPARAMSPH0 "sx9330,afeparamsph0_reg" #define SX9330_AFEPHPH0 "sx9330,afephph0_reg" #define SX9330_ADCFILTPH0 "sx9330,adcfiltph0_reg" #define SX9330_AFEPARAMSPH1 "sx9330,afeparamsph1_reg" #define SX9330_ADCFILTPH1 "sx9330,adcfiltph1_reg" #define SX9330_AVGBFILT "sx9330,avgbfilt_reg" #define SX9330_AVGAFILT "sx9330,avgafilt_reg" #define SX9330_ADVDIG3 "sx9330,advdig3_reg" #define SX9330_ADVDIG4 "sx9330,advdig4_reg" #define SX9330_REFCORRA "sx9330,refcorra_reg" /*define the value without Phase enable settings for easy changes in driver*/ static struct smtc_reg_data setup_reg[] = { { .reg = SX9330_CMD_REG, .val = I2C_REGCMD_PHEN, }, { .reg = SX9330_AFECTRL_REG, .val = 0x00000400, }, { .reg = SX9330_PWM_REG, .val = 0x80804000, }, { .reg = SX9330_CLKGEN_REG, .val = 0x00000008, }, { .reg = SX9330_PINCFG_REG, .val = 0x08000000, }, { .reg = SX9330_PINDOUT_REG, .val = 0x00000000, }, { .reg = SX9330_IRQCFG0_REG, .val = 0x00000000, }, { .reg = SX9330_IRQCFG1_REG, .val = 0x00000000, }, { .reg = SX9330_IRQCFG2_REG, .val = 0x00000000, }, { .reg = SX9330_IRQCFG3_REG, .val = 0x00000000, }, { .reg = SX9330_SCANPERIOD_REG, .val = 0x0000000F, }, { .reg = SX9330_GNRLCTRL2_REG, .val = 0x00FF0003, /* [COMPEN : xFF] [PHEN : 0, 1] */ }, { .reg = SX9330_AFEPARAMSPH0_REG, .val = 0x00000405, /* [FREQ : 250Hz] [RESOLUTION : 256] */ }, { .reg = SX9330_AFEPHPH0_REG, .val = 0x00028000, /* [CSIO0 Measured Input] */ }, { .reg = SX9330_AFEPARAMSPH1_REG, .val = 0x20000447, /* [RINT_PH1 : High] [AGAIN_PH1 : 1.65pF] [FREQ_PH1 : 83.33kHz] [RESOLUTION : 1024] */ }, { .reg = SX9330_AFEPHPH1_REG, .val = 0x00140000, /* [CSIO1 Measured Input] */ }, { .reg = SX9330_AFEPARAMSPH2_REG, .val = 0x00000444, }, { .reg = SX9330_AFEPHPH2_REG, .val = 0x00000000, }, { .reg = SX9330_AFEPARAMSPH3_REG, .val = 0x00000444, }, { .reg = SX9330_AFEPHPH3_REG, .val = 0x00000000, }, { .reg = SX9330_AFEPARAMSPH4_REG, .val = 0x00000444, }, { .reg = SX9330_AFEPHPH4_REG, .val = 0x00000000, }, { .reg = SX9330_AFEPARAMSPH5_REG, .val = 0x00000444, }, { .reg = SX9330_AFEPHPH5_REG, .val = 0x00000000, }, { .reg = SX9330_AFEPARAMSPH6_REG, .val = 0x00000444, }, { .reg = SX9330_AFEPHPH6_REG, .val = 0x00000000, }, { .reg = SX9330_AFEPARAMSPH7_REG, .val = 0x00000444, }, { .reg = SX9330_AFEPHPH7_REG, .val = 0x00000000, }, { .reg = SX9330_ADCFILTPH0_REG, .val = 0x00700000, /* [RAWFILT : 1-1/128] */ }, { .reg = SX9330_AVGBFILTPH0_REG, .val = 0x60600B00, }, { .reg = SX9330_AVGAFILTPH0_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG0PH0_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG1PH0_REG, .val = 0x706447, }, { .reg = SX9330_ADVDIG2PH0_REG, .val = 0x15050200, }, { .reg = SX9330_ADVDIG3PH0_REG , .val = 0x00000000, }, { .reg = SX9330_ADVDIG4PH0_REG, .val = 0x00000000, }, { .reg = SX9330_ADCFILTPH1_REG, .val = 0x002A5F10, /* [RAWFILT : 1-1/4] [ADCFILTSAMPLES : 1-1/4] [ADCFILTCOEF : 1/4] [PROXTHRESH : 4512] [HYST_PH : +/-6%] */ }, { .reg = SX9330_AVGBFILTPH1_REG, .val = 0x20600080, /* [AVGNEGILT : off] [AVGPOSFILT : off] [USETHRSHNODET : 5] */ }, { .reg = SX9330_AVGAFILTPH1_REG, .val = 0x40C0170A, /* [USETHRSHDETPOS : 4] [USETHRSHDETNEG : -4] [USECORRDETNEG : -6] [USEFILTENABLE : on] [USECORRNODET : 7] [USECORRDETNEG : -6] */ }, { .reg = SX9330_ADVDIG0PH1_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG1PH1_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG2PH1_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG3PH1_REG , .val = 0x40004000, /* [REFCOEFINCA : 1.25] [REFCOEFDECA : 1.25] */ }, { .reg = SX9330_ADVDIG4PH1_REG, .val = 0x00010000, /* [REFCORRENABLE : Engine A only] */ }, { .reg = SX9330_ADCFILTPH2_REG, .val = 0x100000, }, { .reg = SX9330_AVGBFILTPH2_REG, .val = 0x20600C00, }, { .reg = SX9330_AVGAFILTPH2_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG0PH2_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG1PH2_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG2PH2_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG3PH2_REG , .val = 0x00000000, }, { .reg = SX9330_ADVDIG4PH2_REG, .val = 0x00000000, }, { .reg = SX9330_ADCFILTPH3_REG, .val = 0x100000, }, { .reg = SX9330_AVGBFILTPH3_REG, .val = 0x20600C00, }, { .reg = SX9330_AVGAFILTPH3_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG0PH3_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG1PH3_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG2PH3_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG3PH3_REG , .val = 0x00000000, }, { .reg = SX9330_ADVDIG4PH3_REG, .val = 0x00000000, }, { .reg = SX9330_ADCFILTPH4_REG, .val = 0x100000, }, { .reg = SX9330_AVGBFILTPH4_REG, .val = 0x20600C00, }, { .reg = SX9330_AVGAFILTPH4_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG0PH4_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG1PH4_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG2PH4_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG3PH4_REG , .val = 0x00000000, }, { .reg = SX9330_ADVDIG4PH4_REG, .val = 0x00000000, }, { .reg = SX9330_ADCFILTPH5_REG, .val = 0x100000, }, { .reg = SX9330_AVGBFILTPH5_REG, .val = 0x20600C00, }, { .reg = SX9330_AVGAFILTPH5_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG0PH5_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG1PH5_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG2PH5_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG3PH5_REG , .val = 0x00000000, }, { .reg = SX9330_ADVDIG4PH5_REG, .val = 0x00000000, }, { .reg = SX9330_ADCFILTPH6_REG, .val = 0x100000, }, { .reg = SX9330_AVGBFILTPH6_REG, .val = 0x20600C00, }, { .reg = SX9330_AVGAFILTPH6_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG0PH6_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG1PH6_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG2PH6_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG3PH6_REG , .val = 0x00000000, }, { .reg = SX9330_ADVDIG4PH6_REG, .val = 0x00000000, }, { .reg = SX9330_ADCFILTPH7_REG, .val = 0x100000, }, { .reg = SX9330_AVGBFILTPH7_REG, .val = 0x20600C00, }, { .reg = SX9330_AVGAFILTPH7_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG0PH7_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG1PH7_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG2PH7_REG, .val = 0x00000000, }, { .reg = SX9330_ADVDIG3PH7_REG , .val = 0x00000000, }, { .reg = SX9330_ADVDIG4PH7_REG, .val = 0x00000000, }, { .reg = SX9330_STEPCANCEL0A_REG, .val = 0x00000000, }, { .reg = SX9330_STEPCANCEL1A_REG, .val = 0x00000000, }, { .reg = SX9330_STEPCANCEL0B_REG, .val = 0x00000000, }, { .reg = SX9330_STEPCANCEL1B_REG, .val = 0x00000000, }, { .reg = SX9330_REFCORRA_REG, .val = 0x04000008, /* [REFENABLE : ON, engine A] [REFINIT : b1] */ }, { .reg = SX9330_REFCORRB_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR0A_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR1A_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR2A_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR3A_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR4A_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR0B_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR1B_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR2B_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR3B_REG, .val = 0x00000000, }, { .reg = SX9330_SMARTSAR4B_REG, .val = 0x00000000, }, { .reg = SX9330_PROX2PWMA_REG, .val = 0x00000000, }, { .reg = SX9330_AUTOFREQ0_REG, .val = 0x000000FF, }, { .reg = SX9330_AUTOFREQ1_REG, .val = 0x0000000E, }, { .reg = SX9330_HOSTIRQMSK_REG, .val = 0x00000000, }, { .reg = SX9330_HOSTIRQCTRL_REG, .val = 0x00000000, }, { .reg = SX9330_DBGVARSEL_REG, .val = 0x01B00008, /* [PHASESEL : 1] */ }, }; enum { OFF = 0, ON = 1 }; #endif /* _SX9330_I2C_REG_H_*/