]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - drivers/mfd/wm831x-core.c
Merge branch 'sh/pci-express-integration'
[karo-tx-linux.git] / drivers / mfd / wm831x-core.c
index 1a968f34d67911d5029e97e1c67bbb15ebafb60a..1e7aaaf6cc6f871e49c7a59e1cb72d42020a197d 100644 (file)
@@ -95,6 +95,7 @@ enum wm831x_parent {
        WM8311 = 0x8311,
        WM8312 = 0x8312,
        WM8320 = 0x8320,
+       WM8321 = 0x8321,
 };
 
 static int wm831x_reg_locked(struct wm831x *wm831x, unsigned short reg)
@@ -1533,6 +1534,12 @@ static int wm831x_device_init(struct wm831x *wm831x, unsigned long id, int irq)
                dev_info(wm831x->dev, "WM8320 revision %c\n", 'A' + rev);
                break;
 
+       case WM8321:
+               parent = WM8321;
+               wm831x->num_gpio = 12;
+               dev_info(wm831x->dev, "WM8321 revision %c\n", 'A' + rev);
+               break;
+
        default:
                dev_err(wm831x->dev, "Unknown WM831x device %04x\n", ret);
                ret = -EINVAL;
@@ -1607,6 +1614,12 @@ static int wm831x_device_init(struct wm831x *wm831x, unsigned long id, int irq)
                                      NULL, 0);
                break;
 
+       case WM8321:
+               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();
@@ -1744,10 +1757,8 @@ static int wm831x_i2c_probe(struct i2c_client *i2c,
        struct wm831x *wm831x;
 
        wm831x = kzalloc(sizeof(struct wm831x), GFP_KERNEL);
-       if (wm831x == NULL) {
-               kfree(i2c);
+       if (wm831x == NULL)
                return -ENOMEM;
-       }
 
        i2c_set_clientdata(i2c, wm831x);
        wm831x->dev = &i2c->dev;
@@ -1779,6 +1790,7 @@ static const struct i2c_device_id wm831x_i2c_id[] = {
        { "wm8311", WM8311 },
        { "wm8312", WM8312 },
        { "wm8320", WM8320 },
+       { "wm8321", WM8321 },
        { }
 };
 MODULE_DEVICE_TABLE(i2c, wm831x_i2c_id);