Revert "i2c: core: make it possible to match a pure device tree driver"
authorWolfram Sang <wsa@the-dreams.de>
Tue, 18 Jun 2013 16:02:45 +0000 (18:02 +0200)
committerWolfram Sang <wsa@the-dreams.de>
Tue, 18 Jun 2013 16:02:45 +0000 (18:02 +0200)
This reverts commit c80f52847c50109ca248c22efbf71ff10553dca4.
Regressions have been found and also run time based instantiation would
fail. We need more thoughts on this.

Signed-off-by: Wolfram Sang <wsa@the-dreams.de>
drivers/i2c/i2c-core.c

index 93fc5bfdb9b421f7716e5116447d469c6f132a6f..48e31ed69dbf159f5e44f2ab2a4968896320c3eb 100644 (file)
@@ -240,7 +240,7 @@ static int i2c_device_probe(struct device *dev)
                return 0;
 
        driver = to_i2c_driver(dev->driver);
-       if (!driver->probe || (!driver->id_table && !dev->driver->of_match_table))
+       if (!driver->probe || !driver->id_table)
                return -ENODEV;
        client->driver = driver;
        if (!device_can_wakeup(&client->dev))
@@ -248,12 +248,7 @@ static int i2c_device_probe(struct device *dev)
                                        client->flags & I2C_CLIENT_WAKE);
        dev_dbg(dev, "probe\n");
 
-       if (of_match_device(dev->driver->of_match_table, dev))
-               /* Device tree matching */
-               status = driver->probe(client, NULL);
-       else
-               /* Fall back to matching the id_table */
-               status = driver->probe(client, i2c_match_id(driver->id_table, client));
+       status = driver->probe(client, i2c_match_id(driver->id_table, client));
        if (status) {
                client->driver = NULL;
                i2c_set_clientdata(client, NULL);