diff --git a/drivers/i2c/i2c-core.c b/drivers/i2c/i2c-core.c
index 93fc5bfdb9b421f7716e5116447d469c6f132a6f..48e31ed69dbf159f5e44f2ab2a4968896320c3eb 100644
--- a/drivers/i2c/i2c-core.c
+++ b/drivers/i2c/i2c-core.c
@@ -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);