Lines Matching +full:nxp +full:- +full:i
1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright 2020 NXP.
4 * NXP PCA9450 pmic driver
56 .max_register = PCA9450_MAX_REGISTER - 1,
91 return regmap_update_bits(rdev->regmap, PCA9450_REG_BUCK1CTRL + id * 3, in pca9450_dvs_set_ramp_delay()
180 int ret, i; in buck_set_dvs() local
184 if (ret == -EINVAL) in buck_set_dvs()
189 for (i = 0; i < desc->n_voltages; i++) { in buck_set_dvs()
190 ret = regulator_desc_list_voltage_linear_range(desc, i); in buck_set_dvs()
194 i <<= ffs(desc->vsel_mask) - 1; in buck_set_dvs()
195 ret = regmap_update_bits(regmap, reg, mask, i); in buck_set_dvs()
209 const struct pc9450_dvs_config *dvs = &data->dvs; in pca9450_set_dvs_levels()
212 int i, ret = 0; in pca9450_set_dvs_levels() local
214 for (i = 0; i < PCA9450_DVS_LEVEL_MAX; i++) { in pca9450_set_dvs_levels()
215 switch (i) { in pca9450_set_dvs_levels()
217 prop = "nxp,dvs-run-voltage"; in pca9450_set_dvs_levels()
218 reg = dvs->run_reg; in pca9450_set_dvs_levels()
219 mask = dvs->run_mask; in pca9450_set_dvs_levels()
222 prop = "nxp,dvs-standby-voltage"; in pca9450_set_dvs_levels()
223 reg = dvs->standby_reg; in pca9450_set_dvs_levels()
224 mask = dvs->standby_mask; in pca9450_set_dvs_levels()
227 return -EINVAL; in pca9450_set_dvs_levels()
230 ret = buck_set_dvs(desc, np, cfg->regmap, prop, reg, mask); in pca9450_set_dvs_levels()
664 struct regmap *regmap = pca9450->regmap; in pca9450_irq_handler()
670 dev_err(pca9450->dev, in pca9450_irq_handler()
676 dev_warn(pca9450->dev, "PWRON interrupt.\n"); in pca9450_irq_handler()
679 dev_warn(pca9450->dev, "WDOGB interrupt.\n"); in pca9450_irq_handler()
682 dev_warn(pca9450->dev, "VRFLT1 interrupt.\n"); in pca9450_irq_handler()
685 dev_warn(pca9450->dev, "VRFLT2 interrupt.\n"); in pca9450_irq_handler()
688 dev_warn(pca9450->dev, "LOWVSYS interrupt.\n"); in pca9450_irq_handler()
691 dev_warn(pca9450->dev, "IRQ_THERM_105 interrupt.\n"); in pca9450_irq_handler()
694 dev_warn(pca9450->dev, "IRQ_THERM_125 interrupt.\n"); in pca9450_irq_handler()
703 of_device_get_match_data(&i2c->dev); in pca9450_i2c_probe()
707 unsigned int device_id, i; in pca9450_i2c_probe() local
710 if (!i2c->irq) { in pca9450_i2c_probe()
711 dev_err(&i2c->dev, "No IRQ configured?\n"); in pca9450_i2c_probe()
712 return -EINVAL; in pca9450_i2c_probe()
715 pca9450 = devm_kzalloc(&i2c->dev, sizeof(struct pca9450), GFP_KERNEL); in pca9450_i2c_probe()
717 return -ENOMEM; in pca9450_i2c_probe()
722 pca9450->rcnt = ARRAY_SIZE(pca9450a_regulators); in pca9450_i2c_probe()
726 pca9450->rcnt = ARRAY_SIZE(pca9450bc_regulators); in pca9450_i2c_probe()
729 dev_err(&i2c->dev, "Unknown device type"); in pca9450_i2c_probe()
730 return -EINVAL; in pca9450_i2c_probe()
733 pca9450->irq = i2c->irq; in pca9450_i2c_probe()
734 pca9450->type = type; in pca9450_i2c_probe()
735 pca9450->dev = &i2c->dev; in pca9450_i2c_probe()
737 dev_set_drvdata(&i2c->dev, pca9450); in pca9450_i2c_probe()
739 pca9450->regmap = devm_regmap_init_i2c(i2c, in pca9450_i2c_probe()
741 if (IS_ERR(pca9450->regmap)) { in pca9450_i2c_probe()
742 dev_err(&i2c->dev, "regmap initialization failed\n"); in pca9450_i2c_probe()
743 return PTR_ERR(pca9450->regmap); in pca9450_i2c_probe()
746 ret = regmap_read(pca9450->regmap, PCA9450_REG_DEV_ID, &device_id); in pca9450_i2c_probe()
748 dev_err(&i2c->dev, "Read device id error\n"); in pca9450_i2c_probe()
755 dev_err(&i2c->dev, "Device id(%x) mismatched\n", in pca9450_i2c_probe()
757 return -EINVAL; in pca9450_i2c_probe()
760 for (i = 0; i < pca9450->rcnt; i++) { in pca9450_i2c_probe()
765 r = ®ulator_desc[i]; in pca9450_i2c_probe()
766 desc = &r->desc; in pca9450_i2c_probe()
768 config.regmap = pca9450->regmap; in pca9450_i2c_probe()
769 config.dev = pca9450->dev; in pca9450_i2c_probe()
771 rdev = devm_regulator_register(pca9450->dev, desc, &config); in pca9450_i2c_probe()
774 dev_err(pca9450->dev, in pca9450_i2c_probe()
776 desc->name, ret); in pca9450_i2c_probe()
781 ret = devm_request_threaded_irq(pca9450->dev, pca9450->irq, NULL, in pca9450_i2c_probe()
784 "pca9450-irq", pca9450); in pca9450_i2c_probe()
786 dev_err(pca9450->dev, "Failed to request IRQ: %d\n", in pca9450_i2c_probe()
787 pca9450->irq); in pca9450_i2c_probe()
791 ret = regmap_update_bits(pca9450->regmap, PCA9450_REG_INT1_MSK, in pca9450_i2c_probe()
796 dev_err(&i2c->dev, "Unmask irq error\n"); in pca9450_i2c_probe()
801 ret = regmap_clear_bits(pca9450->regmap, PCA9450_REG_BUCK123_DVS, in pca9450_i2c_probe()
804 dev_err(&i2c->dev, "Failed to clear PRESET_EN bit: %d\n", ret); in pca9450_i2c_probe()
809 ret = regmap_update_bits(pca9450->regmap, PCA9450_REG_RESET_CTRL, in pca9450_i2c_probe()
812 dev_err(&i2c->dev, "Failed to set WDOG_B reset behavior\n"); in pca9450_i2c_probe()
821 pca9450->sd_vsel_gpio = gpiod_get_optional(pca9450->dev, "sd-vsel", GPIOD_OUT_HIGH); in pca9450_i2c_probe()
823 if (IS_ERR(pca9450->sd_vsel_gpio)) { in pca9450_i2c_probe()
824 dev_err(&i2c->dev, "Failed to get SD_VSEL GPIO\n"); in pca9450_i2c_probe()
828 dev_info(&i2c->dev, "%s probed.\n", in pca9450_i2c_probe()
836 .compatible = "nxp,pca9450a",
840 .compatible = "nxp,pca9450b",
844 .compatible = "nxp,pca9450c",
853 .name = "nxp-pca9450",
861 MODULE_AUTHOR("Robin Gong <yibin.gong@nxp.com>");
862 MODULE_DESCRIPTION("NXP PCA9450 Power Management IC driver");