Lines Matching +full:ltc4162 +full:- +full:s

1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Driver for Analog Devices (Linear Technology) LTC4162-L charger IC.
93 if (info->cell_count) in ltc4162l_get_cell_count()
94 return info->cell_count; in ltc4162l_get_cell_count()
96 ret = regmap_read(info->regmap, LTC4162L_CHEM_CELLS_REG, &val); in ltc4162l_get_cell_count()
106 info->cell_count = val; in ltc4162l_get_cell_count()
134 ret = regmap_read(info->regmap, LTC4162L_CHARGER_STATE, &regval); in ltc4162l_get_status()
136 dev_err(&info->client->dev, "Failed to read CHARGER_STATE\n"); in ltc4162l_get_status()
140 val->intval = ltc4162l_state_decode(regval); in ltc4162l_get_status()
154 /* Anything that's not fast we'll return as trickle */ in ltc4162l_charge_status_decode()
164 ret = regmap_read(info->regmap, LTC4162L_CHARGE_STATUS, &regval); in ltc4162l_get_charge_type()
168 val->intval = ltc4162l_charge_status_decode(regval); in ltc4162l_get_charge_type()
197 ret = regmap_read(info->regmap, LTC4162L_CHARGER_STATE, &regval); in ltc4162l_get_health()
201 val->intval = ltc4162l_state_to_health(regval); in ltc4162l_get_health()
212 ret = regmap_read(info->regmap, LTC4162L_SYSTEM_STATUS_REG, &regval); in ltc4162l_get_online()
217 val->intval = !!(regval & BIT(2)); in ltc4162l_get_online()
229 ret = regmap_read(info->regmap, reg, &regval); in ltc4162l_get_vbat()
237 val->intval = regval; in ltc4162l_get_vbat()
248 ret = regmap_read(info->regmap, LTC4162L_IBAT, &regval); in ltc4162l_get_ibat()
252 /* Signed 16-bit number, 1.466μV / RSNSB amperes/LSB. */ in ltc4162l_get_ibat()
254 val->intval = 100 * mult_frac(ret, 14660, (int)info->rsnsb); in ltc4162l_get_ibat()
266 ret = regmap_read(info->regmap, LTC4162L_VIN, &regval); in ltc4162l_get_input_voltage()
271 val->intval = regval * 1694; in ltc4162l_get_input_voltage()
282 ret = regmap_read(info->regmap, LTC4162L_IIN, &regval); in ltc4162l_get_input_current()
286 /* Signed 16-bit number, 1.466μV / RSNSI amperes/LSB. */ in ltc4162l_get_input_current()
289 ret /= info->rsnsi; in ltc4162l_get_input_current()
292 val->intval = ret; in ltc4162l_get_input_current()
304 ret = regmap_read(info->regmap, reg, &regval); in ltc4162l_get_icharge()
308 regval &= BIT(6) - 1; /* Only the lower 5 bits */ in ltc4162l_get_icharge()
312 val->intval = 10000u * mult_frac(regval, 100000u, info->rsnsb); in ltc4162l_get_icharge()
321 value = mult_frac(value, info->rsnsb, 100000u); in ltc4162l_set_icharge()
326 --value; in ltc4162l_set_icharge()
329 return -EINVAL; in ltc4162l_set_icharge()
331 return regmap_write(info->regmap, reg, value); in ltc4162l_set_icharge()
343 ret = regmap_read(info->regmap, reg, &regval); in ltc4162l_get_vcharge()
347 regval &= BIT(6) - 1; /* Only the lower 5 bits */ in ltc4162l_get_vcharge()
356 val->intval = voltage; in ltc4162l_get_vcharge()
368 return -EBUSY; /* Not available yet, try again later */ in ltc4162l_set_vcharge()
373 return -EINVAL; in ltc4162l_set_vcharge()
375 value -= 3812500; in ltc4162l_set_vcharge()
379 return -EINVAL; in ltc4162l_set_vcharge()
381 return regmap_write(info->regmap, reg, value); in ltc4162l_set_vcharge()
390 ret = regmap_read(info->regmap, LTC4162L_IIN_LIMIT_DAC, &regval); in ltc4162l_get_iin_limit_dac()
394 regval &= BIT(6) - 1; /* Only 6 bits */ in ltc4162l_get_iin_limit_dac()
399 regval /= info->rsnsi; in ltc4162l_get_iin_limit_dac()
400 val->intval = 100u * regval; in ltc4162l_get_iin_limit_dac()
410 regval = mult_frac(value, info->rsnsi, 50000u); in ltc4162l_set_iin_limit()
413 --regval; in ltc4162l_set_iin_limit()
417 return regmap_write(info->regmap, LTC4162L_IIN_LIMIT_TARGET, regval); in ltc4162l_set_iin_limit()
426 ret = regmap_read(info->regmap, LTC4162L_DIE_TEMPERATURE, &regval); in ltc4162l_get_die_temp()
430 /* die_temp × 0.0215°C/LSB - 264.4°C */ in ltc4162l_get_die_temp()
434 ret -= 26440; in ltc4162l_get_die_temp()
435 val->intval = ret; in ltc4162l_get_die_temp()
446 ret = regmap_read(info->regmap, LTC4162L_CHARGER_CONFIG_BITS, &regval); in ltc4162l_get_term_current()
452 val->intval = 0; in ltc4162l_get_term_current()
456 ret = regmap_read(info->regmap, LTC4162L_C_OVER_X_THRESHOLD, &regval); in ltc4162l_get_term_current()
462 regval /= info->rsnsb; in ltc4162l_get_term_current()
463 val->intval = 100 * regval; in ltc4162l_get_term_current()
476 return regmap_update_bits(info->regmap, in ltc4162l_set_term_current()
481 regval = mult_frac(value, info->rsnsb, 14660u); in ltc4162l_set_term_current()
484 ret = regmap_write(info->regmap, LTC4162L_C_OVER_X_THRESHOLD, regval); in ltc4162l_set_term_current()
489 return regmap_update_bits(info->regmap, LTC4162L_CHARGER_CONFIG_BITS, in ltc4162l_set_term_current()
510 ARRAY_SIZE(ltc4162l_charge_status_name) - 1]; in charge_status_show()
516 ret = regmap_read(info->regmap, LTC4162L_CHARGE_STATUS, &regval); in charge_status_show()
520 /* Only one bit is set according to datasheet, let's be safe here */ in charge_status_show()
528 return sprintf(buf, "%s\n", result); in charge_status_show()
588 ret = regmap_read(info->regmap, LTC4162L_CONFIG_BITS_REG, &regval); in force_telemetry_show()
609 ret = regmap_update_bits(info->regmap, LTC4162L_CONFIG_BITS_REG, in force_telemetry_store()
627 ret = regmap_read(info->regmap, LTC4162L_ARM_SHIP_MODE, &regval); in arm_ship_mode_show()
649 ret = regmap_write(info->regmap, LTC4162L_ARM_SHIP_MODE, in arm_ship_mode_store()
717 return -EINVAL; in ltc4162l_get_property()
730 LTC4162L_CHARGE_CURRENT_SETTING, val->intval); in ltc4162l_set_property()
733 LTC4162L_VCHARGE_SETTING, val->intval); in ltc4162l_set_property()
735 return ltc4162l_set_iin_limit(info, val->intval); in ltc4162l_set_property()
737 return ltc4162l_set_term_current(info, val->intval); in ltc4162l_set_property()
739 return -EINVAL; in ltc4162l_set_property()
775 .name = "ltc4162-l",
800 /* all registers after this one are read-only status registers */ in ltc4162l_is_volatile_reg()
817 regmap_write(info->regmap, LTC4162L_LIMIT_ALERTS_REG, 0); in ltc4162l_clear_interrupts()
818 regmap_write(info->regmap, LTC4162L_CHARGER_STATE_ALERTS_REG, 0); in ltc4162l_clear_interrupts()
819 regmap_write(info->regmap, LTC4162L_CHARGE_STATUS_ALERTS_REG, 0); in ltc4162l_clear_interrupts()
825 struct i2c_adapter *adapter = client->adapter; in ltc4162l_probe()
826 struct device *dev = &client->dev; in ltc4162l_probe()
834 return -ENODEV; in ltc4162l_probe()
838 return -ENOMEM; in ltc4162l_probe()
840 info->client = client; in ltc4162l_probe()
843 info->regmap = devm_regmap_init_i2c(client, &ltc4162l_regmap_config); in ltc4162l_probe()
844 if (IS_ERR(info->regmap)) { in ltc4162l_probe()
846 return PTR_ERR(info->regmap); in ltc4162l_probe()
849 ret = device_property_read_u32(dev, "lltc,rsnsb-micro-ohms", in ltc4162l_probe()
850 &info->rsnsb); in ltc4162l_probe()
852 dev_err(dev, "Missing lltc,rsnsb-micro-ohms property\n"); in ltc4162l_probe()
855 if (!info->rsnsb) in ltc4162l_probe()
856 return -EINVAL; in ltc4162l_probe()
858 ret = device_property_read_u32(dev, "lltc,rsnsi-micro-ohms", in ltc4162l_probe()
859 &info->rsnsi); in ltc4162l_probe()
861 dev_err(dev, "Missing lltc,rsnsi-micro-ohms property\n"); in ltc4162l_probe()
864 if (!info->rsnsi) in ltc4162l_probe()
865 return -EINVAL; in ltc4162l_probe()
867 if (!device_property_read_u32(dev, "lltc,cell-count", &value)) in ltc4162l_probe()
868 info->cell_count = value; in ltc4162l_probe()
870 ltc4162l_config.of_node = dev->of_node; in ltc4162l_probe()
874 info->charger = devm_power_supply_register(dev, &ltc4162l_desc, in ltc4162l_probe()
876 if (IS_ERR(info->charger)) { in ltc4162l_probe()
878 return PTR_ERR(info->charger); in ltc4162l_probe()
882 regmap_write(info->regmap, LTC4162L_EN_LIMIT_ALERTS_REG, 0); in ltc4162l_probe()
885 regmap_write(info->regmap, LTC4162L_EN_CHARGER_STATE_ALERTS_REG, in ltc4162l_probe()
887 regmap_write(info->regmap, LTC4162L_EN_CHARGE_STATUS_ALERTS_REG, 0x1f); in ltc4162l_probe()
903 power_supply_changed(info->charger); in ltc4162l_alert()
907 { "ltc4162-l", 0 },
913 { .compatible = "lltc,ltc4162-l", },
923 .name = "ltc4162-l-charger",
931 MODULE_DESCRIPTION("LTC4162-L charger driver");