aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/mfd/pcf50633-core.c30
1 files changed, 17 insertions, 13 deletions
diff --git a/drivers/mfd/pcf50633-core.c b/drivers/mfd/pcf50633-core.c
index c87f7a0a53f8..e15c060d2dc7 100644
--- a/drivers/mfd/pcf50633-core.c
+++ b/drivers/mfd/pcf50633-core.c
@@ -195,8 +195,9 @@ static int pcf50633_probe(struct i2c_client *client,
195 const struct i2c_device_id *ids) 195 const struct i2c_device_id *ids)
196{ 196{
197 struct pcf50633 *pcf; 197 struct pcf50633 *pcf;
198 struct platform_device *pdev;
198 struct pcf50633_platform_data *pdata = dev_get_platdata(&client->dev); 199 struct pcf50633_platform_data *pdata = dev_get_platdata(&client->dev);
199 int i, ret; 200 int i, j, ret;
200 int version, variant; 201 int version, variant;
201 202
202 if (!client->irq) { 203 if (!client->irq) {
@@ -243,9 +244,6 @@ static int pcf50633_probe(struct i2c_client *client,
243 244
244 245
245 for (i = 0; i < PCF50633_NUM_REGULATORS; i++) { 246 for (i = 0; i < PCF50633_NUM_REGULATORS; i++) {
246 struct platform_device *pdev;
247 int j;
248
249 pdev = platform_device_alloc("pcf50633-regulator", i); 247 pdev = platform_device_alloc("pcf50633-regulator", i);
250 if (!pdev) 248 if (!pdev)
251 return -ENOMEM; 249 return -ENOMEM;
@@ -253,25 +251,31 @@ static int pcf50633_probe(struct i2c_client *client,
253 pdev->dev.parent = pcf->dev; 251 pdev->dev.parent = pcf->dev;
254 ret = platform_device_add_data(pdev, &pdata->reg_init_data[i], 252 ret = platform_device_add_data(pdev, &pdata->reg_init_data[i],
255 sizeof(pdata->reg_init_data[i])); 253 sizeof(pdata->reg_init_data[i]));
256 if (ret) { 254 if (ret)
257 platform_device_put(pdev); 255 goto err;
258 for (j = 0; j < i; j++) 256
259 platform_device_put(pcf->regulator_pdev[j]); 257 ret = platform_device_add(pdev);
260 return ret; 258 if (ret)
261 } 259 goto err;
262 pcf->regulator_pdev[i] = pdev;
263 260
264 platform_device_add(pdev); 261 pcf->regulator_pdev[i] = pdev;
265 } 262 }
266 263
267 ret = sysfs_create_group(&client->dev.kobj, &pcf_attr_group); 264 ret = sysfs_create_group(&client->dev.kobj, &pcf_attr_group);
268 if (ret) 265 if (ret)
269 dev_err(pcf->dev, "error creating sysfs entries\n"); 266 dev_warn(pcf->dev, "error creating sysfs entries\n");
270 267
271 if (pdata->probe_done) 268 if (pdata->probe_done)
272 pdata->probe_done(pcf); 269 pdata->probe_done(pcf);
273 270
274 return 0; 271 return 0;
272
273err:
274 platform_device_put(pdev);
275 for (j = 0; j < i; j++)
276 platform_device_put(pcf->regulator_pdev[j]);
277
278 return ret;
275} 279}
276 280
277static int pcf50633_remove(struct i2c_client *client) 281static int pcf50633_remove(struct i2c_client *client)