Commit cb189b07 authored by Bengt Jonsson's avatar Bengt Jonsson Committed by Liam Girdwood

regulators: Moved define for number of regulators in ab8500

The define for number of regulators is moved from ab8500-core to
ab8500-regulator so that the regulator driver can be updated
independently of ab8500-core. This also changes the platform
configuration structure of ab8500-core so that it contains a
pointer to the regulator_init_data array plus number of
regulators instead of an fixed size array of pointers to
regulator_init_data.
Signed-off-by: default avatarBengt Jonsson <bengt.g.jonsson@stericsson.com>
Acked-by: default avatarLinus Walleij <linus.walleij@stericsson.com>
Acked-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: default avatarLiam Girdwood <lrg@slimlogic.co.uk>
parent 1394fd28
...@@ -370,6 +370,12 @@ static __devinit int ab8500_regulator_probe(struct platform_device *pdev) ...@@ -370,6 +370,12 @@ static __devinit int ab8500_regulator_probe(struct platform_device *pdev)
} }
pdata = dev_get_platdata(ab8500->dev); pdata = dev_get_platdata(ab8500->dev);
/* make sure the platform data has the correct size */
if (pdata->num_regulator != ARRAY_SIZE(ab8500_regulator_info)) {
dev_err(&pdev->dev, "platform configuration error\n");
return -EINVAL;
}
/* register all regulators */ /* register all regulators */
for (i = 0; i < ARRAY_SIZE(ab8500_regulator_info); i++) { for (i = 0; i < ARRAY_SIZE(ab8500_regulator_info); i++) {
struct ab8500_regulator_info *info = NULL; struct ab8500_regulator_info *info = NULL;
...@@ -380,7 +386,7 @@ static __devinit int ab8500_regulator_probe(struct platform_device *pdev) ...@@ -380,7 +386,7 @@ static __devinit int ab8500_regulator_probe(struct platform_device *pdev)
info->ab8500 = ab8500; info->ab8500 = ab8500;
info->regulator = regulator_register(&info->desc, &pdev->dev, info->regulator = regulator_register(&info->desc, &pdev->dev,
pdata->regulator[i], info); &pdata->regulator[i], info);
if (IS_ERR(info->regulator)) { if (IS_ERR(info->regulator)) {
err = PTR_ERR(info->regulator); err = PTR_ERR(info->regulator);
dev_err(&pdev->dev, "failed to register regulator %s\n", dev_err(&pdev->dev, "failed to register regulator %s\n",
......
...@@ -99,8 +99,6 @@ ...@@ -99,8 +99,6 @@
#define AB8500_NR_IRQS 104 #define AB8500_NR_IRQS 104
#define AB8500_NUM_IRQ_REGS 13 #define AB8500_NUM_IRQ_REGS 13
#define AB8500_NUM_REGULATORS 15
/** /**
* struct ab8500 - ab8500 internal structure * struct ab8500 - ab8500 internal structure
* @dev: parent device * @dev: parent device
...@@ -145,7 +143,8 @@ struct regulator_init_data; ...@@ -145,7 +143,8 @@ struct regulator_init_data;
struct ab8500_platform_data { struct ab8500_platform_data {
int irq_base; int irq_base;
void (*init) (struct ab8500 *); void (*init) (struct ab8500 *);
struct regulator_init_data *regulator[AB8500_NUM_REGULATORS]; int num_regulator;
struct regulator_init_data *regulator;
}; };
extern int __devinit ab8500_init(struct ab8500 *ab8500); extern int __devinit ab8500_init(struct ab8500 *ab8500);
......
...@@ -11,15 +11,17 @@ ...@@ -11,15 +11,17 @@
#define __LINUX_MFD_AB8500_REGULATOR_H #define __LINUX_MFD_AB8500_REGULATOR_H
/* AB8500 regulators */ /* AB8500 regulators */
#define AB8500_LDO_AUX1 0 enum ab8500_regulator_id {
#define AB8500_LDO_AUX2 1 AB8500_LDO_AUX1,
#define AB8500_LDO_AUX3 2 AB8500_LDO_AUX2,
#define AB8500_LDO_INTCORE 3 AB8500_LDO_AUX3,
#define AB8500_LDO_TVOUT 4 AB8500_LDO_INTCORE,
#define AB8500_LDO_AUDIO 5 AB8500_LDO_TVOUT,
#define AB8500_LDO_ANAMIC1 6 AB8500_LDO_AUDIO,
#define AB8500_LDO_ANAMIC2 7 AB8500_LDO_ANAMIC1,
#define AB8500_LDO_DMIC 8 AB8500_LDO_ANAMIC2,
#define AB8500_LDO_ANA 9 AB8500_LDO_DMIC,
AB8500_LDO_ANA,
AB8500_NUM_REGULATORS,
};
#endif #endif
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