1*714165e1SJeff Chang // SPDX-License-Identifier: GPL-2.0 2*714165e1SJeff Chang // Copyright (C) 2025 Richtek Technology Corp. 3*714165e1SJeff Chang // Author: ChiYuan Huang <cy_huang@richtek.com> 4*714165e1SJeff Chang // Author: ShihChia Chang <jeff_chang@richtek.com> 5*714165e1SJeff Chang 6*714165e1SJeff Chang #include <linux/crc8.h> 7*714165e1SJeff Chang #include <linux/delay.h> 8*714165e1SJeff Chang #include <linux/gpio/consumer.h> 9*714165e1SJeff Chang #include <linux/gpio/driver.h> 10*714165e1SJeff Chang #include <linux/i2c.h> 11*714165e1SJeff Chang #include <linux/interrupt.h> 12*714165e1SJeff Chang #include <linux/kernel.h> 13*714165e1SJeff Chang #include <linux/module.h> 14*714165e1SJeff Chang #include <linux/of.h> 15*714165e1SJeff Chang #include <linux/regmap.h> 16*714165e1SJeff Chang #include <linux/regulator/driver.h> 17*714165e1SJeff Chang 18*714165e1SJeff Chang #define RT5133_REG_CHIP_INFO 0x00 19*714165e1SJeff Chang #define RT5133_REG_RST_CTRL 0x06 20*714165e1SJeff Chang #define RT5133_REG_BASE_CTRL 0x09 21*714165e1SJeff Chang #define RT5133_REG_GPIO_CTRL 0x0B 22*714165e1SJeff Chang #define RT5133_REG_BASE_EVT 0x10 23*714165e1SJeff Chang #define RT5133_REG_LDO_PGB_STAT 0x15 24*714165e1SJeff Chang #define RT5133_REG_BASE_MASK 0x16 25*714165e1SJeff Chang #define RT5133_REG_LDO_SHDN 0x19 26*714165e1SJeff Chang #define RT5133_REG_LDO_ON 0x1A 27*714165e1SJeff Chang #define RT5133_REG_LDO_OFF 0x1B 28*714165e1SJeff Chang #define RT5133_REG_LDO1_CTRL1 0x20 29*714165e1SJeff Chang #define RT5133_REG_LDO1_CTRL2 0x21 30*714165e1SJeff Chang #define RT5133_REG_LDO1_CTRL3 0x22 31*714165e1SJeff Chang #define RT5133_REG_LDO2_CTRL1 0x24 32*714165e1SJeff Chang #define RT5133_REG_LDO2_CTRL2 0x25 33*714165e1SJeff Chang #define RT5133_REG_LDO2_CTRL3 0x26 34*714165e1SJeff Chang #define RT5133_REG_LDO3_CTRL1 0x28 35*714165e1SJeff Chang #define RT5133_REG_LDO3_CTRL2 0x29 36*714165e1SJeff Chang #define RT5133_REG_LDO3_CTRL3 0x2A 37*714165e1SJeff Chang #define RT5133_REG_LDO4_CTRL1 0x2C 38*714165e1SJeff Chang #define RT5133_REG_LDO4_CTRL2 0x2D 39*714165e1SJeff Chang #define RT5133_REG_LDO4_CTRL3 0x2E 40*714165e1SJeff Chang #define RT5133_REG_LDO5_CTRL1 0x30 41*714165e1SJeff Chang #define RT5133_REG_LDO5_CTRL2 0x31 42*714165e1SJeff Chang #define RT5133_REG_LDO5_CTRL3 0x32 43*714165e1SJeff Chang #define RT5133_REG_LDO6_CTRL1 0x34 44*714165e1SJeff Chang #define RT5133_REG_LDO6_CTRL2 0x35 45*714165e1SJeff Chang #define RT5133_REG_LDO6_CTRL3 0x36 46*714165e1SJeff Chang #define RT5133_REG_LDO7_CTRL1 0x38 47*714165e1SJeff Chang #define RT5133_REG_LDO7_CTRL2 0x39 48*714165e1SJeff Chang #define RT5133_REG_LDO7_CTRL3 0x3A 49*714165e1SJeff Chang #define RT5133_REG_LDO8_CTRL1 0x3C 50*714165e1SJeff Chang #define RT5133_REG_LDO8_CTRL2 0x3D 51*714165e1SJeff Chang #define RT5133_REG_LDO8_CTRL3 0x3E 52*714165e1SJeff Chang #define RT5133_REG_LDO8_CTRL4 0x3F 53*714165e1SJeff Chang 54*714165e1SJeff Chang #define RT5133_LDO_REG_BASE(_id) (0x20 + ((_id) - 1) * 4) 55*714165e1SJeff Chang 56*714165e1SJeff Chang #define RT5133_VENDOR_ID_MASK GENMASK(7, 4) 57*714165e1SJeff Chang #define RT5133_RESET_CODE 0xB1 58*714165e1SJeff Chang 59*714165e1SJeff Chang #define RT5133_FOFF_BASE_MASK BIT(1) 60*714165e1SJeff Chang #define RT5133_OCSHDN_ALL_MASK BIT(7) 61*714165e1SJeff Chang #define RT5133_OCSHDN_ALL_SHIFT (7) 62*714165e1SJeff Chang #define RT5133_PGBSHDN_ALL_MASK BIT(6) 63*714165e1SJeff Chang #define RT5133_PGBSHDN_ALL_SHIFT (6) 64*714165e1SJeff Chang 65*714165e1SJeff Chang #define RT5133_OCPTSEL_MASK BIT(5) 66*714165e1SJeff Chang #define RT5133_PGBPTSEL_MASK BIT(4) 67*714165e1SJeff Chang #define RT5133_STBTDSEL_MASK GENMASK(1, 0) 68*714165e1SJeff Chang 69*714165e1SJeff Chang #define RT5133_LDO_ENABLE_MASK BIT(7) 70*714165e1SJeff Chang #define RT5133_LDO_VSEL_MASK GENMASK(7, 5) 71*714165e1SJeff Chang #define RT5133_LDO_AD_MASK BIT(2) 72*714165e1SJeff Chang #define RT5133_LDO_SOFT_START_MASK GENMASK(1, 0) 73*714165e1SJeff Chang 74*714165e1SJeff Chang #define RT5133_GPIO_NR 3 75*714165e1SJeff Chang 76*714165e1SJeff Chang #define RT5133_LDO_PGB_EVT_MASK GENMASK(23, 16) 77*714165e1SJeff Chang #define RT5133_LDO_PGB_EVT_SHIFT 16 78*714165e1SJeff Chang #define RT5133_LDO_OC_EVT_MASK GENMASK(15, 8) 79*714165e1SJeff Chang #define RT5133_LDO_OC_EVT_SHIFT 8 80*714165e1SJeff Chang #define RT5133_VREF_EVT_MASK BIT(6) 81*714165e1SJeff Chang #define RT5133_BASE_EVT_MASK GENMASK(7, 0) 82*714165e1SJeff Chang #define RT5133_INTR_CLR_MASK GENMASK(23, 0) 83*714165e1SJeff Chang #define RT5133_INTR_BYTE_NR 3 84*714165e1SJeff Chang 85*714165e1SJeff Chang #define RT5133_MAX_I2C_BLOCK_SIZE 1 86*714165e1SJeff Chang 87*714165e1SJeff Chang #define RT5133_CRC8_POLYNOMIAL 0x7 88*714165e1SJeff Chang 89*714165e1SJeff Chang #define RT5133_I2C_ADDR_LEN 1 90*714165e1SJeff Chang #define RT5133_PREDATA_LEN 2 91*714165e1SJeff Chang #define RT5133_I2C_CRC_LEN 1 92*714165e1SJeff Chang #define RT5133_REG_ADDR_LEN 1 93*714165e1SJeff Chang #define RT5133_I2C_DUMMY_LEN 1 94*714165e1SJeff Chang 95*714165e1SJeff Chang #define I2C_ADDR_XLATE_8BIT(_addr, _rw) ((((_addr) & 0x7F) << 1) | (_rw)) 96*714165e1SJeff Chang 97*714165e1SJeff Chang enum { 98*714165e1SJeff Chang RT5133_REGULATOR_BASE = 0, 99*714165e1SJeff Chang RT5133_REGULATOR_LDO1, 100*714165e1SJeff Chang RT5133_REGULATOR_LDO2, 101*714165e1SJeff Chang RT5133_REGULATOR_LDO3, 102*714165e1SJeff Chang RT5133_REGULATOR_LDO4, 103*714165e1SJeff Chang RT5133_REGULATOR_LDO5, 104*714165e1SJeff Chang RT5133_REGULATOR_LDO6, 105*714165e1SJeff Chang RT5133_REGULATOR_LDO7, 106*714165e1SJeff Chang RT5133_REGULATOR_LDO8, 107*714165e1SJeff Chang RT5133_REGULATOR_MAX 108*714165e1SJeff Chang }; 109*714165e1SJeff Chang 110*714165e1SJeff Chang struct chip_data { 111*714165e1SJeff Chang const struct regulator_desc *regulators; 112*714165e1SJeff Chang const u8 vendor_id; 113*714165e1SJeff Chang }; 114*714165e1SJeff Chang 115*714165e1SJeff Chang struct rt5133_priv { 116*714165e1SJeff Chang struct device *dev; 117*714165e1SJeff Chang struct regmap *regmap; 118*714165e1SJeff Chang struct gpio_desc *enable_gpio; 119*714165e1SJeff Chang struct regulator_dev *rdev[RT5133_REGULATOR_MAX]; 120*714165e1SJeff Chang struct gpio_chip gc; 121*714165e1SJeff Chang const struct chip_data *cdata; 122*714165e1SJeff Chang unsigned int gpio_output_flag; 123*714165e1SJeff Chang u8 crc8_tbls[CRC8_TABLE_SIZE]; 124*714165e1SJeff Chang }; 125*714165e1SJeff Chang 126*714165e1SJeff Chang static const unsigned int vout_type1_tables[] = { 127*714165e1SJeff Chang 1800000, 2500000, 2700000, 2800000, 2900000, 3000000, 3100000, 3200000 128*714165e1SJeff Chang }; 129*714165e1SJeff Chang 130*714165e1SJeff Chang static const unsigned int vout_type2_tables[] = { 131*714165e1SJeff Chang 1700000, 1800000, 1900000, 2500000, 2700000, 2800000, 2900000, 3000000 132*714165e1SJeff Chang }; 133*714165e1SJeff Chang 134*714165e1SJeff Chang static const unsigned int vout_type3_tables[] = { 135*714165e1SJeff Chang 900000, 950000, 1000000, 1050000, 1100000, 1150000, 1200000, 1800000 136*714165e1SJeff Chang }; 137*714165e1SJeff Chang 138*714165e1SJeff Chang static const unsigned int vout_type4_tables[] = { 139*714165e1SJeff Chang 855000, 900000, 950000, 1000000, 1040000, 1090000, 1140000, 1710000 140*714165e1SJeff Chang }; 141*714165e1SJeff Chang 142*714165e1SJeff Chang static const struct regulator_ops rt5133_regulator_ops = { 143*714165e1SJeff Chang .list_voltage = regulator_list_voltage_table, 144*714165e1SJeff Chang .set_voltage_sel = regulator_set_voltage_sel_regmap, 145*714165e1SJeff Chang .get_voltage_sel = regulator_get_voltage_sel_regmap, 146*714165e1SJeff Chang .enable = regulator_enable_regmap, 147*714165e1SJeff Chang .disable = regulator_disable_regmap, 148*714165e1SJeff Chang .is_enabled = regulator_is_enabled_regmap, 149*714165e1SJeff Chang .set_active_discharge = regulator_set_active_discharge_regmap, 150*714165e1SJeff Chang }; 151*714165e1SJeff Chang 152*714165e1SJeff Chang static const struct regulator_ops rt5133_base_regulator_ops = { 153*714165e1SJeff Chang .enable = regulator_enable_regmap, 154*714165e1SJeff Chang .disable = regulator_disable_regmap, 155*714165e1SJeff Chang .is_enabled = regulator_is_enabled_regmap, 156*714165e1SJeff Chang }; 157*714165e1SJeff Chang 158*714165e1SJeff Chang #define RT5133_REGULATOR_DESC(_name, _node_name, vtables, _supply) \ 159*714165e1SJeff Chang {\ 160*714165e1SJeff Chang .name = #_name,\ 161*714165e1SJeff Chang .id = RT5133_REGULATOR_##_name,\ 162*714165e1SJeff Chang .of_match = of_match_ptr(#_node_name),\ 163*714165e1SJeff Chang .regulators_node = of_match_ptr("regulators"),\ 164*714165e1SJeff Chang .supply_name = _supply,\ 165*714165e1SJeff Chang .type = REGULATOR_VOLTAGE,\ 166*714165e1SJeff Chang .owner = THIS_MODULE,\ 167*714165e1SJeff Chang .ops = &rt5133_regulator_ops,\ 168*714165e1SJeff Chang .n_voltages = ARRAY_SIZE(vtables),\ 169*714165e1SJeff Chang .volt_table = vtables,\ 170*714165e1SJeff Chang .enable_reg = RT5133_REG_##_name##_CTRL1,\ 171*714165e1SJeff Chang .enable_mask = RT5133_LDO_ENABLE_MASK,\ 172*714165e1SJeff Chang .vsel_reg = RT5133_REG_##_name##_CTRL2,\ 173*714165e1SJeff Chang .vsel_mask = RT5133_LDO_VSEL_MASK,\ 174*714165e1SJeff Chang .active_discharge_reg = RT5133_REG_##_name##_CTRL3,\ 175*714165e1SJeff Chang .active_discharge_mask = RT5133_LDO_AD_MASK,\ 176*714165e1SJeff Chang } 177*714165e1SJeff Chang 178*714165e1SJeff Chang static const struct regulator_desc rt5133_regulators[] = { 179*714165e1SJeff Chang /* For digital part, base current control */ 180*714165e1SJeff Chang { 181*714165e1SJeff Chang .name = "base", 182*714165e1SJeff Chang .id = RT5133_REGULATOR_BASE, 183*714165e1SJeff Chang .of_match = of_match_ptr("base"), 184*714165e1SJeff Chang .regulators_node = of_match_ptr("regulators"), 185*714165e1SJeff Chang .type = REGULATOR_VOLTAGE, 186*714165e1SJeff Chang .owner = THIS_MODULE, 187*714165e1SJeff Chang .ops = &rt5133_base_regulator_ops, 188*714165e1SJeff Chang .enable_reg = RT5133_REG_BASE_CTRL, 189*714165e1SJeff Chang .enable_mask = RT5133_FOFF_BASE_MASK, 190*714165e1SJeff Chang .enable_is_inverted = true, 191*714165e1SJeff Chang }, 192*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO1, ldo1, vout_type1_tables, "base"), 193*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO2, ldo2, vout_type1_tables, "base"), 194*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO3, ldo3, vout_type2_tables, "base"), 195*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO4, ldo4, vout_type2_tables, "base"), 196*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO5, ldo5, vout_type2_tables, "base"), 197*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO6, ldo6, vout_type2_tables, "base"), 198*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO7, ldo7, vout_type3_tables, "vin"), 199*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO8, ldo8, vout_type3_tables, "vin"), 200*714165e1SJeff Chang }; 201*714165e1SJeff Chang 202*714165e1SJeff Chang static const struct regulator_desc rt5133a_regulators[] = { 203*714165e1SJeff Chang /* For digital part, base current control */ 204*714165e1SJeff Chang { 205*714165e1SJeff Chang .name = "base", 206*714165e1SJeff Chang .id = RT5133_REGULATOR_BASE, 207*714165e1SJeff Chang .of_match = of_match_ptr("base"), 208*714165e1SJeff Chang .regulators_node = of_match_ptr("regulators"), 209*714165e1SJeff Chang .type = REGULATOR_VOLTAGE, 210*714165e1SJeff Chang .owner = THIS_MODULE, 211*714165e1SJeff Chang .ops = &rt5133_base_regulator_ops, 212*714165e1SJeff Chang .enable_reg = RT5133_REG_BASE_CTRL, 213*714165e1SJeff Chang .enable_mask = RT5133_FOFF_BASE_MASK, 214*714165e1SJeff Chang .enable_is_inverted = true, 215*714165e1SJeff Chang }, 216*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO1, ldo1, vout_type1_tables, "base"), 217*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO2, ldo2, vout_type1_tables, "base"), 218*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO3, ldo3, vout_type2_tables, "base"), 219*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO4, ldo4, vout_type2_tables, "base"), 220*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO5, ldo5, vout_type2_tables, "base"), 221*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO6, ldo6, vout_type2_tables, "base"), 222*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO7, ldo7, vout_type3_tables, "vin"), 223*714165e1SJeff Chang RT5133_REGULATOR_DESC(LDO8, ldo8, vout_type4_tables, "vin"), 224*714165e1SJeff Chang }; 225*714165e1SJeff Chang 226*714165e1SJeff Chang static const struct chip_data regulator_data[] = { 227*714165e1SJeff Chang { rt5133_regulators, 0x70}, 228*714165e1SJeff Chang { rt5133a_regulators, 0x80}, 229*714165e1SJeff Chang }; 230*714165e1SJeff Chang 231*714165e1SJeff Chang static int rt5133_gpio_direction_output(struct gpio_chip *gpio, 232*714165e1SJeff Chang unsigned int offset, int value) 233*714165e1SJeff Chang { 234*714165e1SJeff Chang struct rt5133_priv *priv = gpiochip_get_data(gpio); 235*714165e1SJeff Chang 236*714165e1SJeff Chang if (offset >= RT5133_GPIO_NR) 237*714165e1SJeff Chang return -EINVAL; 238*714165e1SJeff Chang 239*714165e1SJeff Chang return regmap_update_bits(priv->regmap, RT5133_REG_GPIO_CTRL, 240*714165e1SJeff Chang BIT(7 - offset) | BIT(3 - offset), 241*714165e1SJeff Chang value ? BIT(7 - offset) | BIT(3 - offset) : 0); 242*714165e1SJeff Chang } 243*714165e1SJeff Chang 244*714165e1SJeff Chang static int rt5133_gpio_get(struct gpio_chip *chip, unsigned int offset) 245*714165e1SJeff Chang { 246*714165e1SJeff Chang struct rt5133_priv *priv = gpiochip_get_data(chip); 247*714165e1SJeff Chang 248*714165e1SJeff Chang return !!(priv->gpio_output_flag & BIT(offset)); 249*714165e1SJeff Chang } 250*714165e1SJeff Chang 251*714165e1SJeff Chang static int rt5133_get_gpioen_mask(unsigned int offset, unsigned int *mask) 252*714165e1SJeff Chang { 253*714165e1SJeff Chang if (offset >= RT5133_GPIO_NR) 254*714165e1SJeff Chang return -EINVAL; 255*714165e1SJeff Chang 256*714165e1SJeff Chang *mask = (BIT(7 - offset) | BIT(3 - offset)); 257*714165e1SJeff Chang 258*714165e1SJeff Chang return 0; 259*714165e1SJeff Chang } 260*714165e1SJeff Chang 261*714165e1SJeff Chang static int rt5133_gpio_set(struct gpio_chip *chip, unsigned int offset, int set_val) 262*714165e1SJeff Chang { 263*714165e1SJeff Chang struct rt5133_priv *priv = gpiochip_get_data(chip); 264*714165e1SJeff Chang unsigned int mask = 0, val = 0, next_flag = priv->gpio_output_flag; 265*714165e1SJeff Chang int ret = 0; 266*714165e1SJeff Chang 267*714165e1SJeff Chang ret = rt5133_get_gpioen_mask(offset, &mask); 268*714165e1SJeff Chang if (ret) { 269*714165e1SJeff Chang dev_err(priv->dev, "%s get gpion en mask failed, offset(%d)\n", __func__, offset); 270*714165e1SJeff Chang return ret; 271*714165e1SJeff Chang } 272*714165e1SJeff Chang 273*714165e1SJeff Chang val = set_val ? mask : 0; 274*714165e1SJeff Chang 275*714165e1SJeff Chang if (set_val) 276*714165e1SJeff Chang next_flag |= BIT(offset); 277*714165e1SJeff Chang else 278*714165e1SJeff Chang next_flag &= ~BIT(offset); 279*714165e1SJeff Chang 280*714165e1SJeff Chang ret = regmap_update_bits(priv->regmap, RT5133_REG_GPIO_CTRL, mask, val); 281*714165e1SJeff Chang if (ret) { 282*714165e1SJeff Chang dev_err(priv->dev, "Failed to set gpio [%d] val %d\n", offset, 283*714165e1SJeff Chang set_val); 284*714165e1SJeff Chang return ret; 285*714165e1SJeff Chang } 286*714165e1SJeff Chang 287*714165e1SJeff Chang priv->gpio_output_flag = next_flag; 288*714165e1SJeff Chang return 0; 289*714165e1SJeff Chang } 290*714165e1SJeff Chang 291*714165e1SJeff Chang static irqreturn_t rt5133_intr_handler(int irq_number, void *data) 292*714165e1SJeff Chang { 293*714165e1SJeff Chang struct rt5133_priv *priv = data; 294*714165e1SJeff Chang u32 intr_evts = 0, handle_evts; 295*714165e1SJeff Chang int i, ret; 296*714165e1SJeff Chang 297*714165e1SJeff Chang ret = regmap_bulk_read(priv->regmap, RT5133_REG_BASE_EVT, &intr_evts, 298*714165e1SJeff Chang RT5133_INTR_BYTE_NR); 299*714165e1SJeff Chang if (ret) { 300*714165e1SJeff Chang dev_err(priv->dev, "%s, read event failed\n", __func__); 301*714165e1SJeff Chang return IRQ_NONE; 302*714165e1SJeff Chang } 303*714165e1SJeff Chang 304*714165e1SJeff Chang handle_evts = intr_evts & RT5133_BASE_EVT_MASK; 305*714165e1SJeff Chang /* 306*714165e1SJeff Chang * VREF_EVT is a special case, if base off 307*714165e1SJeff Chang * this event will also be trigger. Skip it 308*714165e1SJeff Chang */ 309*714165e1SJeff Chang if (handle_evts & ~RT5133_VREF_EVT_MASK) 310*714165e1SJeff Chang dev_dbg(priv->dev, "base event occurred [0x%02x]\n", 311*714165e1SJeff Chang handle_evts); 312*714165e1SJeff Chang 313*714165e1SJeff Chang handle_evts = (intr_evts & RT5133_LDO_OC_EVT_MASK) >> 314*714165e1SJeff Chang RT5133_LDO_OC_EVT_SHIFT; 315*714165e1SJeff Chang 316*714165e1SJeff Chang for (i = RT5133_REGULATOR_LDO1; i < RT5133_REGULATOR_MAX && handle_evts; i++) { 317*714165e1SJeff Chang if (!(handle_evts & BIT(i - 1))) 318*714165e1SJeff Chang continue; 319*714165e1SJeff Chang regulator_notifier_call_chain(priv->rdev[i], 320*714165e1SJeff Chang REGULATOR_EVENT_OVER_CURRENT, 321*714165e1SJeff Chang &i); 322*714165e1SJeff Chang } 323*714165e1SJeff Chang 324*714165e1SJeff Chang handle_evts = (intr_evts & RT5133_LDO_PGB_EVT_MASK) >> 325*714165e1SJeff Chang RT5133_LDO_PGB_EVT_SHIFT; 326*714165e1SJeff Chang for (i = RT5133_REGULATOR_LDO1; i < RT5133_REGULATOR_MAX && handle_evts; i++) { 327*714165e1SJeff Chang if (!(handle_evts & BIT(i - 1))) 328*714165e1SJeff Chang continue; 329*714165e1SJeff Chang regulator_notifier_call_chain(priv->rdev[i], 330*714165e1SJeff Chang REGULATOR_EVENT_FAIL, &i); 331*714165e1SJeff Chang } 332*714165e1SJeff Chang 333*714165e1SJeff Chang ret = regmap_bulk_write(priv->regmap, RT5133_REG_BASE_EVT, &intr_evts, 334*714165e1SJeff Chang RT5133_INTR_BYTE_NR); 335*714165e1SJeff Chang if (ret) 336*714165e1SJeff Chang dev_err(priv->dev, "%s, clear event failed\n", __func__); 337*714165e1SJeff Chang 338*714165e1SJeff Chang return IRQ_HANDLED; 339*714165e1SJeff Chang } 340*714165e1SJeff Chang 341*714165e1SJeff Chang static int rt5133_enable_interrupts(int irq_no, struct rt5133_priv *priv) 342*714165e1SJeff Chang { 343*714165e1SJeff Chang u32 mask = RT5133_INTR_CLR_MASK; 344*714165e1SJeff Chang int ret; 345*714165e1SJeff Chang 346*714165e1SJeff Chang /* Force to write clear all events */ 347*714165e1SJeff Chang ret = regmap_bulk_write(priv->regmap, RT5133_REG_BASE_EVT, &mask, 348*714165e1SJeff Chang RT5133_INTR_BYTE_NR); 349*714165e1SJeff Chang if (ret) { 350*714165e1SJeff Chang dev_err(priv->dev, "Failed to clear all interrupts\n"); 351*714165e1SJeff Chang return ret; 352*714165e1SJeff Chang } 353*714165e1SJeff Chang 354*714165e1SJeff Chang /* Unmask all interrupts */ 355*714165e1SJeff Chang mask = 0; 356*714165e1SJeff Chang ret = regmap_bulk_write(priv->regmap, RT5133_REG_BASE_MASK, &mask, 357*714165e1SJeff Chang RT5133_INTR_BYTE_NR); 358*714165e1SJeff Chang if (ret) { 359*714165e1SJeff Chang dev_err(priv->dev, "Failed to unmask all interrupts\n"); 360*714165e1SJeff Chang return ret; 361*714165e1SJeff Chang } 362*714165e1SJeff Chang 363*714165e1SJeff Chang return devm_request_threaded_irq(priv->dev, irq_no, NULL, 364*714165e1SJeff Chang rt5133_intr_handler, IRQF_ONESHOT, 365*714165e1SJeff Chang dev_name(priv->dev), priv); 366*714165e1SJeff Chang } 367*714165e1SJeff Chang 368*714165e1SJeff Chang static int rt5133_regmap_hw_read(void *context, const void *reg_buf, 369*714165e1SJeff Chang size_t reg_size, void *val_buf, 370*714165e1SJeff Chang size_t val_size) 371*714165e1SJeff Chang { 372*714165e1SJeff Chang struct rt5133_priv *priv = context; 373*714165e1SJeff Chang struct i2c_client *client = to_i2c_client(priv->dev); 374*714165e1SJeff Chang u8 reg = *(u8 *)reg_buf, crc; 375*714165e1SJeff Chang u8 *buf; 376*714165e1SJeff Chang int buf_len = RT5133_PREDATA_LEN + val_size + RT5133_I2C_CRC_LEN; 377*714165e1SJeff Chang int read_len, ret; 378*714165e1SJeff Chang 379*714165e1SJeff Chang buf = kzalloc(buf_len, GFP_KERNEL); 380*714165e1SJeff Chang if (!buf) 381*714165e1SJeff Chang return -ENOMEM; 382*714165e1SJeff Chang 383*714165e1SJeff Chang buf[0] = I2C_ADDR_XLATE_8BIT(client->addr, I2C_SMBUS_READ); 384*714165e1SJeff Chang buf[1] = reg; 385*714165e1SJeff Chang 386*714165e1SJeff Chang read_len = val_size + RT5133_I2C_CRC_LEN; 387*714165e1SJeff Chang ret = i2c_smbus_read_i2c_block_data(client, reg, read_len, 388*714165e1SJeff Chang buf + RT5133_PREDATA_LEN); 389*714165e1SJeff Chang 390*714165e1SJeff Chang if (ret < 0) 391*714165e1SJeff Chang goto out_read_err; 392*714165e1SJeff Chang 393*714165e1SJeff Chang if (ret != read_len) { 394*714165e1SJeff Chang ret = -EIO; 395*714165e1SJeff Chang goto out_read_err; 396*714165e1SJeff Chang } 397*714165e1SJeff Chang 398*714165e1SJeff Chang crc = crc8(priv->crc8_tbls, buf, RT5133_PREDATA_LEN + val_size, 0); 399*714165e1SJeff Chang if (crc != buf[RT5133_PREDATA_LEN + val_size]) { 400*714165e1SJeff Chang ret = -EIO; 401*714165e1SJeff Chang goto out_read_err; 402*714165e1SJeff Chang } 403*714165e1SJeff Chang 404*714165e1SJeff Chang memcpy(val_buf, buf + RT5133_PREDATA_LEN, val_size); 405*714165e1SJeff Chang dev_dbg(priv->dev, "%s, reg = 0x%02x, data = 0x%02x\n", __func__, reg, *(u8 *)val_buf); 406*714165e1SJeff Chang 407*714165e1SJeff Chang out_read_err: 408*714165e1SJeff Chang kfree(buf); 409*714165e1SJeff Chang return (ret < 0) ? ret : 0; 410*714165e1SJeff Chang } 411*714165e1SJeff Chang 412*714165e1SJeff Chang static int rt5133_regmap_hw_write(void *context, const void *data, size_t count) 413*714165e1SJeff Chang { 414*714165e1SJeff Chang struct rt5133_priv *priv = context; 415*714165e1SJeff Chang struct i2c_client *client = to_i2c_client(priv->dev); 416*714165e1SJeff Chang u8 reg = *(u8 *)data, crc; 417*714165e1SJeff Chang u8 *buf; 418*714165e1SJeff Chang int buf_len = RT5133_I2C_ADDR_LEN + count + RT5133_I2C_CRC_LEN + 419*714165e1SJeff Chang RT5133_I2C_DUMMY_LEN; 420*714165e1SJeff Chang int write_len, ret; 421*714165e1SJeff Chang 422*714165e1SJeff Chang buf = kzalloc(buf_len, GFP_KERNEL); 423*714165e1SJeff Chang if (!buf) 424*714165e1SJeff Chang return -ENOMEM; 425*714165e1SJeff Chang 426*714165e1SJeff Chang buf[0] = I2C_ADDR_XLATE_8BIT(client->addr, I2C_SMBUS_WRITE); 427*714165e1SJeff Chang buf[1] = reg; 428*714165e1SJeff Chang memcpy(buf + RT5133_PREDATA_LEN, data + RT5133_REG_ADDR_LEN, 429*714165e1SJeff Chang count - RT5133_REG_ADDR_LEN); 430*714165e1SJeff Chang 431*714165e1SJeff Chang crc = crc8(priv->crc8_tbls, buf, RT5133_I2C_ADDR_LEN + count, 0); 432*714165e1SJeff Chang buf[RT5133_I2C_ADDR_LEN + count] = crc; 433*714165e1SJeff Chang 434*714165e1SJeff Chang write_len = count - RT5133_REG_ADDR_LEN + RT5133_I2C_CRC_LEN + 435*714165e1SJeff Chang RT5133_I2C_DUMMY_LEN; 436*714165e1SJeff Chang ret = i2c_smbus_write_i2c_block_data(client, reg, write_len, 437*714165e1SJeff Chang buf + RT5133_PREDATA_LEN); 438*714165e1SJeff Chang 439*714165e1SJeff Chang dev_dbg(priv->dev, "%s, reg = 0x%02x, data = 0x%02x\n", __func__, reg, 440*714165e1SJeff Chang *(u8 *)(buf + RT5133_PREDATA_LEN)); 441*714165e1SJeff Chang kfree(buf); 442*714165e1SJeff Chang return ret; 443*714165e1SJeff Chang } 444*714165e1SJeff Chang 445*714165e1SJeff Chang static const struct regmap_bus rt5133_regmap_bus = { 446*714165e1SJeff Chang .read = rt5133_regmap_hw_read, 447*714165e1SJeff Chang .write = rt5133_regmap_hw_write, 448*714165e1SJeff Chang /* Due to crc, the block read/write length has the limit */ 449*714165e1SJeff Chang .max_raw_read = RT5133_MAX_I2C_BLOCK_SIZE, 450*714165e1SJeff Chang .max_raw_write = RT5133_MAX_I2C_BLOCK_SIZE, 451*714165e1SJeff Chang }; 452*714165e1SJeff Chang 453*714165e1SJeff Chang static bool rt5133_is_volatile_reg(struct device *dev, unsigned int reg) 454*714165e1SJeff Chang { 455*714165e1SJeff Chang switch (reg) { 456*714165e1SJeff Chang case RT5133_REG_CHIP_INFO: 457*714165e1SJeff Chang case RT5133_REG_BASE_EVT...RT5133_REG_LDO_PGB_STAT: 458*714165e1SJeff Chang case RT5133_REG_LDO_ON...RT5133_REG_LDO_OFF: 459*714165e1SJeff Chang case RT5133_REG_LDO1_CTRL1: 460*714165e1SJeff Chang case RT5133_REG_LDO2_CTRL1: 461*714165e1SJeff Chang case RT5133_REG_LDO3_CTRL1: 462*714165e1SJeff Chang case RT5133_REG_LDO4_CTRL1: 463*714165e1SJeff Chang case RT5133_REG_LDO5_CTRL1: 464*714165e1SJeff Chang case RT5133_REG_LDO6_CTRL1: 465*714165e1SJeff Chang case RT5133_REG_LDO7_CTRL1: 466*714165e1SJeff Chang case RT5133_REG_LDO8_CTRL1: 467*714165e1SJeff Chang return true; 468*714165e1SJeff Chang default: 469*714165e1SJeff Chang return false; 470*714165e1SJeff Chang }; 471*714165e1SJeff Chang } 472*714165e1SJeff Chang 473*714165e1SJeff Chang static const struct regmap_config rt5133_regmap_config = { 474*714165e1SJeff Chang .reg_bits = 8, 475*714165e1SJeff Chang .val_bits = 8, 476*714165e1SJeff Chang .max_register = RT5133_REG_LDO8_CTRL4, 477*714165e1SJeff Chang .cache_type = REGCACHE_FLAT, 478*714165e1SJeff Chang .num_reg_defaults_raw = RT5133_REG_LDO8_CTRL4 + 1, 479*714165e1SJeff Chang .volatile_reg = rt5133_is_volatile_reg, 480*714165e1SJeff Chang }; 481*714165e1SJeff Chang 482*714165e1SJeff Chang static int rt5133_chip_reset(struct rt5133_priv *priv) 483*714165e1SJeff Chang { 484*714165e1SJeff Chang int ret; 485*714165e1SJeff Chang 486*714165e1SJeff Chang ret = regmap_write(priv->regmap, RT5133_REG_RST_CTRL, 487*714165e1SJeff Chang RT5133_RESET_CODE); 488*714165e1SJeff Chang if (ret) 489*714165e1SJeff Chang return ret; 490*714165e1SJeff Chang 491*714165e1SJeff Chang /* Wait for register reset to take effect */ 492*714165e1SJeff Chang udelay(2); 493*714165e1SJeff Chang 494*714165e1SJeff Chang return 0; 495*714165e1SJeff Chang } 496*714165e1SJeff Chang 497*714165e1SJeff Chang static int rt5133_validate_vendor_info(struct rt5133_priv *priv) 498*714165e1SJeff Chang { 499*714165e1SJeff Chang unsigned int val = 0; 500*714165e1SJeff Chang int i, ret; 501*714165e1SJeff Chang 502*714165e1SJeff Chang ret = regmap_read(priv->regmap, RT5133_REG_CHIP_INFO, &val); 503*714165e1SJeff Chang if (ret) 504*714165e1SJeff Chang return ret; 505*714165e1SJeff Chang 506*714165e1SJeff Chang for (i = 0; i < ARRAY_SIZE(regulator_data); i++) { 507*714165e1SJeff Chang if ((val & RT5133_VENDOR_ID_MASK) == 508*714165e1SJeff Chang regulator_data[i].vendor_id){ 509*714165e1SJeff Chang priv->cdata = ®ulator_data[i]; 510*714165e1SJeff Chang break; 511*714165e1SJeff Chang } 512*714165e1SJeff Chang } 513*714165e1SJeff Chang if (IS_ERR(priv->cdata)) { 514*714165e1SJeff Chang dev_err(priv->dev, "Failed to find regualtor match version\n"); 515*714165e1SJeff Chang return -ENODEV; 516*714165e1SJeff Chang } 517*714165e1SJeff Chang 518*714165e1SJeff Chang return 0; 519*714165e1SJeff Chang } 520*714165e1SJeff Chang 521*714165e1SJeff Chang static int rt5133_parse_dt(struct rt5133_priv *priv) 522*714165e1SJeff Chang { 523*714165e1SJeff Chang unsigned int val = 0; 524*714165e1SJeff Chang int ret = 0; 525*714165e1SJeff Chang 526*714165e1SJeff Chang if (!device_property_read_bool(priv->dev, "richtek,oc-shutdown-all")) 527*714165e1SJeff Chang val = 0; 528*714165e1SJeff Chang else 529*714165e1SJeff Chang val = 1 << RT5133_OCSHDN_ALL_SHIFT; 530*714165e1SJeff Chang ret = regmap_update_bits(priv->regmap, RT5133_REG_LDO_SHDN, 531*714165e1SJeff Chang RT5133_OCSHDN_ALL_MASK, val); 532*714165e1SJeff Chang if (ret) 533*714165e1SJeff Chang return ret; 534*714165e1SJeff Chang 535*714165e1SJeff Chang if (!device_property_read_bool(priv->dev, "richtek,pgb-shutdown-all")) 536*714165e1SJeff Chang val = 0; 537*714165e1SJeff Chang else 538*714165e1SJeff Chang val = 1 << RT5133_PGBSHDN_ALL_SHIFT; 539*714165e1SJeff Chang return regmap_update_bits(priv->regmap, RT5133_REG_LDO_SHDN, 540*714165e1SJeff Chang RT5133_PGBSHDN_ALL_MASK, val); 541*714165e1SJeff Chang } 542*714165e1SJeff Chang 543*714165e1SJeff Chang static int rt5133_probe(struct i2c_client *i2c) 544*714165e1SJeff Chang { 545*714165e1SJeff Chang struct rt5133_priv *priv; 546*714165e1SJeff Chang struct regulator_config config = {0}; 547*714165e1SJeff Chang int i, ret; 548*714165e1SJeff Chang 549*714165e1SJeff Chang priv = devm_kzalloc(&i2c->dev, sizeof(*priv), GFP_KERNEL); 550*714165e1SJeff Chang if (!priv) 551*714165e1SJeff Chang return -ENOMEM; 552*714165e1SJeff Chang 553*714165e1SJeff Chang priv->dev = &i2c->dev; 554*714165e1SJeff Chang crc8_populate_msb(priv->crc8_tbls, RT5133_CRC8_POLYNOMIAL); 555*714165e1SJeff Chang 556*714165e1SJeff Chang priv->enable_gpio = devm_gpiod_get_optional(&i2c->dev, "enable", 557*714165e1SJeff Chang GPIOD_OUT_HIGH); 558*714165e1SJeff Chang if (IS_ERR(priv->enable_gpio)) 559*714165e1SJeff Chang dev_err(&i2c->dev, "Failed to request HWEN gpio, check if default en=high\n"); 560*714165e1SJeff Chang 561*714165e1SJeff Chang priv->regmap = devm_regmap_init(&i2c->dev, &rt5133_regmap_bus, priv, 562*714165e1SJeff Chang &rt5133_regmap_config); 563*714165e1SJeff Chang if (IS_ERR(priv->regmap)) { 564*714165e1SJeff Chang dev_err(&i2c->dev, "Failed to register regmap\n"); 565*714165e1SJeff Chang return PTR_ERR(priv->regmap); 566*714165e1SJeff Chang } 567*714165e1SJeff Chang 568*714165e1SJeff Chang ret = rt5133_validate_vendor_info(priv); 569*714165e1SJeff Chang if (ret) { 570*714165e1SJeff Chang dev_err(&i2c->dev, "Failed to check vendor info [%d]\n", ret); 571*714165e1SJeff Chang return ret; 572*714165e1SJeff Chang } 573*714165e1SJeff Chang 574*714165e1SJeff Chang ret = rt5133_chip_reset(priv); 575*714165e1SJeff Chang if (ret) { 576*714165e1SJeff Chang dev_err(&i2c->dev, "Failed to execute sw reset\n"); 577*714165e1SJeff Chang return ret; 578*714165e1SJeff Chang } 579*714165e1SJeff Chang 580*714165e1SJeff Chang config.dev = &i2c->dev; 581*714165e1SJeff Chang config.driver_data = priv; 582*714165e1SJeff Chang config.regmap = priv->regmap; 583*714165e1SJeff Chang 584*714165e1SJeff Chang for (i = 0; i < RT5133_REGULATOR_MAX; i++) { 585*714165e1SJeff Chang priv->rdev[i] = devm_regulator_register(&i2c->dev, 586*714165e1SJeff Chang priv->cdata->regulators + i, 587*714165e1SJeff Chang &config); 588*714165e1SJeff Chang if (IS_ERR(priv->rdev[i])) { 589*714165e1SJeff Chang dev_err(&i2c->dev, 590*714165e1SJeff Chang "Failed to register [%d] regulator\n", i); 591*714165e1SJeff Chang return PTR_ERR(priv->rdev[i]); 592*714165e1SJeff Chang } 593*714165e1SJeff Chang } 594*714165e1SJeff Chang 595*714165e1SJeff Chang ret = rt5133_parse_dt(priv); 596*714165e1SJeff Chang if (ret) { 597*714165e1SJeff Chang dev_err(&i2c->dev, "%s, Failed to parse dt\n", __func__); 598*714165e1SJeff Chang return ret; 599*714165e1SJeff Chang } 600*714165e1SJeff Chang 601*714165e1SJeff Chang priv->gc.label = dev_name(&i2c->dev); 602*714165e1SJeff Chang priv->gc.parent = &i2c->dev; 603*714165e1SJeff Chang priv->gc.base = -1; 604*714165e1SJeff Chang priv->gc.ngpio = RT5133_GPIO_NR; 605*714165e1SJeff Chang priv->gc.set = rt5133_gpio_set; 606*714165e1SJeff Chang priv->gc.get = rt5133_gpio_get; 607*714165e1SJeff Chang priv->gc.direction_output = rt5133_gpio_direction_output; 608*714165e1SJeff Chang priv->gc.can_sleep = true; 609*714165e1SJeff Chang 610*714165e1SJeff Chang ret = devm_gpiochip_add_data(&i2c->dev, &priv->gc, priv); 611*714165e1SJeff Chang if (ret) 612*714165e1SJeff Chang return ret; 613*714165e1SJeff Chang 614*714165e1SJeff Chang ret = rt5133_enable_interrupts(i2c->irq, priv); 615*714165e1SJeff Chang if (ret) { 616*714165e1SJeff Chang dev_err(&i2c->dev, "enable interrupt failed\n"); 617*714165e1SJeff Chang return ret; 618*714165e1SJeff Chang } 619*714165e1SJeff Chang 620*714165e1SJeff Chang i2c_set_clientdata(i2c, priv); 621*714165e1SJeff Chang 622*714165e1SJeff Chang return ret; 623*714165e1SJeff Chang } 624*714165e1SJeff Chang 625*714165e1SJeff Chang static const struct of_device_id __maybe_unused rt5133_of_match_table[] = { 626*714165e1SJeff Chang { .compatible = "richtek,rt5133", }, 627*714165e1SJeff Chang { } 628*714165e1SJeff Chang }; 629*714165e1SJeff Chang MODULE_DEVICE_TABLE(of, rt5133_of_match_table); 630*714165e1SJeff Chang 631*714165e1SJeff Chang static struct i2c_driver rt5133_driver = { 632*714165e1SJeff Chang .driver = { 633*714165e1SJeff Chang .name = "rt5133", 634*714165e1SJeff Chang .probe_type = PROBE_PREFER_ASYNCHRONOUS, 635*714165e1SJeff Chang .of_match_table = rt5133_of_match_table, 636*714165e1SJeff Chang }, 637*714165e1SJeff Chang .probe = rt5133_probe, 638*714165e1SJeff Chang }; 639*714165e1SJeff Chang module_i2c_driver(rt5133_driver); 640*714165e1SJeff Chang 641*714165e1SJeff Chang MODULE_DESCRIPTION("RT5133 Regulator Driver"); 642*714165e1SJeff Chang MODULE_LICENSE("GPL v2"); 643