greybus: usb: Create separate module
authorViresh Kumar <viresh.kumar@linaro.org>
Mon, 9 May 2016 12:45:12 +0000 (18:15 +0530)
committerGreg Kroah-Hartman <gregkh@google.com>
Sat, 14 May 2016 17:13:57 +0000 (19:13 +0200)
Create separate module for usb gpbridge driver.

Tested on EVT 1.5 by inserting GP test module, all the devices were
enumerated correctly.

Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
drivers/staging/greybus/Makefile
drivers/staging/greybus/gpbridge.c
drivers/staging/greybus/gpbridge.h
drivers/staging/greybus/usb.c

index e99a9a83dd8e034e8975b19c17ee8b283c205477..592525ce7e8b70cb3f078e241b334e2640fe1519 100644 (file)
@@ -14,8 +14,7 @@ greybus-y :=  core.o          \
                operation.o     \
                legacy.o
 
-gb-phy-y :=    gpbridge.o      \
-               usb.o
+gb-phy-y :=    gpbridge.o
 
 # Prefix all modules with gb-
 gb-vibrator-y := vibrator.o
@@ -40,6 +39,7 @@ gb-uart-y := uart.o
 gb-pwm-y := pwm.o
 gb-gpio-y := gpio.o
 gb-i2c-y := i2c.o
+gb-usb-y := usb.o
 
 obj-m += greybus.o
 obj-m += gb-phy.o
@@ -68,6 +68,7 @@ obj-m += gb-uart.o
 obj-m += gb-pwm.o
 obj-m += gb-gpio.o
 obj-m += gb-i2c.o
+obj-m += gb-usb.o
 
 KERNELVER              ?= $(shell uname -r)
 KERNELDIR              ?= /lib/modules/$(KERNELVER)/build
index 5a65564dc34cbc5c31159c41680b33cbd8e53880..67f18ac9fe370e8a3d838af6e74990b95f90da37 100644 (file)
@@ -317,15 +317,8 @@ static int __init gpbridge_init(void)
                goto error_gpbridge;
        }
 
-       if (gb_usb_driver_init()) {
-               pr_err("error initializing usb driver\n");
-               goto error_usb;
-       }
-
        return 0;
 
-error_usb:
-       greybus_deregister(&gb_gpbridge_driver);
 error_gpbridge:
        bus_unregister(&gpbridge_bus_type);
        ida_destroy(&gpbridge_id);
@@ -335,8 +328,6 @@ module_init(gpbridge_init);
 
 static void __exit gpbridge_exit(void)
 {
-       gb_usb_driver_exit();
-
        greybus_deregister(&gb_gpbridge_driver);
        bus_unregister(&gpbridge_bus_type);
        ida_destroy(&gpbridge_id);
index 532dd5682f02954ed8b6fb3f3663810d8c6608aa..d4339e62d8a487c13a1664356c3ccbd3a6d858dd 100644 (file)
@@ -66,9 +66,6 @@ void gb_##__driver##_exit(void)                               \
        gb_gpbridge_deregister(&__driver);                      \
 }
 
-extern int gb_usb_driver_init(void);
-extern void gb_usb_driver_exit(void);
-
 /**
  * module_gpbridge_driver() - Helper macro for registering a gpbridge driver
  * @__gpbridge_driver: gpbridge_driver structure
index 2b4789bde0c2a0ebe424d574656202ffcdee8cd2..2f68a1b49e3c5a49db5e201368fcaeae021a8517 100644 (file)
@@ -242,6 +242,7 @@ static const struct gpbridge_device_id gb_usb_id_table[] = {
        { GPBRIDGE_PROTOCOL(GREYBUS_PROTOCOL_USB) },
        { },
 };
+MODULE_DEVICE_TABLE(gpbridge, gb_usb_id_table);
 
 static struct gpbridge_driver usb_driver = {
        .name           = "usb",
@@ -249,4 +250,6 @@ static struct gpbridge_driver usb_driver = {
        .remove         = gb_usb_remove,
        .id_table       = gb_usb_id_table,
 };
-gb_gpbridge_builtin_driver(usb_driver);
+
+module_gpbridge_driver(usb_driver);
+MODULE_LICENSE("GPL v2");