i2c: Dynamically assign adapter id if it wasn't explictly specified
authorKarol Lewandowski <k.lewandowsk@samsung.com>
Tue, 27 Mar 2012 09:10:28 +0000 (11:10 +0200)
committerWolfram Sang <w.sang@pengutronix.de>
Sat, 12 May 2012 12:28:11 +0000 (14:28 +0200)
Commit 488bf314b ("i2c: Allow i2c_add_numbered_adapter() to assign a
bus id") reworked i2c_add_numbered_adapter() to call i2c_add_adapter()
if requested bus was -1.

This allows to simplify driver's initialization procedure by using
just one function for static and dynamic adapter id registration.

This patch updates few more drivers (missed out in original patch)
to use this functionality.

Signed-off-by: Karol Lewandowski <k.lewandowsk@samsung.com>
Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Wolfram Sang <w.sang@pengutronix.de>
drivers/i2c/busses/i2c-gpio.c
drivers/i2c/busses/i2c-pca-platform.c
drivers/i2c/busses/i2c-versatile.c

index c0330a41db039d15ddfece5a81a58abf50d6c1b9..e62d2d938628fecbcb507cb2ef23a93186b88a09 100644 (file)
@@ -190,12 +190,7 @@ static int __devinit i2c_gpio_probe(struct platform_device *pdev)
        adap->dev.parent = &pdev->dev;
        adap->dev.of_node = pdev->dev.of_node;
 
-       /*
-        * If "dev->id" is negative we consider it as zero.
-        * The reason to do so is to avoid sysfs names that only make
-        * sense when there are multiple adapters.
-        */
-       adap->nr = (pdev->id != -1) ? pdev->id : 0;
+       adap->nr = pdev->id;
        ret = i2c_bit_add_numbered_bus(adap);
        if (ret)
                goto err_add_bus;
index 2adbf1a8fdea0019d8ca3acae29790ca18722552..675878f49f76a2ad1c1235068c775abfc583ef0e 100644 (file)
@@ -171,7 +171,7 @@ static int __devinit i2c_pca_pf_probe(struct platform_device *pdev)
        i2c->io_size = resource_size(res);
        i2c->irq = irq;
 
-       i2c->adap.nr = pdev->id >= 0 ? pdev->id : 0;
+       i2c->adap.nr = pdev->id;
        i2c->adap.owner = THIS_MODULE;
        snprintf(i2c->adap.name, sizeof(i2c->adap.name),
                 "PCA9564/PCA9665 at 0x%08lx",
index f585aead50cc32eb045010406ab8e7e7e0b61d97..eec20db6246fac995f3bde2ae1e45177b37d4fe3 100644 (file)
@@ -104,13 +104,8 @@ static int i2c_versatile_probe(struct platform_device *dev)
        i2c->algo = i2c_versatile_algo;
        i2c->algo.data = i2c;
 
-       if (dev->id >= 0) {
-               /* static bus numbering */
-               i2c->adap.nr = dev->id;
-               ret = i2c_bit_add_numbered_bus(&i2c->adap);
-       } else
-               /* dynamic bus numbering */
-               ret = i2c_bit_add_bus(&i2c->adap);
+       i2c->adap.nr = dev->id;
+       ret = i2c_bit_add_numbered_bus(&i2c->adap);
        if (ret >= 0) {
                platform_set_drvdata(dev, i2c);
                of_i2c_register_devices(&i2c->adap);