[media] use a function for DVB media controller register
authorMauro Carvalho Chehab <mchehab@osg.samsung.com>
Mon, 2 Mar 2015 14:26:14 +0000 (11:26 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Mon, 2 Mar 2015 14:29:39 +0000 (11:29 -0300)
This is really a simple function, but using it avoids to have
if's inside the drivers.

Also, the kABI becomes a little more clearer.

This shouldn't generate any overhead, and the type check
will happen when compiling with MC DVB enabled.

So, let's do it.

Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/common/siano/smsdvb-main.c
drivers/media/dvb-core/dvbdev.h
drivers/media/usb/cx231xx/cx231xx-dvb.c
drivers/media/usb/dvb-usb-v2/dvb_usb_core.c
drivers/media/usb/dvb-usb/dvb-usb-dvb.c

index c739725ca7eedce3897466480136442d0374d169..367b8e77feb831a2372bfbd03126221413634ba3 100644 (file)
@@ -1104,9 +1104,7 @@ static int smsdvb_hotplug(struct smscore_device_t *coredev,
                pr_err("dvb_register_adapter() failed %d\n", rc);
                goto adapter_error;
        }
-#ifdef CONFIG_MEDIA_CONTROLLER_DVB
-       client->adapter.mdev = coredev->media_dev;
-#endif
+       dvb_register_media_controller(&client->adapter, coredev->media_dev);
 
        /* init dvb demux */
        client->demux.dmx.capabilities = DMX_TS_FILTERING;
index 556c9e9d1d4e738c3771499bb28aa2ec367b0189..12629b8ecb0cd7c322f806535e1ffa2274dcf95e 100644 (file)
@@ -125,8 +125,15 @@ extern void dvb_unregister_device (struct dvb_device *dvbdev);
 
 #ifdef CONFIG_MEDIA_CONTROLLER_DVB
 void dvb_create_media_graph(struct dvb_adapter *adap);
+static inline void dvb_register_media_controller(struct dvb_adapter *adap,
+                                                struct media_device *mdev)
+{
+       adap->mdev = mdev;
+}
+
 #else
 static inline void dvb_create_media_graph(struct dvb_adapter *adap) {}
+#define dvb_register_media_controller(a, b) {}
 #endif
 
 extern int dvb_generic_open (struct inode *inode, struct file *file);
index 8bf2baae387f29f5d426b761d8e193566c61aedc..ff39bf22442d51c4f694e460375f0e6687b6ad8a 100644 (file)
@@ -465,9 +465,7 @@ static int register_dvb(struct cx231xx_dvb *dvb,
                       dev->name, result);
                goto fail_adapter;
        }
-#ifdef CONFIG_MEDIA_CONTROLLER_DVB
-       dvb->adapter.mdev = dev->media_dev;
-#endif
+       dvb_register_media_controller(&dvb->adapter, dev->media_dev);
 
        /* Ensure all frontends negotiate bus access */
        dvb->frontend->ops.ts_bus_ctrl = cx231xx_dvb_bus_ctrl;
index 8bd08ba4f8692d08ee1826a98abf6525a6f7f85b..f5df9eaba04fb0843e40bb26555aec4eb8c0c641 100644 (file)
@@ -429,7 +429,7 @@ static void dvb_usbv2_media_device_register(struct dvb_usb_adapter *adap)
                return;
        }
 
-       adap->dvb_adap.mdev = mdev;
+       dvb_register_media_controller(&adap->dvb_adap, mdev);
 
        dev_info(&d->udev->dev, "media controller created\n");
 
index 980d976960d95e0359e9557e33379838660d6fc8..7b7b834777b7a877a67c7763cdd1cb08c41bec12 100644 (file)
@@ -122,7 +122,7 @@ static void dvb_usb_media_device_register(struct dvb_usb_adapter *adap)
                kfree(mdev);
                return;
        }
-       adap->dvb_adap.mdev = mdev;
+       dvb_register_media_controller(&adap->dvb_adap, mdev);
 
        dev_info(&d->udev->dev, "media controller created\n");
 #endif