fbdev: Make fb-notify a no-op if CONFIG_FB=n
authorEzequiel Garcia <ezequiel@vanguardiasur.com.ar>
Wed, 25 Nov 2015 03:11:48 +0000 (00:11 -0300)
committerTomi Valkeinen <tomi.valkeinen@ti.com>
Tue, 15 Dec 2015 13:41:24 +0000 (15:41 +0200)
There's no point in having support for framebuffer notifications
is CONFIG_FB is disabled. This commit adds the necessary stubs
for code to link properly when CONFIG_FB=n and moves fb-notify.o
to be built only when CONFIG_FB=y.

Signed-off-by: Ezequiel Garcia <ezequiel@vanguardiasur.com.ar>
Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
drivers/video/fbdev/Kconfig
drivers/video/fbdev/core/Makefile
include/linux/fb.h

index 1727a964aea5e76897f6efba18eac2f47948cb5d..d43f27682d028b9a64563159e68b5d8135edc7d3 100644 (file)
@@ -5,6 +5,7 @@
 menuconfig FB
        tristate "Support for frame buffer devices"
        select FB_CMDLINE
+       select FB_NOTIFY
        ---help---
          The frame buffer device provides an abstraction for the graphics
          hardware. It represents the frame buffer of some video hardware and
@@ -56,6 +57,9 @@ config FIRMWARE_EDID
 config FB_CMDLINE
        bool
 
+config FB_NOTIFY
+       bool
+
 config FB_DDC
        tristate
        depends on FB
index 23d86a8b7d7b3d0264da4a6c7fdb05cea28768fa..9e3ddf225393e697ce0993814eb37f1dbe6f087a 100644 (file)
@@ -1,5 +1,5 @@
-obj-y                             += fb_notify.o
 obj-$(CONFIG_FB_CMDLINE)          += fb_cmdline.o
+obj-$(CONFIG_FB_NOTIFY)           += fb_notify.o
 obj-$(CONFIG_FB)                  += fb.o
 fb-y                              := fbmem.o fbmon.o fbcmap.o fbsysfs.o \
                                      modedb.o fbcvt.o
index 3d003805aac32ab1880c432cf556da8c5c29e14c..55433f86f0a323930d237733507a284be83607aa 100644 (file)
@@ -175,9 +175,27 @@ struct fb_blit_caps {
        u32 flags;
 };
 
+#ifdef CONFIG_FB_NOTIFY
 extern int fb_register_client(struct notifier_block *nb);
 extern int fb_unregister_client(struct notifier_block *nb);
 extern int fb_notifier_call_chain(unsigned long val, void *v);
+#else
+static inline int fb_register_client(struct notifier_block *nb)
+{
+       return 0;
+};
+
+static inline int fb_unregister_client(struct notifier_block *nb)
+{
+       return 0;
+};
+
+static inline int fb_notifier_call_chain(unsigned long val, void *v)
+{
+       return 0;
+};
+#endif
+
 /*
  * Pixmap structure definition
  *