Commit 7933147e authored by Mark Brown's avatar Mark Brown

Merge branch 'regulator-5.3' into regulator-5.4

parents 6cbe29c9 3829100a
...@@ -169,16 +169,16 @@ static int act8945a_set_mode(struct regulator_dev *rdev, unsigned int mode) ...@@ -169,16 +169,16 @@ static int act8945a_set_mode(struct regulator_dev *rdev, unsigned int mode)
reg = ACT8945A_DCDC3_CTRL; reg = ACT8945A_DCDC3_CTRL;
break; break;
case ACT8945A_ID_LDO1: case ACT8945A_ID_LDO1:
reg = ACT8945A_LDO1_SUS; reg = ACT8945A_LDO1_CTRL;
break; break;
case ACT8945A_ID_LDO2: case ACT8945A_ID_LDO2:
reg = ACT8945A_LDO2_SUS; reg = ACT8945A_LDO2_CTRL;
break; break;
case ACT8945A_ID_LDO3: case ACT8945A_ID_LDO3:
reg = ACT8945A_LDO3_SUS; reg = ACT8945A_LDO3_CTRL;
break; break;
case ACT8945A_ID_LDO4: case ACT8945A_ID_LDO4:
reg = ACT8945A_LDO4_SUS; reg = ACT8945A_LDO4_CTRL;
break; break;
default: default:
return -EINVAL; return -EINVAL;
......
...@@ -174,14 +174,14 @@ ...@@ -174,14 +174,14 @@
#define AXP803_DCDC5_1140mV_STEPS 35 #define AXP803_DCDC5_1140mV_STEPS 35
#define AXP803_DCDC5_1140mV_END \ #define AXP803_DCDC5_1140mV_END \
(AXP803_DCDC5_1140mV_START + AXP803_DCDC5_1140mV_STEPS) (AXP803_DCDC5_1140mV_START + AXP803_DCDC5_1140mV_STEPS)
#define AXP803_DCDC5_NUM_VOLTAGES 68 #define AXP803_DCDC5_NUM_VOLTAGES 69
#define AXP803_DCDC6_600mV_START 0x00 #define AXP803_DCDC6_600mV_START 0x00
#define AXP803_DCDC6_600mV_STEPS 50 #define AXP803_DCDC6_600mV_STEPS 50
#define AXP803_DCDC6_600mV_END \ #define AXP803_DCDC6_600mV_END \
(AXP803_DCDC6_600mV_START + AXP803_DCDC6_600mV_STEPS) (AXP803_DCDC6_600mV_START + AXP803_DCDC6_600mV_STEPS)
#define AXP803_DCDC6_1120mV_START 0x33 #define AXP803_DCDC6_1120mV_START 0x33
#define AXP803_DCDC6_1120mV_STEPS 14 #define AXP803_DCDC6_1120mV_STEPS 20
#define AXP803_DCDC6_1120mV_END \ #define AXP803_DCDC6_1120mV_END \
(AXP803_DCDC6_1120mV_START + AXP803_DCDC6_1120mV_STEPS) (AXP803_DCDC6_1120mV_START + AXP803_DCDC6_1120mV_STEPS)
#define AXP803_DCDC6_NUM_VOLTAGES 72 #define AXP803_DCDC6_NUM_VOLTAGES 72
...@@ -240,7 +240,7 @@ ...@@ -240,7 +240,7 @@
#define AXP806_DCDCA_600mV_END \ #define AXP806_DCDCA_600mV_END \
(AXP806_DCDCA_600mV_START + AXP806_DCDCA_600mV_STEPS) (AXP806_DCDCA_600mV_START + AXP806_DCDCA_600mV_STEPS)
#define AXP806_DCDCA_1120mV_START 0x33 #define AXP806_DCDCA_1120mV_START 0x33
#define AXP806_DCDCA_1120mV_STEPS 14 #define AXP806_DCDCA_1120mV_STEPS 20
#define AXP806_DCDCA_1120mV_END \ #define AXP806_DCDCA_1120mV_END \
(AXP806_DCDCA_1120mV_START + AXP806_DCDCA_1120mV_STEPS) (AXP806_DCDCA_1120mV_START + AXP806_DCDCA_1120mV_STEPS)
#define AXP806_DCDCA_NUM_VOLTAGES 72 #define AXP806_DCDCA_NUM_VOLTAGES 72
...@@ -774,8 +774,8 @@ static const struct regulator_linear_range axp806_dcdcd_ranges[] = { ...@@ -774,8 +774,8 @@ static const struct regulator_linear_range axp806_dcdcd_ranges[] = {
AXP806_DCDCD_600mV_END, AXP806_DCDCD_600mV_END,
20000), 20000),
REGULATOR_LINEAR_RANGE(1600000, REGULATOR_LINEAR_RANGE(1600000,
AXP806_DCDCD_600mV_START, AXP806_DCDCD_1600mV_START,
AXP806_DCDCD_600mV_END, AXP806_DCDCD_1600mV_END,
100000), 100000),
}; };
......
...@@ -163,7 +163,7 @@ static int lp87565_regulator_probe(struct platform_device *pdev) ...@@ -163,7 +163,7 @@ static int lp87565_regulator_probe(struct platform_device *pdev)
struct lp87565 *lp87565 = dev_get_drvdata(pdev->dev.parent); struct lp87565 *lp87565 = dev_get_drvdata(pdev->dev.parent);
struct regulator_config config = { }; struct regulator_config config = { };
struct regulator_dev *rdev; struct regulator_dev *rdev;
int i, min_idx = LP87565_BUCK_0, max_idx = LP87565_BUCK_3; int i, min_idx, max_idx;
platform_set_drvdata(pdev, lp87565); platform_set_drvdata(pdev, lp87565);
...@@ -182,9 +182,9 @@ static int lp87565_regulator_probe(struct platform_device *pdev) ...@@ -182,9 +182,9 @@ static int lp87565_regulator_probe(struct platform_device *pdev)
max_idx = LP87565_BUCK_3210; max_idx = LP87565_BUCK_3210;
break; break;
default: default:
dev_err(lp87565->dev, "Invalid lp config %d\n", min_idx = LP87565_BUCK_0;
lp87565->dev_type); max_idx = LP87565_BUCK_3;
return -EINVAL; break;
} }
for (i = min_idx; i <= max_idx; i++) { for (i = min_idx; i <= max_idx; i++) {
......
...@@ -416,8 +416,10 @@ device_node *regulator_of_get_init_node(struct device *dev, ...@@ -416,8 +416,10 @@ device_node *regulator_of_get_init_node(struct device *dev,
if (!name) if (!name)
name = child->name; name = child->name;
if (!strcmp(desc->of_match, name)) if (!strcmp(desc->of_match, name)) {
of_node_put(search);
return of_node_get(child); return of_node_get(child);
}
} }
of_node_put(search); of_node_put(search);
......
...@@ -205,7 +205,7 @@ static int slg51000_of_parse_cb(struct device_node *np, ...@@ -205,7 +205,7 @@ static int slg51000_of_parse_cb(struct device_node *np,
ena_gpiod = devm_gpiod_get_from_of_node(chip->dev, np, ena_gpiod = devm_gpiod_get_from_of_node(chip->dev, np,
"enable-gpios", 0, "enable-gpios", 0,
gflags, "gpio-en-ldo"); gflags, "gpio-en-ldo");
if (ena_gpiod) { if (!IS_ERR(ena_gpiod)) {
config->ena_gpiod = ena_gpiod; config->ena_gpiod = ena_gpiod;
devm_gpiod_unhinge(chip->dev, config->ena_gpiod); devm_gpiod_unhinge(chip->dev, config->ena_gpiod);
} }
...@@ -459,7 +459,7 @@ static int slg51000_i2c_probe(struct i2c_client *client, ...@@ -459,7 +459,7 @@ static int slg51000_i2c_probe(struct i2c_client *client,
GPIOD_OUT_HIGH GPIOD_OUT_HIGH
| GPIOD_FLAGS_BIT_NONEXCLUSIVE, | GPIOD_FLAGS_BIT_NONEXCLUSIVE,
"slg51000-cs"); "slg51000-cs");
if (cs_gpiod) { if (!IS_ERR(cs_gpiod)) {
dev_info(dev, "Found chip selector property\n"); dev_info(dev, "Found chip selector property\n");
chip->cs_gpiod = cs_gpiod; chip->cs_gpiod = cs_gpiod;
} }
......
...@@ -359,6 +359,17 @@ static const u16 VINTANA2_VSEL_table[] = { ...@@ -359,6 +359,17 @@ static const u16 VINTANA2_VSEL_table[] = {
2500, 2750, 2500, 2750,
}; };
/* 600mV to 1450mV in 12.5 mV steps */
static const struct regulator_linear_range VDD1_ranges[] = {
REGULATOR_LINEAR_RANGE(600000, 0, 68, 12500)
};
/* 600mV to 1450mV in 12.5 mV steps, everything above = 1500mV */
static const struct regulator_linear_range VDD2_ranges[] = {
REGULATOR_LINEAR_RANGE(600000, 0, 68, 12500),
REGULATOR_LINEAR_RANGE(1500000, 69, 69, 12500)
};
static int twl4030ldo_list_voltage(struct regulator_dev *rdev, unsigned index) static int twl4030ldo_list_voltage(struct regulator_dev *rdev, unsigned index)
{ {
struct twlreg_info *info = rdev_get_drvdata(rdev); struct twlreg_info *info = rdev_get_drvdata(rdev);
...@@ -427,6 +438,8 @@ static int twl4030smps_get_voltage(struct regulator_dev *rdev) ...@@ -427,6 +438,8 @@ static int twl4030smps_get_voltage(struct regulator_dev *rdev)
} }
static const struct regulator_ops twl4030smps_ops = { static const struct regulator_ops twl4030smps_ops = {
.list_voltage = regulator_list_voltage_linear_range,
.set_voltage = twl4030smps_set_voltage, .set_voltage = twl4030smps_set_voltage,
.get_voltage = twl4030smps_get_voltage, .get_voltage = twl4030smps_get_voltage,
}; };
...@@ -466,7 +479,8 @@ static const struct twlreg_info TWL4030_INFO_##label = { \ ...@@ -466,7 +479,8 @@ static const struct twlreg_info TWL4030_INFO_##label = { \
}, \ }, \
} }
#define TWL4030_ADJUSTABLE_SMPS(label, offset, num, turnon_delay, remap_conf) \ #define TWL4030_ADJUSTABLE_SMPS(label, offset, num, turnon_delay, remap_conf, \
n_volt) \
static const struct twlreg_info TWL4030_INFO_##label = { \ static const struct twlreg_info TWL4030_INFO_##label = { \
.base = offset, \ .base = offset, \
.id = num, \ .id = num, \
...@@ -479,6 +493,9 @@ static const struct twlreg_info TWL4030_INFO_##label = { \ ...@@ -479,6 +493,9 @@ static const struct twlreg_info TWL4030_INFO_##label = { \
.owner = THIS_MODULE, \ .owner = THIS_MODULE, \
.enable_time = turnon_delay, \ .enable_time = turnon_delay, \
.of_map_mode = twl4030reg_map_mode, \ .of_map_mode = twl4030reg_map_mode, \
.n_voltages = n_volt, \
.n_linear_ranges = ARRAY_SIZE(label ## _ranges), \
.linear_ranges = label ## _ranges, \
}, \ }, \
} }
...@@ -518,8 +535,8 @@ TWL4030_ADJUSTABLE_LDO(VSIM, 0x37, 9, 100, 0x00); ...@@ -518,8 +535,8 @@ TWL4030_ADJUSTABLE_LDO(VSIM, 0x37, 9, 100, 0x00);
TWL4030_ADJUSTABLE_LDO(VDAC, 0x3b, 10, 100, 0x08); TWL4030_ADJUSTABLE_LDO(VDAC, 0x3b, 10, 100, 0x08);
TWL4030_ADJUSTABLE_LDO(VINTANA2, 0x43, 12, 100, 0x08); TWL4030_ADJUSTABLE_LDO(VINTANA2, 0x43, 12, 100, 0x08);
TWL4030_ADJUSTABLE_LDO(VIO, 0x4b, 14, 1000, 0x08); TWL4030_ADJUSTABLE_LDO(VIO, 0x4b, 14, 1000, 0x08);
TWL4030_ADJUSTABLE_SMPS(VDD1, 0x55, 15, 1000, 0x08); TWL4030_ADJUSTABLE_SMPS(VDD1, 0x55, 15, 1000, 0x08, 68);
TWL4030_ADJUSTABLE_SMPS(VDD2, 0x63, 16, 1000, 0x08); TWL4030_ADJUSTABLE_SMPS(VDD2, 0x63, 16, 1000, 0x08, 69);
/* VUSBCP is managed *only* by the USB subchip */ /* VUSBCP is managed *only* by the USB subchip */
TWL4030_FIXED_LDO(VINTANA1, 0x3f, 1500, 11, 100, 0x08); TWL4030_FIXED_LDO(VINTANA1, 0x3f, 1500, 11, 100, 0x08);
TWL4030_FIXED_LDO(VINTDIG, 0x47, 1500, 13, 100, 0x08); TWL4030_FIXED_LDO(VINTDIG, 0x47, 1500, 13, 100, 0x08);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment