提交 62d62b59 编写于 作者: M Mark Brown 提交者: Samuel Ortiz

mfd: arizona: Defer patch initialistation until after first device boot

Make sure that we don't race with the initial device boot by only doing
the initialisation after we've waited for the boot to complete.

The runtime PM code already waits for the boot to complete before it
syncs the register patches so in most systems if a race does occur we will
power down very soon afterwards and recover anyway.
Reported-by: NCharles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: NMark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: NSamuel Ortiz <sameo@linux.intel.com>
上级 0582c0fa
...@@ -292,6 +292,7 @@ int __devinit arizona_dev_init(struct arizona *arizona) ...@@ -292,6 +292,7 @@ int __devinit arizona_dev_init(struct arizona *arizona)
struct device *dev = arizona->dev; struct device *dev = arizona->dev;
const char *type_name; const char *type_name;
unsigned int reg, val; unsigned int reg, val;
int (*apply_patch)(struct arizona *) = NULL;
int ret, i; int ret, i;
dev_set_drvdata(arizona->dev, arizona); dev_set_drvdata(arizona->dev, arizona);
...@@ -391,7 +392,7 @@ int __devinit arizona_dev_init(struct arizona *arizona) ...@@ -391,7 +392,7 @@ int __devinit arizona_dev_init(struct arizona *arizona)
arizona->type); arizona->type);
arizona->type = WM5102; arizona->type = WM5102;
} }
ret = wm5102_patch(arizona); apply_patch = wm5102_patch;
break; break;
#endif #endif
#ifdef CONFIG_MFD_WM5110 #ifdef CONFIG_MFD_WM5110
...@@ -402,7 +403,7 @@ int __devinit arizona_dev_init(struct arizona *arizona) ...@@ -402,7 +403,7 @@ int __devinit arizona_dev_init(struct arizona *arizona)
arizona->type); arizona->type);
arizona->type = WM5110; arizona->type = WM5110;
} }
ret = wm5110_patch(arizona); apply_patch = wm5110_patch;
break; break;
#endif #endif
default: default:
...@@ -412,9 +413,6 @@ int __devinit arizona_dev_init(struct arizona *arizona) ...@@ -412,9 +413,6 @@ int __devinit arizona_dev_init(struct arizona *arizona)
dev_info(dev, "%s revision %c\n", type_name, arizona->rev + 'A'); dev_info(dev, "%s revision %c\n", type_name, arizona->rev + 'A');
if (ret != 0)
dev_err(arizona->dev, "Failed to apply patch: %d\n", ret);
/* If we have a /RESET GPIO we'll already be reset */ /* If we have a /RESET GPIO we'll already be reset */
if (!arizona->pdata.reset) { if (!arizona->pdata.reset) {
ret = regmap_write(arizona->regmap, ARIZONA_SOFTWARE_RESET, 0); ret = regmap_write(arizona->regmap, ARIZONA_SOFTWARE_RESET, 0);
...@@ -430,6 +428,15 @@ int __devinit arizona_dev_init(struct arizona *arizona) ...@@ -430,6 +428,15 @@ int __devinit arizona_dev_init(struct arizona *arizona)
goto err_reset; goto err_reset;
} }
if (apply_patch) {
ret = apply_patch(arizona);
if (ret != 0) {
dev_err(arizona->dev, "Failed to apply patch: %d\n",
ret);
goto err_reset;
}
}
for (i = 0; i < ARRAY_SIZE(arizona->pdata.gpio_defaults); i++) { for (i = 0; i < ARRAY_SIZE(arizona->pdata.gpio_defaults); i++) {
if (!arizona->pdata.gpio_defaults[i]) if (!arizona->pdata.gpio_defaults[i])
continue; continue;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册