Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 357596
b: refs/heads/master
c: 306df79
h: refs/heads/master
v: v3
  • Loading branch information
Yi Zhang authored and Samuel Ortiz committed Feb 13, 2013
1 parent 7098632 commit 4937137
Show file tree
Hide file tree
Showing 5 changed files with 11 additions and 29 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: b3aac62bbb1c3f8e71c88e6e477836def3058fe8
refs/heads/master: 306df798507d8e009a7d4a5e8ce238a3b107de20
10 changes: 3 additions & 7 deletions trunk/drivers/mfd/88pm800.c
Original file line number Diff line number Diff line change
Expand Up @@ -531,7 +531,7 @@ static int pm800_probe(struct i2c_client *client,
ret = device_800_init(chip, pdata);
if (ret) {
dev_err(chip->dev, "%s id 0x%x failed!\n", __func__, chip->id);
goto err_800_init;
goto err_subchip_alloc;
}

ret = pm800_pages_init(chip);
Expand All @@ -546,10 +546,8 @@ static int pm800_probe(struct i2c_client *client,
err_page_init:
mfd_remove_devices(chip->dev);
device_irq_exit_800(chip);
err_800_init:
devm_kfree(&client->dev, subchip);
err_subchip_alloc:
pm80x_deinit(client);
pm80x_deinit();
out_init:
return ret;
}
Expand All @@ -562,9 +560,7 @@ static int pm800_remove(struct i2c_client *client)
device_irq_exit_800(chip);

pm800_pages_exit(chip);
devm_kfree(&client->dev, chip->subchip);

pm80x_deinit(client);
pm80x_deinit();

return 0;
}
Expand Down
4 changes: 2 additions & 2 deletions trunk/drivers/mfd/88pm805.c
Original file line number Diff line number Diff line change
Expand Up @@ -257,7 +257,7 @@ static int pm805_probe(struct i2c_client *client,
pdata->plat_config(chip, pdata);

err_805_init:
pm80x_deinit(client);
pm80x_deinit();
out_init:
return ret;
}
Expand All @@ -269,7 +269,7 @@ static int pm805_remove(struct i2c_client *client)
mfd_remove_devices(chip->dev);
device_irq_exit_805(chip);

pm80x_deinit(client);
pm80x_deinit();

return 0;
}
Expand Down
22 changes: 4 additions & 18 deletions trunk/drivers/mfd/88pm80x.c
Original file line number Diff line number Diff line change
Expand Up @@ -48,14 +48,12 @@ int pm80x_init(struct i2c_client *client,
ret = PTR_ERR(map);
dev_err(&client->dev, "Failed to allocate register map: %d\n",
ret);
goto err_regmap_init;
return ret;
}

chip->id = id->driver_data;
if (chip->id < CHIP_PM800 || chip->id > CHIP_PM805) {
ret = -EINVAL;
goto err_chip_id;
}
if (chip->id < CHIP_PM800 || chip->id > CHIP_PM805)
return -EINVAL;

chip->client = client;
chip->regmap = map;
Expand All @@ -82,19 +80,11 @@ int pm80x_init(struct i2c_client *client,
}

return 0;

err_chip_id:
regmap_exit(map);
err_regmap_init:
devm_kfree(&client->dev, chip);
return ret;
}
EXPORT_SYMBOL_GPL(pm80x_init);

int pm80x_deinit(struct i2c_client *client)
int pm80x_deinit(void)
{
struct pm80x_chip *chip = i2c_get_clientdata(client);

/*
* workaround: clear the dependency between pm800 and pm805.
* would remove it after HW chip fixes the issue.
Expand All @@ -103,10 +93,6 @@ int pm80x_deinit(struct i2c_client *client)
g_pm80x_chip->companion = NULL;
else
g_pm80x_chip = NULL;

regmap_exit(chip->regmap);
devm_kfree(&client->dev, chip);

return 0;
}
EXPORT_SYMBOL_GPL(pm80x_deinit);
Expand Down
2 changes: 1 addition & 1 deletion trunk/include/linux/mfd/88pm80x.h
Original file line number Diff line number Diff line change
Expand Up @@ -365,5 +365,5 @@ static inline int pm80x_dev_resume(struct device *dev)

extern int pm80x_init(struct i2c_client *client,
const struct i2c_device_id *id);
extern int pm80x_deinit(struct i2c_client *client);
extern int pm80x_deinit(void);
#endif /* __LINUX_MFD_88PM80X_H */

0 comments on commit 4937137

Please sign in to comment.