i2c: add debug info when class instantiation was dropped
authorWolfram Sang <wsa@the-dreams.de>
Thu, 10 Jul 2014 11:46:21 +0000 (13:46 +0200)
committerWolfram Sang <wsa@the-dreams.de>
Wed, 16 Jul 2014 20:59:55 +0000 (22:59 +0200)
We have a warning already when support for old-fashioned class based
instantiation is about to be dropped somewhen soon from a driver. Let's
have another one when it was actually dropped. This allows to remove the
cruft a little earlier and still let users know what happened in the
rare case they are missing devices after the change. However, there is
enough interest to get rid of class based instantiation rather sooner
than later because it improves boot up time.

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

index 4ccff114b147af9e8add34c040a24732732cd1e8..a1eeb8a5d3f8615aa46a3935b335f56033ba933d 100644 (file)
@@ -1915,6 +1915,16 @@ static int i2c_detect(struct i2c_adapter *adapter, struct i2c_driver *driver)
        if (!driver->detect || !address_list)
                return 0;
 
+       /* Warn that the adapter lost class based instantiation */
+       if (adapter->class == I2C_CLASS_DEPRECATED) {
+               dev_dbg(&adapter->dev,
+                       "This adapter dropped support for I2C classes and "
+                       "won't auto-detect %s devices anymore. If you need it, check "
+                       "'Documentation/i2c/instantiating-devices' for alternatives.\n",
+                       driver->driver.name);
+               return 0;
+       }
+
        /* Stop here if the classes do not match */
        if (!(adapter->class & driver->class))
                return 0;