提交 ae05ea36 编写于 作者: R Richard Fitzgerald 提交者: Lee Jones

mfd: arizona: Simplify adding subdevices

The code was using a switch on the code type to execute
one of several mfd_add_devices() calls. We're already
switching on the code type earlier in the function to
select the correct patch function so we can roll selection
of the mfd device table into the same switch.
Signed-off-by: NRichard Fitzgerald <rf@opensource.wolfsonmicro.com>
Acked-by: NLee Jones <lee.jones@linaro.org>
Signed-off-by: NCharles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: NLee Jones <lee.jones@linaro.org>
上级 161ad30b
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
#include <linux/regulator/consumer.h> #include <linux/regulator/consumer.h>
#include <linux/regulator/machine.h> #include <linux/regulator/machine.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/platform_device.h>
#include <linux/mfd/arizona/core.h> #include <linux/mfd/arizona/core.h>
#include <linux/mfd/arizona/registers.h> #include <linux/mfd/arizona/registers.h>
...@@ -965,7 +966,8 @@ int arizona_dev_init(struct arizona *arizona) ...@@ -965,7 +966,8 @@ int arizona_dev_init(struct arizona *arizona)
const char *type_name; const char *type_name;
unsigned int reg, val, mask; unsigned int reg, val, mask;
int (*apply_patch)(struct arizona *) = NULL; int (*apply_patch)(struct arizona *) = NULL;
int ret, i; const struct mfd_cell *subdevs = NULL;
int n_subdevs, ret, i;
dev_set_drvdata(arizona->dev, arizona); dev_set_drvdata(arizona->dev, arizona);
mutex_init(&arizona->clk_lock); mutex_init(&arizona->clk_lock);
...@@ -1136,6 +1138,8 @@ int arizona_dev_init(struct arizona *arizona) ...@@ -1136,6 +1138,8 @@ int arizona_dev_init(struct arizona *arizona)
} }
apply_patch = wm5102_patch; apply_patch = wm5102_patch;
arizona->rev &= 0x7; arizona->rev &= 0x7;
subdevs = wm5102_devs;
n_subdevs = ARRAY_SIZE(wm5102_devs);
break; break;
#endif #endif
#ifdef CONFIG_MFD_WM5110 #ifdef CONFIG_MFD_WM5110
...@@ -1155,6 +1159,8 @@ int arizona_dev_init(struct arizona *arizona) ...@@ -1155,6 +1159,8 @@ int arizona_dev_init(struct arizona *arizona)
break; break;
} }
apply_patch = wm5110_patch; apply_patch = wm5110_patch;
subdevs = wm5110_devs;
n_subdevs = ARRAY_SIZE(wm5110_devs);
break; break;
#endif #endif
#ifdef CONFIG_MFD_WM8997 #ifdef CONFIG_MFD_WM8997
...@@ -1166,6 +1172,8 @@ int arizona_dev_init(struct arizona *arizona) ...@@ -1166,6 +1172,8 @@ int arizona_dev_init(struct arizona *arizona)
arizona->type = WM8997; arizona->type = WM8997;
} }
apply_patch = wm8997_patch; apply_patch = wm8997_patch;
subdevs = wm8997_devs;
n_subdevs = ARRAY_SIZE(wm8997_devs);
break; break;
#endif #endif
#ifdef CONFIG_MFD_WM8998 #ifdef CONFIG_MFD_WM8998
...@@ -1187,6 +1195,8 @@ int arizona_dev_init(struct arizona *arizona) ...@@ -1187,6 +1195,8 @@ int arizona_dev_init(struct arizona *arizona)
} }
apply_patch = wm8998_patch; apply_patch = wm8998_patch;
subdevs = wm8998_devs;
n_subdevs = ARRAY_SIZE(wm8998_devs);
break; break;
#endif #endif
default: default:
...@@ -1379,28 +1389,10 @@ int arizona_dev_init(struct arizona *arizona) ...@@ -1379,28 +1389,10 @@ int arizona_dev_init(struct arizona *arizona)
arizona_request_irq(arizona, ARIZONA_IRQ_UNDERCLOCKED, "Underclocked", arizona_request_irq(arizona, ARIZONA_IRQ_UNDERCLOCKED, "Underclocked",
arizona_underclocked, arizona); arizona_underclocked, arizona);
switch (arizona->type) { ret = mfd_add_devices(arizona->dev, PLATFORM_DEVID_NONE,
case WM5102: subdevs, n_subdevs, NULL, 0, NULL);
ret = mfd_add_devices(arizona->dev, -1, wm5102_devs,
ARRAY_SIZE(wm5102_devs), NULL, 0, NULL);
break;
case WM5110:
case WM8280:
ret = mfd_add_devices(arizona->dev, -1, wm5110_devs,
ARRAY_SIZE(wm5110_devs), NULL, 0, NULL);
break;
case WM8997:
ret = mfd_add_devices(arizona->dev, -1, wm8997_devs,
ARRAY_SIZE(wm8997_devs), NULL, 0, NULL);
break;
case WM8998:
case WM1814:
ret = mfd_add_devices(arizona->dev, -1, wm8998_devs,
ARRAY_SIZE(wm8998_devs), NULL, 0, NULL);
break;
}
if (ret != 0) { if (ret) {
dev_err(arizona->dev, "Failed to add subdevices: %d\n", ret); dev_err(arizona->dev, "Failed to add subdevices: %d\n", ret);
goto err_irq; goto err_irq;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册