1*4882a593Smuzhiyun /* linux/mfd/tps6507x.h 2*4882a593Smuzhiyun * 3*4882a593Smuzhiyun * Functions to access TPS65070 power management chip. 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (c) 2009 RidgeRun (todd.fischer@ridgerun.com) 6*4882a593Smuzhiyun * 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun * For licencing details see kernel-base/COPYING 9*4882a593Smuzhiyun */ 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #ifndef __LINUX_MFD_TPS6507X_H 12*4882a593Smuzhiyun #define __LINUX_MFD_TPS6507X_H 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun /* 15*4882a593Smuzhiyun * ---------------------------------------------------------------------------- 16*4882a593Smuzhiyun * Registers, all 8 bits 17*4882a593Smuzhiyun * ---------------------------------------------------------------------------- 18*4882a593Smuzhiyun */ 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun /* Register definitions */ 22*4882a593Smuzhiyun #define TPS6507X_REG_PPATH1 0X01 23*4882a593Smuzhiyun #define TPS6507X_CHG_USB BIT(7) 24*4882a593Smuzhiyun #define TPS6507X_CHG_AC BIT(6) 25*4882a593Smuzhiyun #define TPS6507X_CHG_USB_PW_ENABLE BIT(5) 26*4882a593Smuzhiyun #define TPS6507X_CHG_AC_PW_ENABLE BIT(4) 27*4882a593Smuzhiyun #define TPS6507X_CHG_AC_CURRENT BIT(2) 28*4882a593Smuzhiyun #define TPS6507X_CHG_USB_CURRENT BIT(0) 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun #define TPS6507X_REG_INT 0X02 31*4882a593Smuzhiyun #define TPS6507X_REG_MASK_AC_USB BIT(7) 32*4882a593Smuzhiyun #define TPS6507X_REG_MASK_TSC BIT(6) 33*4882a593Smuzhiyun #define TPS6507X_REG_MASK_PB_IN BIT(5) 34*4882a593Smuzhiyun #define TPS6507X_REG_TSC_INT BIT(3) 35*4882a593Smuzhiyun #define TPS6507X_REG_PB_IN_INT BIT(2) 36*4882a593Smuzhiyun #define TPS6507X_REG_AC_USB_APPLIED BIT(1) 37*4882a593Smuzhiyun #define TPS6507X_REG_AC_USB_REMOVED BIT(0) 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun #define TPS6507X_REG_CHGCONFIG0 0X03 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun #define TPS6507X_REG_CHGCONFIG1 0X04 42*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_DCDC1_ENABLE BIT(4) 43*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_DCDC2_ENABLE BIT(3) 44*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_DCDC3_ENABLE BIT(2) 45*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_LDO1_ENABLE BIT(1) 46*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_LDO2_ENABLE BIT(0) 47*4882a593Smuzhiyun 48*4882a593Smuzhiyun #define TPS6507X_REG_CHGCONFIG2 0X05 49*4882a593Smuzhiyun 50*4882a593Smuzhiyun #define TPS6507X_REG_CHGCONFIG3 0X06 51*4882a593Smuzhiyun 52*4882a593Smuzhiyun #define TPS6507X_REG_ADCONFIG 0X07 53*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_AD_ENABLE BIT(7) 54*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_START_CONVERSION BIT(6) 55*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_CONVERSION_DONE BIT(5) 56*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_VREF_ENABLE BIT(4) 57*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_AD_IN1 0 58*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_AD_IN2 1 59*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_AD_IN3 2 60*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_AD_IN4 3 61*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_TS_PIN 4 62*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_BAT_CURRENT 5 63*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_AC_VOLTAGE 6 64*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_SYS_VOLTAGE 7 65*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_CHARGER_VOLTAGE 8 66*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_BAT_VOLTAGE 9 67*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_THRESHOLD_VOLTAGE 10 68*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_ISET1_VOLTAGE 11 69*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_ISET2_VOLTAGE 12 70*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_REAL_TSC 14 71*4882a593Smuzhiyun #define TPS6507X_ADCONFIG_INPUT_TSC 15 72*4882a593Smuzhiyun 73*4882a593Smuzhiyun #define TPS6507X_REG_TSCMODE 0X08 74*4882a593Smuzhiyun #define TPS6507X_TSCMODE_X_POSITION 0 75*4882a593Smuzhiyun #define TPS6507X_TSCMODE_Y_POSITION 1 76*4882a593Smuzhiyun #define TPS6507X_TSCMODE_PRESSURE 2 77*4882a593Smuzhiyun #define TPS6507X_TSCMODE_X_PLATE 3 78*4882a593Smuzhiyun #define TPS6507X_TSCMODE_Y_PLATE 4 79*4882a593Smuzhiyun #define TPS6507X_TSCMODE_STANDBY 5 80*4882a593Smuzhiyun #define TPS6507X_TSCMODE_ADC_INPUT 6 81*4882a593Smuzhiyun #define TPS6507X_TSCMODE_DISABLE 7 82*4882a593Smuzhiyun 83*4882a593Smuzhiyun #define TPS6507X_REG_ADRESULT_1 0X09 84*4882a593Smuzhiyun 85*4882a593Smuzhiyun #define TPS6507X_REG_ADRESULT_2 0X0A 86*4882a593Smuzhiyun #define TPS6507X_REG_ADRESULT_2_MASK (BIT(1) | BIT(0)) 87*4882a593Smuzhiyun 88*4882a593Smuzhiyun #define TPS6507X_REG_PGOOD 0X0B 89*4882a593Smuzhiyun 90*4882a593Smuzhiyun #define TPS6507X_REG_PGOODMASK 0X0C 91*4882a593Smuzhiyun 92*4882a593Smuzhiyun #define TPS6507X_REG_CON_CTRL1 0X0D 93*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_DCDC1_ENABLE BIT(4) 94*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_DCDC2_ENABLE BIT(3) 95*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_DCDC3_ENABLE BIT(2) 96*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_LDO1_ENABLE BIT(1) 97*4882a593Smuzhiyun #define TPS6507X_CON_CTRL1_LDO2_ENABLE BIT(0) 98*4882a593Smuzhiyun 99*4882a593Smuzhiyun #define TPS6507X_REG_CON_CTRL2 0X0E 100*4882a593Smuzhiyun 101*4882a593Smuzhiyun #define TPS6507X_REG_CON_CTRL3 0X0F 102*4882a593Smuzhiyun 103*4882a593Smuzhiyun #define TPS6507X_REG_DEFDCDC1 0X10 104*4882a593Smuzhiyun #define TPS6507X_DEFDCDC1_DCDC1_EXT_ADJ_EN BIT(7) 105*4882a593Smuzhiyun #define TPS6507X_DEFDCDC1_DCDC1_MASK 0X3F 106*4882a593Smuzhiyun 107*4882a593Smuzhiyun #define TPS6507X_REG_DEFDCDC2_LOW 0X11 108*4882a593Smuzhiyun #define TPS6507X_DEFDCDC2_LOW_DCDC2_MASK 0X3F 109*4882a593Smuzhiyun 110*4882a593Smuzhiyun #define TPS6507X_REG_DEFDCDC2_HIGH 0X12 111*4882a593Smuzhiyun #define TPS6507X_DEFDCDC2_HIGH_DCDC2_MASK 0X3F 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun #define TPS6507X_REG_DEFDCDC3_LOW 0X13 114*4882a593Smuzhiyun #define TPS6507X_DEFDCDC3_LOW_DCDC3_MASK 0X3F 115*4882a593Smuzhiyun 116*4882a593Smuzhiyun #define TPS6507X_REG_DEFDCDC3_HIGH 0X14 117*4882a593Smuzhiyun #define TPS6507X_DEFDCDC3_HIGH_DCDC3_MASK 0X3F 118*4882a593Smuzhiyun 119*4882a593Smuzhiyun #define TPS6507X_REG_DEFSLEW 0X15 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun #define TPS6507X_REG_LDO_CTRL1 0X16 122*4882a593Smuzhiyun #define TPS6507X_REG_LDO_CTRL1_LDO1_MASK 0X0F 123*4882a593Smuzhiyun 124*4882a593Smuzhiyun #define TPS6507X_REG_DEFLDO2 0X17 125*4882a593Smuzhiyun #define TPS6507X_REG_DEFLDO2_LDO2_MASK 0X3F 126*4882a593Smuzhiyun 127*4882a593Smuzhiyun #define TPS6507X_REG_WLED_CTRL1 0X18 128*4882a593Smuzhiyun 129*4882a593Smuzhiyun #define TPS6507X_REG_WLED_CTRL2 0X19 130*4882a593Smuzhiyun 131*4882a593Smuzhiyun /* VDCDC MASK */ 132*4882a593Smuzhiyun #define TPS6507X_DEFDCDCX_DCDC_MASK 0X3F 133*4882a593Smuzhiyun 134*4882a593Smuzhiyun #define TPS6507X_MAX_REGISTER 0X19 135*4882a593Smuzhiyun 136*4882a593Smuzhiyun /** 137*4882a593Smuzhiyun * struct tps6507x_board - packages regulator and touchscreen init data 138*4882a593Smuzhiyun * @tps6507x_regulator_data: regulator initialization values 139*4882a593Smuzhiyun * 140*4882a593Smuzhiyun * Board data may be used to initialize regulator and touchscreen. 141*4882a593Smuzhiyun */ 142*4882a593Smuzhiyun 143*4882a593Smuzhiyun struct tps6507x_board { 144*4882a593Smuzhiyun struct regulator_init_data *tps6507x_pmic_init_data; 145*4882a593Smuzhiyun struct touchscreen_init_data *tps6507x_ts_init_data; 146*4882a593Smuzhiyun }; 147*4882a593Smuzhiyun 148*4882a593Smuzhiyun /** 149*4882a593Smuzhiyun * struct tps6507x_dev - tps6507x sub-driver chip access routines 150*4882a593Smuzhiyun * @read_dev() - I2C register read function 151*4882a593Smuzhiyun * @write_dev() - I2C register write function 152*4882a593Smuzhiyun * 153*4882a593Smuzhiyun * Device data may be used to access the TPS6507x chip 154*4882a593Smuzhiyun */ 155*4882a593Smuzhiyun 156*4882a593Smuzhiyun struct tps6507x_dev { 157*4882a593Smuzhiyun struct device *dev; 158*4882a593Smuzhiyun struct i2c_client *i2c_client; 159*4882a593Smuzhiyun int (*read_dev)(struct tps6507x_dev *tps6507x, char reg, int size, 160*4882a593Smuzhiyun void *dest); 161*4882a593Smuzhiyun int (*write_dev)(struct tps6507x_dev *tps6507x, char reg, int size, 162*4882a593Smuzhiyun void *src); 163*4882a593Smuzhiyun 164*4882a593Smuzhiyun /* Client devices */ 165*4882a593Smuzhiyun struct tps6507x_pmic *pmic; 166*4882a593Smuzhiyun }; 167*4882a593Smuzhiyun 168*4882a593Smuzhiyun #endif /* __LINUX_MFD_TPS6507X_H */ 169