diff options
author | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2008-11-24 14:20:30 -0500 |
---|---|---|
committer | Samuel Ortiz <samuel@sortiz.org> | 2009-01-04 06:17:38 -0500 |
commit | d756f4a4446227ca9626087939a6769ca55ab036 (patch) | |
tree | 572e6788f3aa01c74c1c8ebb139b0d8a137cdd72 /drivers | |
parent | 14431aa0c5a443d13d24e6f865a8838f97dab973 (diff) |
mfd: Switch WM8350 revision detection to a feature based model
Rather than check for chip revisions in the WM8350 drivers have the core
code set flags for relevant differences.
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: Samuel Ortiz <sameo@openedhand.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/mfd/wm8350-core.c | 6 | ||||
-rw-r--r-- | drivers/power/wm8350_power.c | 2 |
2 files changed, 3 insertions, 5 deletions
diff --git a/drivers/mfd/wm8350-core.c b/drivers/mfd/wm8350-core.c index 60439bd3984d..764bf15ea684 100644 --- a/drivers/mfd/wm8350-core.c +++ b/drivers/mfd/wm8350-core.c | |||
@@ -1240,19 +1240,17 @@ int wm8350_device_init(struct wm8350 *wm8350, int irq, | |||
1240 | switch ((id2 & WM8350_CHIP_REV_MASK) >> 12) { | 1240 | switch ((id2 & WM8350_CHIP_REV_MASK) >> 12) { |
1241 | case WM8350_REV_E: | 1241 | case WM8350_REV_E: |
1242 | dev_info(wm8350->dev, "Found Rev E device\n"); | 1242 | dev_info(wm8350->dev, "Found Rev E device\n"); |
1243 | wm8350->rev = WM8350_REV_E; | ||
1244 | break; | 1243 | break; |
1245 | case WM8350_REV_F: | 1244 | case WM8350_REV_F: |
1246 | dev_info(wm8350->dev, "Found Rev F device\n"); | 1245 | dev_info(wm8350->dev, "Found Rev F device\n"); |
1247 | wm8350->rev = WM8350_REV_F; | ||
1248 | break; | 1246 | break; |
1249 | case WM8350_REV_G: | 1247 | case WM8350_REV_G: |
1250 | dev_info(wm8350->dev, "Found Rev G device\n"); | 1248 | dev_info(wm8350->dev, "Found Rev G device\n"); |
1251 | wm8350->rev = WM8350_REV_G; | 1249 | wm8350->power.rev_g_coeff = 1; |
1252 | break; | 1250 | break; |
1253 | case WM8350_REV_H: | 1251 | case WM8350_REV_H: |
1254 | dev_info(wm8350->dev, "Found Rev H device\n"); | 1252 | dev_info(wm8350->dev, "Found Rev H device\n"); |
1255 | wm8350->rev = WM8350_REV_H; | 1253 | wm8350->power.rev_g_coeff = 1; |
1256 | break; | 1254 | break; |
1257 | default: | 1255 | default: |
1258 | /* For safety we refuse to run on unknown hardware */ | 1256 | /* For safety we refuse to run on unknown hardware */ |
diff --git a/drivers/power/wm8350_power.c b/drivers/power/wm8350_power.c index 9c0a847a1139..74e7593beffb 100644 --- a/drivers/power/wm8350_power.c +++ b/drivers/power/wm8350_power.c | |||
@@ -44,7 +44,7 @@ static int wm8350_read_usb_uvolts(struct wm8350 *wm8350) | |||
44 | 44 | ||
45 | static inline int wm8350_charge_time_min(struct wm8350 *wm8350, int min) | 45 | static inline int wm8350_charge_time_min(struct wm8350 *wm8350, int min) |
46 | { | 46 | { |
47 | if (wm8350->rev < WM8350_REV_G) | 47 | if (!wm8350->power.rev_g_coeff) |
48 | return (((min - 30) / 15) & 0xf) << 8; | 48 | return (((min - 30) / 15) & 0xf) << 8; |
49 | else | 49 | else |
50 | return (((min - 30) / 30) & 0xf) << 8; | 50 | return (((min - 30) / 30) & 0xf) << 8; |