diff options
| author | Haojian Zhuang <haojian.zhuang@marvell.com> | 2010-04-29 13:33:50 -0400 |
|---|---|---|
| committer | Liam Girdwood <lrg@slimlogic.co.uk> | 2010-05-25 05:16:02 -0400 |
| commit | 192bbb95ca16f2b4d4383e76b3262672e6116daa (patch) | |
| tree | 1e090809827018c4a7d4f9dfcd6a97e3ab08c106 | |
| parent | d4033b54fc91221b13e2850bf298683c0f2ff37d (diff) | |
regulator: make 88pm860x sharing one driver structure
Remove a lot of driver structures in 88pm860x driver. Make regulators share
one driver structure.
Signed-off-by: Haojian Zhuang <haojian.zhuang@marvell.com>
Acked-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: Liam Girdwood <lrg@slimlogic.co.uk>
| -rw-r--r-- | drivers/mfd/88pm860x-core.c | 34 | ||||
| -rw-r--r-- | drivers/regulator/88pm8607.c | 51 |
2 files changed, 27 insertions, 58 deletions
diff --git a/drivers/mfd/88pm860x-core.c b/drivers/mfd/88pm860x-core.c index 6a14d2b1ccf0..21de38daf948 100644 --- a/drivers/mfd/88pm860x-core.c +++ b/drivers/mfd/88pm860x-core.c | |||
| @@ -176,30 +176,30 @@ static struct resource regulator_resources[] = { | |||
| 176 | PM8607_REG_RESOURCE(LDO14, LDO14), | 176 | PM8607_REG_RESOURCE(LDO14, LDO14), |
| 177 | }; | 177 | }; |
| 178 | 178 | ||
| 179 | #define PM8607_REG_DEVS(_name, _id) \ | 179 | #define PM8607_REG_DEVS(_id) \ |
| 180 | { \ | 180 | { \ |
| 181 | .name = "88pm8607-" #_name, \ | 181 | .name = "88pm860x-regulator", \ |
| 182 | .num_resources = 1, \ | 182 | .num_resources = 1, \ |
| 183 | .resources = ®ulator_resources[PM8607_ID_##_id], \ | 183 | .resources = ®ulator_resources[PM8607_ID_##_id], \ |
| 184 | .id = PM8607_ID_##_id, \ | 184 | .id = PM8607_ID_##_id, \ |
| 185 | } | 185 | } |
| 186 | 186 | ||
| 187 | static struct mfd_cell regulator_devs[] = { | 187 | static struct mfd_cell regulator_devs[] = { |
| 188 | PM8607_REG_DEVS(buck1, BUCK1), | 188 | PM8607_REG_DEVS(BUCK1), |
| 189 | PM8607_REG_DEVS(buck2, BUCK2), | 189 | PM8607_REG_DEVS(BUCK2), |
| 190 | PM8607_REG_DEVS(buck3, BUCK3), | 190 | PM8607_REG_DEVS(BUCK3), |
| 191 | PM8607_REG_DEVS(ldo1, LDO1), | 191 | PM8607_REG_DEVS(LDO1), |
| 192 | PM8607_REG_DEVS(ldo2, LDO2), | 192 | PM8607_REG_DEVS(LDO2), |
| 193 | PM8607_REG_DEVS(ldo3, LDO3), | 193 | PM8607_REG_DEVS(LDO3), |
| 194 | PM8607_REG_DEVS(ldo4, LDO4), | 194 | PM8607_REG_DEVS(LDO4), |
| 195 | PM8607_REG_DEVS(ldo5, LDO5), | 195 | PM8607_REG_DEVS(LDO5), |
| 196 | PM8607_REG_DEVS(ldo6, LDO6), | 196 | PM8607_REG_DEVS(LDO6), |
| 197 | PM8607_REG_DEVS(ldo7, LDO7), | 197 | PM8607_REG_DEVS(LDO7), |
| 198 | PM8607_REG_DEVS(ldo8, LDO8), | 198 | PM8607_REG_DEVS(LDO8), |
| 199 | PM8607_REG_DEVS(ldo9, LDO9), | 199 | PM8607_REG_DEVS(LDO9), |
| 200 | PM8607_REG_DEVS(ldo10, LDO10), | 200 | PM8607_REG_DEVS(LDO10), |
| 201 | PM8607_REG_DEVS(ldo12, LDO12), | 201 | PM8607_REG_DEVS(LDO12), |
| 202 | PM8607_REG_DEVS(ldo14, LDO14), | 202 | PM8607_REG_DEVS(LDO14), |
| 203 | }; | 203 | }; |
| 204 | 204 | ||
| 205 | struct pm860x_irq_data { | 205 | struct pm860x_irq_data { |
diff --git a/drivers/regulator/88pm8607.c b/drivers/regulator/88pm8607.c index 5fb83e2ced25..121bab4c0dc0 100644 --- a/drivers/regulator/88pm8607.c +++ b/drivers/regulator/88pm8607.c | |||
| @@ -484,60 +484,29 @@ static int __devexit pm8607_regulator_remove(struct platform_device *pdev) | |||
| 484 | { | 484 | { |
| 485 | struct pm8607_regulator_info *info = platform_get_drvdata(pdev); | 485 | struct pm8607_regulator_info *info = platform_get_drvdata(pdev); |
| 486 | 486 | ||
| 487 | platform_set_drvdata(pdev, NULL); | ||
| 487 | regulator_unregister(info->regulator); | 488 | regulator_unregister(info->regulator); |
| 488 | return 0; | 489 | return 0; |
| 489 | } | 490 | } |
| 490 | 491 | ||
| 491 | #define PM8607_REGULATOR_DRIVER(_name) \ | 492 | static struct platform_driver pm8607_regulator_driver = { |
| 492 | { \ | 493 | .driver = { |
| 493 | .driver = { \ | 494 | .name = "88pm860x-regulator", |
| 494 | .name = "88pm8607-" #_name, \ | 495 | .owner = THIS_MODULE, |
| 495 | .owner = THIS_MODULE, \ | 496 | }, |
| 496 | }, \ | 497 | .probe = pm8607_regulator_probe, |
| 497 | .probe = pm8607_regulator_probe, \ | 498 | .remove = __devexit_p(pm8607_regulator_remove), |
| 498 | .remove = __devexit_p(pm8607_regulator_remove), \ | ||
| 499 | } | ||
| 500 | |||
| 501 | static struct platform_driver pm8607_regulator_driver[] = { | ||
| 502 | PM8607_REGULATOR_DRIVER(buck1), | ||
| 503 | PM8607_REGULATOR_DRIVER(buck2), | ||
| 504 | PM8607_REGULATOR_DRIVER(buck3), | ||
| 505 | PM8607_REGULATOR_DRIVER(ldo1), | ||
| 506 | PM8607_REGULATOR_DRIVER(ldo2), | ||
| 507 | PM8607_REGULATOR_DRIVER(ldo3), | ||
| 508 | PM8607_REGULATOR_DRIVER(ldo4), | ||
| 509 | PM8607_REGULATOR_DRIVER(ldo5), | ||
| 510 | PM8607_REGULATOR_DRIVER(ldo6), | ||
| 511 | PM8607_REGULATOR_DRIVER(ldo7), | ||
| 512 | PM8607_REGULATOR_DRIVER(ldo8), | ||
| 513 | PM8607_REGULATOR_DRIVER(ldo9), | ||
| 514 | PM8607_REGULATOR_DRIVER(ldo10), | ||
| 515 | PM8607_REGULATOR_DRIVER(ldo12), | ||
| 516 | PM8607_REGULATOR_DRIVER(ldo14), | ||
| 517 | }; | 499 | }; |
| 518 | 500 | ||
| 519 | static int __init pm8607_regulator_init(void) | 501 | static int __init pm8607_regulator_init(void) |
| 520 | { | 502 | { |
| 521 | int i, count, ret; | 503 | return platform_driver_register(&pm8607_regulator_driver); |
| 522 | |||
| 523 | count = ARRAY_SIZE(pm8607_regulator_driver); | ||
| 524 | for (i = 0; i < count; i++) { | ||
| 525 | ret = platform_driver_register(&pm8607_regulator_driver[i]); | ||
| 526 | if (ret != 0) | ||
| 527 | pr_err("Failed to register regulator driver: %d\n", | ||
| 528 | ret); | ||
| 529 | } | ||
| 530 | return 0; | ||
| 531 | } | 504 | } |
| 532 | subsys_initcall(pm8607_regulator_init); | 505 | subsys_initcall(pm8607_regulator_init); |
| 533 | 506 | ||
| 534 | static void __exit pm8607_regulator_exit(void) | 507 | static void __exit pm8607_regulator_exit(void) |
| 535 | { | 508 | { |
| 536 | int i, count; | 509 | platform_driver_unregister(&pm8607_regulator_driver); |
| 537 | |||
| 538 | count = ARRAY_SIZE(pm8607_regulator_driver); | ||
| 539 | for (i = 0; i < count; i++) | ||
| 540 | platform_driver_unregister(&pm8607_regulator_driver[i]); | ||
| 541 | } | 510 | } |
| 542 | module_exit(pm8607_regulator_exit); | 511 | module_exit(pm8607_regulator_exit); |
| 543 | 512 | ||
