Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

regulator: max8893: add regulator driver

MAX8893 is a simple regulator which can be found on some of Sasmsung
phones.

Signed-off-by: Sergey Larin <cerg2010cerg2010@mail.ru>
Link: https://lore.kernel.org/r/20210618141607.884-1-cerg2010cerg2010@mail.ru
Signed-off-by: Mark Brown <broonie@kernel.org>

authored by

Sergey Larin and committed by
Mark Brown
d83f778c ae60e6a9

+191
+7
drivers/regulator/Kconfig
··· 578 578 This driver controls a Maxim 8660/8661 voltage output 579 579 regulator via I2C bus. 580 580 581 + config REGULATOR_MAX8893 582 + tristate "Maxim 8893 voltage regulator" 583 + depends on I2C 584 + help 585 + This driver controls a Maxim 8893 voltage output 586 + regulator via I2C bus. 587 + 581 588 config REGULATOR_MAX8907 582 589 tristate "Maxim 8907 voltage regulator" 583 590 depends on MFD_MAX8907 || COMPILE_TEST
+1
drivers/regulator/Makefile
··· 71 71 obj-$(CONFIG_REGULATOR_MAX77650) += max77650-regulator.o 72 72 obj-$(CONFIG_REGULATOR_MAX8649) += max8649.o 73 73 obj-$(CONFIG_REGULATOR_MAX8660) += max8660.o 74 + obj-$(CONFIG_REGULATOR_MAX8893) += max8893.o 74 75 obj-$(CONFIG_REGULATOR_MAX8907) += max8907-regulator.o 75 76 obj-$(CONFIG_REGULATOR_MAX8925) += max8925-regulator.o 76 77 obj-$(CONFIG_REGULATOR_MAX8952) += max8952.o
+183
drivers/regulator/max8893.c
··· 1 + // SPDX-License-Identifier: GPL-2.0+ 2 + #include <linux/module.h> 3 + #include <linux/i2c.h> 4 + #include <linux/of.h> 5 + #include <linux/regmap.h> 6 + #include <linux/regulator/driver.h> 7 + 8 + static const struct regulator_ops max8893_ops = { 9 + .is_enabled = regulator_is_enabled_regmap, 10 + .enable = regulator_enable_regmap, 11 + .disable = regulator_disable_regmap, 12 + .get_voltage_sel = regulator_get_voltage_sel_regmap, 13 + .set_voltage_sel = regulator_set_voltage_sel_regmap, 14 + .list_voltage = regulator_list_voltage_linear, 15 + .map_voltage = regulator_map_voltage_linear, 16 + }; 17 + 18 + static const struct regulator_desc max8893_regulators[] = { 19 + { 20 + .name = "BUCK", 21 + .supply_name = "in-buck", 22 + .of_match = of_match_ptr("buck"), 23 + .regulators_node = of_match_ptr("regulators"), 24 + .n_voltages = 0x11, 25 + .id = 6, 26 + .ops = &max8893_ops, 27 + .type = REGULATOR_VOLTAGE, 28 + .owner = THIS_MODULE, 29 + .min_uV = 800000, 30 + .uV_step = 100000, 31 + .vsel_reg = 0x4, 32 + .vsel_mask = 0x1f, 33 + .enable_reg = 0x0, 34 + .enable_mask = BIT(7), 35 + }, 36 + { 37 + .name = "LDO1", 38 + .supply_name = "in-ldo1", 39 + .of_match = of_match_ptr("ldo1"), 40 + .regulators_node = of_match_ptr("regulators"), 41 + .n_voltages = 0x12, 42 + .id = 1, 43 + .ops = &max8893_ops, 44 + .type = REGULATOR_VOLTAGE, 45 + .owner = THIS_MODULE, 46 + .min_uV = 1600000, 47 + .uV_step = 100000, 48 + .vsel_reg = 0x5, 49 + .vsel_mask = 0x1f, 50 + .enable_reg = 0x0, 51 + .enable_mask = BIT(5), 52 + }, 53 + { 54 + .name = "LDO2", 55 + .supply_name = "in-ldo2", 56 + .of_match = of_match_ptr("ldo2"), 57 + .regulators_node = of_match_ptr("regulators"), 58 + .n_voltages = 0x16, 59 + .id = 2, 60 + .ops = &max8893_ops, 61 + .type = REGULATOR_VOLTAGE, 62 + .owner = THIS_MODULE, 63 + .min_uV = 1200000, 64 + .uV_step = 100000, 65 + .vsel_reg = 0x6, 66 + .vsel_mask = 0x1f, 67 + .enable_reg = 0x0, 68 + .enable_mask = BIT(4), 69 + }, 70 + { 71 + .name = "LDO3", 72 + .supply_name = "in-ldo3", 73 + .of_match = of_match_ptr("ldo3"), 74 + .regulators_node = of_match_ptr("regulators"), 75 + .n_voltages = 0x12, 76 + .id = 3, 77 + .ops = &max8893_ops, 78 + .type = REGULATOR_VOLTAGE, 79 + .owner = THIS_MODULE, 80 + .min_uV = 1600000, 81 + .uV_step = 100000, 82 + .vsel_reg = 0x7, 83 + .vsel_mask = 0x1f, 84 + .enable_reg = 0x0, 85 + .enable_mask = BIT(3), 86 + }, 87 + { 88 + .name = "LDO4", 89 + .supply_name = "in-ldo4", 90 + .of_match = of_match_ptr("ldo4"), 91 + .regulators_node = of_match_ptr("regulators"), 92 + .n_voltages = 0x1a, 93 + .id = 4, 94 + .ops = &max8893_ops, 95 + .type = REGULATOR_VOLTAGE, 96 + .owner = THIS_MODULE, 97 + .min_uV = 800000, 98 + .uV_step = 100000, 99 + .vsel_reg = 0x8, 100 + .vsel_mask = 0x1f, 101 + .enable_reg = 0x0, 102 + .enable_mask = BIT(2), 103 + }, 104 + { 105 + .name = "LDO5", 106 + .supply_name = "in-ldo5", 107 + .of_match = of_match_ptr("ldo5"), 108 + .regulators_node = of_match_ptr("regulators"), 109 + .n_voltages = 0x1a, 110 + .id = 5, 111 + .ops = &max8893_ops, 112 + .type = REGULATOR_VOLTAGE, 113 + .owner = THIS_MODULE, 114 + .min_uV = 800000, 115 + .uV_step = 100000, 116 + .vsel_reg = 0x9, 117 + .vsel_mask = 0x1f, 118 + .enable_reg = 0x0, 119 + .enable_mask = BIT(1), 120 + } 121 + }; 122 + 123 + static const struct regmap_config max8893_regmap = { 124 + .reg_bits = 8, 125 + .val_bits = 8, 126 + }; 127 + 128 + static int max8893_probe_new(struct i2c_client *i2c) 129 + { 130 + int id, ret; 131 + struct regulator_config config = {.dev = &i2c->dev}; 132 + struct regmap *regmap = devm_regmap_init_i2c(i2c, &max8893_regmap); 133 + 134 + if (IS_ERR(regmap)) { 135 + ret = PTR_ERR(regmap); 136 + dev_err(&i2c->dev, "regmap init failed: %d\n", ret); 137 + return ret; 138 + } 139 + 140 + for (id = 0; id < ARRAY_SIZE(max8893_regulators); id++) { 141 + struct regulator_dev *rdev; 142 + rdev = devm_regulator_register(&i2c->dev, 143 + &max8893_regulators[id], 144 + &config); 145 + if (IS_ERR(rdev)) { 146 + ret = PTR_ERR(rdev); 147 + dev_err(&i2c->dev, "failed to register %s: %d\n", 148 + max8893_regulators[id].name, ret); 149 + return ret; 150 + } 151 + } 152 + 153 + return 0; 154 + } 155 + 156 + #ifdef CONFIG_OF 157 + static const struct of_device_id max8893_dt_match[] = { 158 + { .compatible = "maxim,max8893" }, 159 + { /* sentinel */ }, 160 + }; 161 + MODULE_DEVICE_TABLE(of, max8893_dt_match); 162 + #endif 163 + 164 + static const struct i2c_device_id max8893_ids[] = { 165 + { "max8893", 0 }, 166 + { }, 167 + }; 168 + MODULE_DEVICE_TABLE(i2c, max8893_ids); 169 + 170 + static struct i2c_driver max8893_driver = { 171 + .probe_new = max8893_probe_new, 172 + .driver = { 173 + .name = "max8893", 174 + .of_match_table = of_match_ptr(max8893_dt_match), 175 + }, 176 + .id_table = max8893_ids, 177 + }; 178 + 179 + module_i2c_driver(max8893_driver); 180 + 181 + MODULE_DESCRIPTION("Maxim MAX8893 PMIC driver"); 182 + MODULE_AUTHOR("Sergey Larin <cerg2010cerg2010@mail.ru>"); 183 + MODULE_LICENSE("GPL");