[media] v4l2-device: Don't unregister ACPI/Device Tree based devices
authorTommi Franttila <tommi.franttila@intel.com>
Thu, 12 Nov 2015 09:01:07 +0000 (07:01 -0200)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Tue, 17 Nov 2015 17:04:12 +0000 (15:04 -0200)
When a V4L2 sub-device backed by a DT or ACPI based device was removed,
the device was unregistered as well which certainly was not intentional,
as the client device would not be re-created by simply reinstating the
V4L2 sub-device (indeed the device would have to be there first!).

Skip unregistering the device in case it has non-NULL of_node or fwnode.

Signed-off-by: Tommi Franttila <tommi.franttila@intel.com>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/v4l2-core/v4l2-device.c

index 5b0a30b9252be2a205fcef2feecaf6fd1f3e57f6..7129e438f29e776fa7ff2a72a0ee4873ababdc94 100644 (file)
@@ -118,11 +118,20 @@ void v4l2_device_unregister(struct v4l2_device *v4l2_dev)
                if (sd->flags & V4L2_SUBDEV_FL_IS_I2C) {
                        struct i2c_client *client = v4l2_get_subdevdata(sd);
 
-                       /* We need to unregister the i2c client explicitly.
-                          We cannot rely on i2c_del_adapter to always
-                          unregister clients for us, since if the i2c bus
-                          is a platform bus, then it is never deleted. */
-                       if (client)
+                       /*
+                        * We need to unregister the i2c client
+                        * explicitly. We cannot rely on
+                        * i2c_del_adapter to always unregister
+                        * clients for us, since if the i2c bus is a
+                        * platform bus, then it is never deleted.
+                        *
+                        * Device tree or ACPI based devices must not
+                        * be unregistered as they have not been
+                        * registered by us, and would not be
+                        * re-created by just probing the V4L2 driver.
+                        */
+                       if (client &&
+                           !client->dev.of_node && !client->dev.fwnode)
                                i2c_unregister_device(client);
                        continue;
                }
@@ -131,7 +140,7 @@ void v4l2_device_unregister(struct v4l2_device *v4l2_dev)
                if (sd->flags & V4L2_SUBDEV_FL_IS_SPI) {
                        struct spi_device *spi = v4l2_get_subdevdata(sd);
 
-                       if (spi)
+                       if (spi && !spi->dev.of_node && !spi->dev.fwnode)
                                spi_unregister_device(spi);
                        continue;
                }