From 00d38e5b25c39c124727a1a68dfdb42b90f5e8d4 Mon Sep 17 00:00:00 2001 From: Mark Brown Date: Tue, 28 Sep 2010 09:13:39 -0700 Subject: [PATCH] --- yaml --- r: 220608 b: refs/heads/master c: 0b3158842f1f22277bc5cb0968c09a833f9d15c1 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/mfd/wm831x-core.c | 14 ++++++++++++++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index f74afb5f0fc0..6736abd2858e 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: c6252e9ce7f51a2af66bd69c93afb37191467c96 +refs/heads/master: 0b3158842f1f22277bc5cb0968c09a833f9d15c1 diff --git a/trunk/drivers/mfd/wm831x-core.c b/trunk/drivers/mfd/wm831x-core.c index 1e7aaaf6cc6f..ad36579bc815 100644 --- a/trunk/drivers/mfd/wm831x-core.c +++ b/trunk/drivers/mfd/wm831x-core.c @@ -96,6 +96,7 @@ enum wm831x_parent { WM8312 = 0x8312, WM8320 = 0x8320, WM8321 = 0x8321, + WM8325 = 0x8325, }; static int wm831x_reg_locked(struct wm831x *wm831x, unsigned short reg) @@ -1540,6 +1541,12 @@ static int wm831x_device_init(struct wm831x *wm831x, unsigned long id, int irq) dev_info(wm831x->dev, "WM8321 revision %c\n", 'A' + rev); break; + case WM8325: + parent = WM8325; + wm831x->num_gpio = 12; + dev_info(wm831x->dev, "WM8325 revision %c\n", 'A' + rev); + break; + default: dev_err(wm831x->dev, "Unknown WM831x device %04x\n", ret); ret = -EINVAL; @@ -1620,6 +1627,12 @@ static int wm831x_device_init(struct wm831x *wm831x, unsigned long id, int irq) NULL, 0); break; + case WM8325: + ret = mfd_add_devices(wm831x->dev, -1, + wm8320_devs, ARRAY_SIZE(wm8320_devs), + NULL, 0); + break; + default: /* If this happens the bus probe function is buggy */ BUG(); @@ -1791,6 +1804,7 @@ static const struct i2c_device_id wm831x_i2c_id[] = { { "wm8312", WM8312 }, { "wm8320", WM8320 }, { "wm8321", WM8321 }, + { "wm8325", WM8325 }, { } }; MODULE_DEVICE_TABLE(i2c, wm831x_i2c_id);