Merge remote-tracking branches 'regulator/topic/88pm800', 'regulator/topic/88pm8607', 'regulator/topic/aat2870', 'regulator/topic/act8865', 'regulator/topic/anatop', 'regulator/topic/arizona', 'regulator/topic/as3711' and 'regulator/topic/as3722' into regulator-next
This commit is contained in:
parent
29dbdcf316
001f004ba7
e54f19bff4
08d6da2914
fb8eb45400
114c5748d5
a35ff28616
31833581de
ba40e5571b
commit
e4e16c2b67
@ -310,10 +310,8 @@ static int pm800_regulator_probe(struct platform_device *pdev)
|
|||||||
|
|
||||||
pm800_data = devm_kzalloc(&pdev->dev, sizeof(*pm800_data),
|
pm800_data = devm_kzalloc(&pdev->dev, sizeof(*pm800_data),
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
if (!pm800_data) {
|
if (!pm800_data)
|
||||||
dev_err(&pdev->dev, "Failed to allocate pm800_regualtors");
|
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
|
||||||
|
|
||||||
pm800_data->map = chip->subchip->regmap_power;
|
pm800_data->map = chip->subchip->regmap_power;
|
||||||
pm800_data->chip = chip;
|
pm800_data->chip = chip;
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* Regulators driver for Marvell 88PM8607
|
* Regulators driver for Marvell 88PM8607
|
||||||
*
|
*
|
||||||
* Copyright (C) 2009 Marvell International Ltd.
|
* Copyright (C) 2009 Marvell International Ltd.
|
||||||
* Haojian Zhuang <haojian.zhuang@marvell.com>
|
* Haojian Zhuang <haojian.zhuang@marvell.com>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* This program is free software; you can redistribute it and/or modify
|
||||||
* it under the terms of the GNU General Public License version 2 as
|
* it under the terms of the GNU General Public License version 2 as
|
||||||
@ -78,7 +78,7 @@ static const unsigned int BUCK2_suspend_table[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const unsigned int BUCK3_table[] = {
|
static const unsigned int BUCK3_table[] = {
|
||||||
0, 25000, 50000, 75000, 100000, 125000, 150000, 175000,
|
0, 25000, 50000, 75000, 100000, 125000, 150000, 175000,
|
||||||
200000, 225000, 250000, 275000, 300000, 325000, 350000, 375000,
|
200000, 225000, 250000, 275000, 300000, 325000, 350000, 375000,
|
||||||
400000, 425000, 450000, 475000, 500000, 525000, 550000, 575000,
|
400000, 425000, 450000, 475000, 500000, 525000, 550000, 575000,
|
||||||
600000, 625000, 650000, 675000, 700000, 725000, 750000, 775000,
|
600000, 625000, 650000, 675000, 700000, 725000, 750000, 775000,
|
||||||
@ -89,7 +89,7 @@ static const unsigned int BUCK3_table[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static const unsigned int BUCK3_suspend_table[] = {
|
static const unsigned int BUCK3_suspend_table[] = {
|
||||||
0, 25000, 50000, 75000, 100000, 125000, 150000, 175000,
|
0, 25000, 50000, 75000, 100000, 125000, 150000, 175000,
|
||||||
200000, 225000, 250000, 275000, 300000, 325000, 350000, 375000,
|
200000, 225000, 250000, 275000, 300000, 325000, 350000, 375000,
|
||||||
400000, 425000, 450000, 475000, 500000, 525000, 550000, 575000,
|
400000, 425000, 450000, 475000, 500000, 525000, 550000, 575000,
|
||||||
600000, 625000, 650000, 675000, 700000, 725000, 750000, 775000,
|
600000, 625000, 650000, 675000, 700000, 725000, 750000, 775000,
|
||||||
@ -322,7 +322,7 @@ static int pm8607_regulator_dt_init(struct platform_device *pdev,
|
|||||||
nproot = of_node_get(pdev->dev.parent->of_node);
|
nproot = of_node_get(pdev->dev.parent->of_node);
|
||||||
if (!nproot)
|
if (!nproot)
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
nproot = of_find_node_by_name(nproot, "regulators");
|
nproot = of_get_child_by_name(nproot, "regulators");
|
||||||
if (!nproot) {
|
if (!nproot) {
|
||||||
dev_err(&pdev->dev, "failed to find regulators node\n");
|
dev_err(&pdev->dev, "failed to find regulators node\n");
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
|
@ -99,6 +99,7 @@ static int aat2870_ldo_is_enabled(struct regulator_dev *rdev)
|
|||||||
|
|
||||||
static struct regulator_ops aat2870_ldo_ops = {
|
static struct regulator_ops aat2870_ldo_ops = {
|
||||||
.list_voltage = regulator_list_voltage_table,
|
.list_voltage = regulator_list_voltage_table,
|
||||||
|
.map_voltage = regulator_map_voltage_ascend,
|
||||||
.set_voltage_sel = aat2870_ldo_set_voltage_sel,
|
.set_voltage_sel = aat2870_ldo_set_voltage_sel,
|
||||||
.get_voltage_sel = aat2870_ldo_get_voltage_sel,
|
.get_voltage_sel = aat2870_ldo_get_voltage_sel,
|
||||||
.enable = aat2870_ldo_enable,
|
.enable = aat2870_ldo_enable,
|
||||||
|
@ -62,7 +62,6 @@
|
|||||||
#define ACT8865_VOLTAGE_NUM 64
|
#define ACT8865_VOLTAGE_NUM 64
|
||||||
|
|
||||||
struct act8865 {
|
struct act8865 {
|
||||||
struct regulator_dev *rdev[ACT8865_REG_NUM];
|
|
||||||
struct regmap *regmap;
|
struct regmap *regmap;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -213,7 +212,7 @@ static int act8865_pdata_from_dt(struct device *dev,
|
|||||||
struct device_node *np;
|
struct device_node *np;
|
||||||
struct act8865_regulator_data *regulator;
|
struct act8865_regulator_data *regulator;
|
||||||
|
|
||||||
np = of_find_node_by_name(dev->of_node, "regulators");
|
np = of_get_child_by_name(dev->of_node, "regulators");
|
||||||
if (!np) {
|
if (!np) {
|
||||||
dev_err(dev, "missing 'regulators' subnode in DT\n");
|
dev_err(dev, "missing 'regulators' subnode in DT\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -221,17 +220,15 @@ static int act8865_pdata_from_dt(struct device *dev,
|
|||||||
|
|
||||||
matched = of_regulator_match(dev, np,
|
matched = of_regulator_match(dev, np,
|
||||||
act8865_matches, ARRAY_SIZE(act8865_matches));
|
act8865_matches, ARRAY_SIZE(act8865_matches));
|
||||||
|
of_node_put(np);
|
||||||
if (matched <= 0)
|
if (matched <= 0)
|
||||||
return matched;
|
return matched;
|
||||||
|
|
||||||
pdata->regulators = devm_kzalloc(dev,
|
pdata->regulators = devm_kzalloc(dev,
|
||||||
sizeof(struct act8865_regulator_data) *
|
sizeof(struct act8865_regulator_data) *
|
||||||
ARRAY_SIZE(act8865_matches), GFP_KERNEL);
|
ARRAY_SIZE(act8865_matches), GFP_KERNEL);
|
||||||
if (!pdata->regulators) {
|
if (!pdata->regulators)
|
||||||
dev_err(dev, "%s: failed to allocate act8865 registor\n",
|
|
||||||
__func__);
|
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
|
||||||
|
|
||||||
pdata->num_regulators = matched;
|
pdata->num_regulators = matched;
|
||||||
regulator = pdata->regulators;
|
regulator = pdata->regulators;
|
||||||
@ -258,7 +255,7 @@ static inline int act8865_pdata_from_dt(struct device *dev,
|
|||||||
static int act8865_pmic_probe(struct i2c_client *client,
|
static int act8865_pmic_probe(struct i2c_client *client,
|
||||||
const struct i2c_device_id *i2c_id)
|
const struct i2c_device_id *i2c_id)
|
||||||
{
|
{
|
||||||
struct regulator_dev **rdev;
|
struct regulator_dev *rdev;
|
||||||
struct device *dev = &client->dev;
|
struct device *dev = &client->dev;
|
||||||
struct act8865_platform_data *pdata = dev_get_platdata(dev);
|
struct act8865_platform_data *pdata = dev_get_platdata(dev);
|
||||||
struct regulator_config config = { };
|
struct regulator_config config = { };
|
||||||
@ -292,8 +289,6 @@ static int act8865_pmic_probe(struct i2c_client *client,
|
|||||||
if (!act8865)
|
if (!act8865)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
rdev = act8865->rdev;
|
|
||||||
|
|
||||||
act8865->regmap = devm_regmap_init_i2c(client, &act8865_regmap_config);
|
act8865->regmap = devm_regmap_init_i2c(client, &act8865_regmap_config);
|
||||||
if (IS_ERR(act8865->regmap)) {
|
if (IS_ERR(act8865->regmap)) {
|
||||||
error = PTR_ERR(act8865->regmap);
|
error = PTR_ERR(act8865->regmap);
|
||||||
@ -313,12 +308,12 @@ static int act8865_pmic_probe(struct i2c_client *client,
|
|||||||
config.driver_data = act8865;
|
config.driver_data = act8865;
|
||||||
config.regmap = act8865->regmap;
|
config.regmap = act8865->regmap;
|
||||||
|
|
||||||
rdev[i] = devm_regulator_register(&client->dev,
|
rdev = devm_regulator_register(&client->dev, &act8865_reg[i],
|
||||||
&act8865_reg[i], &config);
|
&config);
|
||||||
if (IS_ERR(rdev[i])) {
|
if (IS_ERR(rdev)) {
|
||||||
dev_err(dev, "failed to register %s\n",
|
dev_err(dev, "failed to register %s\n",
|
||||||
act8865_reg[id].name);
|
act8865_reg[id].name);
|
||||||
return PTR_ERR(rdev[i]);
|
return PTR_ERR(rdev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -34,6 +34,9 @@
|
|||||||
#define LDO_RAMP_UP_UNIT_IN_CYCLES 64 /* 64 cycles per step */
|
#define LDO_RAMP_UP_UNIT_IN_CYCLES 64 /* 64 cycles per step */
|
||||||
#define LDO_RAMP_UP_FREQ_IN_MHZ 24 /* cycle based on 24M OSC */
|
#define LDO_RAMP_UP_FREQ_IN_MHZ 24 /* cycle based on 24M OSC */
|
||||||
|
|
||||||
|
#define LDO_POWER_GATE 0x00
|
||||||
|
#define LDO_FET_FULL_ON 0x1f
|
||||||
|
|
||||||
struct anatop_regulator {
|
struct anatop_regulator {
|
||||||
const char *name;
|
const char *name;
|
||||||
u32 control_reg;
|
u32 control_reg;
|
||||||
@ -48,19 +51,10 @@ struct anatop_regulator {
|
|||||||
int max_voltage;
|
int max_voltage;
|
||||||
struct regulator_desc rdesc;
|
struct regulator_desc rdesc;
|
||||||
struct regulator_init_data *initdata;
|
struct regulator_init_data *initdata;
|
||||||
|
bool bypass;
|
||||||
|
int sel;
|
||||||
};
|
};
|
||||||
|
|
||||||
static int anatop_regmap_set_voltage_sel(struct regulator_dev *reg,
|
|
||||||
unsigned selector)
|
|
||||||
{
|
|
||||||
struct anatop_regulator *anatop_reg = rdev_get_drvdata(reg);
|
|
||||||
|
|
||||||
if (!anatop_reg->control_reg)
|
|
||||||
return -ENOTSUPP;
|
|
||||||
|
|
||||||
return regulator_set_voltage_sel_regmap(reg, selector);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int anatop_regmap_set_voltage_time_sel(struct regulator_dev *reg,
|
static int anatop_regmap_set_voltage_time_sel(struct regulator_dev *reg,
|
||||||
unsigned int old_sel,
|
unsigned int old_sel,
|
||||||
unsigned int new_sel)
|
unsigned int new_sel)
|
||||||
@ -87,24 +81,101 @@ static int anatop_regmap_set_voltage_time_sel(struct regulator_dev *reg,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int anatop_regmap_get_voltage_sel(struct regulator_dev *reg)
|
static int anatop_regmap_enable(struct regulator_dev *reg)
|
||||||
|
{
|
||||||
|
struct anatop_regulator *anatop_reg = rdev_get_drvdata(reg);
|
||||||
|
int sel;
|
||||||
|
|
||||||
|
sel = anatop_reg->bypass ? LDO_FET_FULL_ON : anatop_reg->sel;
|
||||||
|
return regulator_set_voltage_sel_regmap(reg, sel);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int anatop_regmap_disable(struct regulator_dev *reg)
|
||||||
|
{
|
||||||
|
return regulator_set_voltage_sel_regmap(reg, LDO_POWER_GATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int anatop_regmap_is_enabled(struct regulator_dev *reg)
|
||||||
|
{
|
||||||
|
return regulator_get_voltage_sel_regmap(reg) != LDO_POWER_GATE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int anatop_regmap_core_set_voltage_sel(struct regulator_dev *reg,
|
||||||
|
unsigned selector)
|
||||||
|
{
|
||||||
|
struct anatop_regulator *anatop_reg = rdev_get_drvdata(reg);
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (anatop_reg->bypass || !anatop_regmap_is_enabled(reg)) {
|
||||||
|
anatop_reg->sel = selector;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = regulator_set_voltage_sel_regmap(reg, selector);
|
||||||
|
if (!ret)
|
||||||
|
anatop_reg->sel = selector;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int anatop_regmap_core_get_voltage_sel(struct regulator_dev *reg)
|
||||||
{
|
{
|
||||||
struct anatop_regulator *anatop_reg = rdev_get_drvdata(reg);
|
struct anatop_regulator *anatop_reg = rdev_get_drvdata(reg);
|
||||||
|
|
||||||
if (!anatop_reg->control_reg)
|
if (anatop_reg->bypass || !anatop_regmap_is_enabled(reg))
|
||||||
return -ENOTSUPP;
|
return anatop_reg->sel;
|
||||||
|
|
||||||
return regulator_get_voltage_sel_regmap(reg);
|
return regulator_get_voltage_sel_regmap(reg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int anatop_regmap_get_bypass(struct regulator_dev *reg, bool *enable)
|
||||||
|
{
|
||||||
|
struct anatop_regulator *anatop_reg = rdev_get_drvdata(reg);
|
||||||
|
int sel;
|
||||||
|
|
||||||
|
sel = regulator_get_voltage_sel_regmap(reg);
|
||||||
|
if (sel == LDO_FET_FULL_ON)
|
||||||
|
WARN_ON(!anatop_reg->bypass);
|
||||||
|
else if (sel != LDO_POWER_GATE)
|
||||||
|
WARN_ON(anatop_reg->bypass);
|
||||||
|
|
||||||
|
*enable = anatop_reg->bypass;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int anatop_regmap_set_bypass(struct regulator_dev *reg, bool enable)
|
||||||
|
{
|
||||||
|
struct anatop_regulator *anatop_reg = rdev_get_drvdata(reg);
|
||||||
|
int sel;
|
||||||
|
|
||||||
|
if (enable == anatop_reg->bypass)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
sel = enable ? LDO_FET_FULL_ON : anatop_reg->sel;
|
||||||
|
anatop_reg->bypass = enable;
|
||||||
|
|
||||||
|
return regulator_set_voltage_sel_regmap(reg, sel);
|
||||||
|
}
|
||||||
|
|
||||||
static struct regulator_ops anatop_rops = {
|
static struct regulator_ops anatop_rops = {
|
||||||
.set_voltage_sel = anatop_regmap_set_voltage_sel,
|
.set_voltage_sel = regulator_set_voltage_sel_regmap,
|
||||||
.set_voltage_time_sel = anatop_regmap_set_voltage_time_sel,
|
.get_voltage_sel = regulator_get_voltage_sel_regmap,
|
||||||
.get_voltage_sel = anatop_regmap_get_voltage_sel,
|
|
||||||
.list_voltage = regulator_list_voltage_linear,
|
.list_voltage = regulator_list_voltage_linear,
|
||||||
.map_voltage = regulator_map_voltage_linear,
|
.map_voltage = regulator_map_voltage_linear,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct regulator_ops anatop_core_rops = {
|
||||||
|
.enable = anatop_regmap_enable,
|
||||||
|
.disable = anatop_regmap_disable,
|
||||||
|
.is_enabled = anatop_regmap_is_enabled,
|
||||||
|
.set_voltage_sel = anatop_regmap_core_set_voltage_sel,
|
||||||
|
.set_voltage_time_sel = anatop_regmap_set_voltage_time_sel,
|
||||||
|
.get_voltage_sel = anatop_regmap_core_get_voltage_sel,
|
||||||
|
.list_voltage = regulator_list_voltage_linear,
|
||||||
|
.map_voltage = regulator_map_voltage_linear,
|
||||||
|
.get_bypass = anatop_regmap_get_bypass,
|
||||||
|
.set_bypass = anatop_regmap_set_bypass,
|
||||||
|
};
|
||||||
|
|
||||||
static int anatop_regulator_probe(struct platform_device *pdev)
|
static int anatop_regulator_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
@ -116,6 +187,7 @@ static int anatop_regulator_probe(struct platform_device *pdev)
|
|||||||
struct regulator_init_data *initdata;
|
struct regulator_init_data *initdata;
|
||||||
struct regulator_config config = { };
|
struct regulator_config config = { };
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
u32 val;
|
||||||
|
|
||||||
initdata = of_get_regulator_init_data(dev, np);
|
initdata = of_get_regulator_init_data(dev, np);
|
||||||
sreg = devm_kzalloc(dev, sizeof(*sreg), GFP_KERNEL);
|
sreg = devm_kzalloc(dev, sizeof(*sreg), GFP_KERNEL);
|
||||||
@ -125,7 +197,6 @@ static int anatop_regulator_probe(struct platform_device *pdev)
|
|||||||
sreg->name = of_get_property(np, "regulator-name", NULL);
|
sreg->name = of_get_property(np, "regulator-name", NULL);
|
||||||
rdesc = &sreg->rdesc;
|
rdesc = &sreg->rdesc;
|
||||||
rdesc->name = sreg->name;
|
rdesc->name = sreg->name;
|
||||||
rdesc->ops = &anatop_rops;
|
|
||||||
rdesc->type = REGULATOR_VOLTAGE;
|
rdesc->type = REGULATOR_VOLTAGE;
|
||||||
rdesc->owner = THIS_MODULE;
|
rdesc->owner = THIS_MODULE;
|
||||||
|
|
||||||
@ -197,6 +268,25 @@ static int anatop_regulator_probe(struct platform_device *pdev)
|
|||||||
config.of_node = pdev->dev.of_node;
|
config.of_node = pdev->dev.of_node;
|
||||||
config.regmap = sreg->anatop;
|
config.regmap = sreg->anatop;
|
||||||
|
|
||||||
|
/* Only core regulators have the ramp up delay configuration. */
|
||||||
|
if (sreg->control_reg && sreg->delay_bit_width) {
|
||||||
|
rdesc->ops = &anatop_core_rops;
|
||||||
|
|
||||||
|
ret = regmap_read(config.regmap, rdesc->vsel_reg, &val);
|
||||||
|
if (ret) {
|
||||||
|
dev_err(dev, "failed to read initial state\n");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
sreg->sel = (val & rdesc->vsel_mask) >> sreg->vol_bit_shift;
|
||||||
|
if (sreg->sel == LDO_FET_FULL_ON) {
|
||||||
|
sreg->sel = 0;
|
||||||
|
sreg->bypass = true;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
rdesc->ops = &anatop_rops;
|
||||||
|
}
|
||||||
|
|
||||||
/* register regulator */
|
/* register regulator */
|
||||||
rdev = devm_regulator_register(dev, rdesc, &config);
|
rdev = devm_regulator_register(dev, rdesc, &config);
|
||||||
if (IS_ERR(rdev)) {
|
if (IS_ERR(rdev)) {
|
||||||
|
@ -153,11 +153,9 @@ static const struct regulator_desc arizona_ldo1 = {
|
|||||||
|
|
||||||
.vsel_reg = ARIZONA_LDO1_CONTROL_1,
|
.vsel_reg = ARIZONA_LDO1_CONTROL_1,
|
||||||
.vsel_mask = ARIZONA_LDO1_VSEL_MASK,
|
.vsel_mask = ARIZONA_LDO1_VSEL_MASK,
|
||||||
.bypass_reg = ARIZONA_LDO1_CONTROL_1,
|
|
||||||
.bypass_mask = ARIZONA_LDO1_BYPASS,
|
|
||||||
.min_uV = 900000,
|
.min_uV = 900000,
|
||||||
.uV_step = 50000,
|
.uV_step = 25000,
|
||||||
.n_voltages = 7,
|
.n_voltages = 13,
|
||||||
.enable_time = 500,
|
.enable_time = 500,
|
||||||
|
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
@ -189,10 +187,8 @@ static int arizona_ldo1_probe(struct platform_device *pdev)
|
|||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
ldo1 = devm_kzalloc(&pdev->dev, sizeof(*ldo1), GFP_KERNEL);
|
ldo1 = devm_kzalloc(&pdev->dev, sizeof(*ldo1), GFP_KERNEL);
|
||||||
if (ldo1 == NULL) {
|
if (!ldo1)
|
||||||
dev_err(&pdev->dev, "Unable to allocate private data\n");
|
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
|
||||||
|
|
||||||
ldo1->arizona = arizona;
|
ldo1->arizona = arizona;
|
||||||
|
|
||||||
@ -203,6 +199,7 @@ static int arizona_ldo1_probe(struct platform_device *pdev)
|
|||||||
*/
|
*/
|
||||||
switch (arizona->type) {
|
switch (arizona->type) {
|
||||||
case WM5102:
|
case WM5102:
|
||||||
|
case WM8997:
|
||||||
desc = &arizona_ldo1_hc;
|
desc = &arizona_ldo1_hc;
|
||||||
ldo1->init_data = arizona_ldo1_dvfs;
|
ldo1->init_data = arizona_ldo1_dvfs;
|
||||||
break;
|
break;
|
||||||
|
@ -204,10 +204,8 @@ static int arizona_micsupp_probe(struct platform_device *pdev)
|
|||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
micsupp = devm_kzalloc(&pdev->dev, sizeof(*micsupp), GFP_KERNEL);
|
micsupp = devm_kzalloc(&pdev->dev, sizeof(*micsupp), GFP_KERNEL);
|
||||||
if (micsupp == NULL) {
|
if (!micsupp)
|
||||||
dev_err(&pdev->dev, "Unable to allocate private data\n");
|
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
|
||||||
|
|
||||||
micsupp->arizona = arizona;
|
micsupp->arizona = arizona;
|
||||||
INIT_WORK(&micsupp->check_cp_work, arizona_micsupp_check_cp);
|
INIT_WORK(&micsupp->check_cp_work, arizona_micsupp_check_cp);
|
||||||
|
@ -191,7 +191,7 @@ static int as3711_regulator_parse_dt(struct device *dev,
|
|||||||
{
|
{
|
||||||
struct as3711_regulator_pdata *pdata = dev_get_platdata(dev);
|
struct as3711_regulator_pdata *pdata = dev_get_platdata(dev);
|
||||||
struct device_node *regulators =
|
struct device_node *regulators =
|
||||||
of_find_node_by_name(dev->parent->of_node, "regulators");
|
of_get_child_by_name(dev->parent->of_node, "regulators");
|
||||||
struct of_regulator_match *match;
|
struct of_regulator_match *match;
|
||||||
int ret, i;
|
int ret, i;
|
||||||
|
|
||||||
@ -221,7 +221,6 @@ static int as3711_regulator_probe(struct platform_device *pdev)
|
|||||||
{
|
{
|
||||||
struct as3711_regulator_pdata *pdata = dev_get_platdata(&pdev->dev);
|
struct as3711_regulator_pdata *pdata = dev_get_platdata(&pdev->dev);
|
||||||
struct as3711 *as3711 = dev_get_drvdata(pdev->dev.parent);
|
struct as3711 *as3711 = dev_get_drvdata(pdev->dev.parent);
|
||||||
struct regulator_init_data *reg_data;
|
|
||||||
struct regulator_config config = {.dev = &pdev->dev,};
|
struct regulator_config config = {.dev = &pdev->dev,};
|
||||||
struct as3711_regulator *reg = NULL;
|
struct as3711_regulator *reg = NULL;
|
||||||
struct as3711_regulator *regs;
|
struct as3711_regulator *regs;
|
||||||
@ -246,22 +245,14 @@ static int as3711_regulator_probe(struct platform_device *pdev)
|
|||||||
|
|
||||||
regs = devm_kzalloc(&pdev->dev, AS3711_REGULATOR_NUM *
|
regs = devm_kzalloc(&pdev->dev, AS3711_REGULATOR_NUM *
|
||||||
sizeof(struct as3711_regulator), GFP_KERNEL);
|
sizeof(struct as3711_regulator), GFP_KERNEL);
|
||||||
if (!regs) {
|
if (!regs)
|
||||||
dev_err(&pdev->dev, "Memory allocation failed exiting..\n");
|
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
|
||||||
|
|
||||||
for (id = 0, ri = as3711_reg_info; id < AS3711_REGULATOR_NUM; ++id, ri++) {
|
for (id = 0, ri = as3711_reg_info; id < AS3711_REGULATOR_NUM; ++id, ri++) {
|
||||||
reg_data = pdata->init_data[id];
|
|
||||||
|
|
||||||
/* No need to register if there is no regulator data */
|
|
||||||
if (!reg_data)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
reg = ®s[id];
|
reg = ®s[id];
|
||||||
reg->reg_info = ri;
|
reg->reg_info = ri;
|
||||||
|
|
||||||
config.init_data = reg_data;
|
config.init_data = pdata->init_data[id];
|
||||||
config.driver_data = reg;
|
config.driver_data = reg;
|
||||||
config.regmap = as3711->regmap;
|
config.regmap = as3711->regmap;
|
||||||
config.of_node = of_node[id];
|
config.of_node = of_node[id];
|
||||||
|
@ -719,6 +719,7 @@ static int as3722_get_regulator_dt_data(struct platform_device *pdev,
|
|||||||
|
|
||||||
ret = of_regulator_match(&pdev->dev, np, as3722_regulator_matches,
|
ret = of_regulator_match(&pdev->dev, np, as3722_regulator_matches,
|
||||||
ARRAY_SIZE(as3722_regulator_matches));
|
ARRAY_SIZE(as3722_regulator_matches));
|
||||||
|
of_node_put(np);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
dev_err(&pdev->dev, "Parsing of regulator node failed: %d\n",
|
dev_err(&pdev->dev, "Parsing of regulator node failed: %d\n",
|
||||||
ret);
|
ret);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user