Commit ca23f8c1 authored by Mark Brown's avatar Mark Brown Committed by Samuel Ortiz

mfd: Add WM8351 support

The WM8351 is a WM8350 variant. As well as register default changes the
WM8351 has fewer voltage and current regulators than the WM8350.
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: default avatarSamuel Ortiz <sameo@openedhand.com>
parent 645524a9
...@@ -143,6 +143,22 @@ config MFD_WM8350_CONFIG_MODE_3 ...@@ -143,6 +143,22 @@ config MFD_WM8350_CONFIG_MODE_3
bool bool
depends on MFD_WM8350 depends on MFD_WM8350
config MFD_WM8351_CONFIG_MODE_0
bool
depends on MFD_WM8350
config MFD_WM8351_CONFIG_MODE_1
bool
depends on MFD_WM8350
config MFD_WM8351_CONFIG_MODE_2
bool
depends on MFD_WM8350
config MFD_WM8351_CONFIG_MODE_3
bool
depends on MFD_WM8350
config MFD_WM8352_CONFIG_MODE_0 config MFD_WM8352_CONFIG_MODE_0
bool bool
depends on MFD_WM8350 depends on MFD_WM8350
......
...@@ -1169,6 +1169,36 @@ static int wm8350_create_cache(struct wm8350 *wm8350, int type, int mode) ...@@ -1169,6 +1169,36 @@ static int wm8350_create_cache(struct wm8350 *wm8350, int type, int mode)
return -EINVAL; return -EINVAL;
} }
case 1:
switch (mode) {
#ifdef CONFIG_MFD_WM8351_CONFIG_MODE_0
case 0:
reg_map = wm8351_mode0_defaults;
break;
#endif
#ifdef CONFIG_MFD_WM8351_CONFIG_MODE_1
case 1:
reg_map = wm8351_mode1_defaults;
break;
#endif
#ifdef CONFIG_MFD_WM8351_CONFIG_MODE_2
case 2:
reg_map = wm8351_mode2_defaults;
break;
#endif
#ifdef CONFIG_MFD_WM8351_CONFIG_MODE_3
case 3:
reg_map = wm8351_mode3_defaults;
break;
#endif
default:
dev_err(wm8350->dev,
"WM8351 configuration mode %d not supported\n",
mode);
return -EINVAL;
}
break;
case 2: case 2:
switch (mode) { switch (mode) {
#ifdef CONFIG_MFD_WM8352_CONFIG_MODE_0 #ifdef CONFIG_MFD_WM8352_CONFIG_MODE_0
...@@ -1327,6 +1357,23 @@ int wm8350_device_init(struct wm8350 *wm8350, int irq, ...@@ -1327,6 +1357,23 @@ int wm8350_device_init(struct wm8350 *wm8350, int irq,
} }
break; break;
case 1:
wm8350->pmic.max_dcdc = WM8350_DCDC_4;
wm8350->pmic.max_isink = WM8350_ISINK_A;
switch (chip_rev) {
case 0:
dev_info(wm8350->dev, "WM8351 Rev A\n");
wm8350->power.rev_g_coeff = 1;
break;
default:
dev_err(wm8350->dev, "Unknown WM8351 CHIP_REV\n");
ret = -ENODEV;
goto err;
}
break;
case 2: case 2:
wm8350->pmic.max_dcdc = WM8350_DCDC_6; wm8350->pmic.max_dcdc = WM8350_DCDC_6;
wm8350->pmic.max_isink = WM8350_ISINK_B; wm8350->pmic.max_isink = WM8350_ISINK_B;
......
...@@ -97,6 +97,7 @@ static int wm8350_i2c_remove(struct i2c_client *i2c) ...@@ -97,6 +97,7 @@ static int wm8350_i2c_remove(struct i2c_client *i2c)
static const struct i2c_device_id wm8350_i2c_id[] = { static const struct i2c_device_id wm8350_i2c_id[] = {
{ "wm8350", 0 }, { "wm8350", 0 },
{ "wm8351", 0 },
{ "wm8352", 0 }, { "wm8352", 0 },
{ } { }
}; };
......
This diff is collapsed.
...@@ -589,6 +589,10 @@ extern const u16 wm8350_mode0_defaults[]; ...@@ -589,6 +589,10 @@ extern const u16 wm8350_mode0_defaults[];
extern const u16 wm8350_mode1_defaults[]; extern const u16 wm8350_mode1_defaults[];
extern const u16 wm8350_mode2_defaults[]; extern const u16 wm8350_mode2_defaults[];
extern const u16 wm8350_mode3_defaults[]; extern const u16 wm8350_mode3_defaults[];
extern const u16 wm8351_mode0_defaults[];
extern const u16 wm8351_mode1_defaults[];
extern const u16 wm8351_mode2_defaults[];
extern const u16 wm8351_mode3_defaults[];
extern const u16 wm8352_mode0_defaults[]; extern const u16 wm8352_mode0_defaults[];
extern const u16 wm8352_mode1_defaults[]; extern const u16 wm8352_mode1_defaults[];
extern const u16 wm8352_mode2_defaults[]; extern const u16 wm8352_mode2_defaults[];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment