usb: gadget: f_tcm: remove compatibility layer
authorAndrzej Pietrasiewicz <andrzej.p@samsung.com>
Fri, 11 Dec 2015 15:06:23 +0000 (16:06 +0100)
committerNicholas Bellinger <nab@linux-iscsi.org>
Mon, 21 Dec 2015 03:40:39 +0000 (19:40 -0800)
There are no old function interface users left.

Signed-off-by: Andrzej Pietrasiewicz <andrzej.p@samsung.com>
Acked-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
drivers/usb/gadget/function/f_tcm.c

index 3b1ba893ecfc20655959f6905f747479ea9cf673..33afe6ac0b6275f12ba47efb69675d3246da747a 100644 (file)
@@ -24,8 +24,6 @@
 #include "tcm.h"
 #include "u_tcm.h"
 
-#ifndef USBF_TCM_INCLUDED
-
 #define TPG_INSTANCES          1
 
 struct tpg_instance {
@@ -36,7 +34,6 @@ struct tpg_instance {
 static struct tpg_instance tpg_instances[TPG_INSTANCES];
 
 static DEFINE_MUTEX(tpg_instances_lock);
-#endif
 
 static inline struct f_uas *to_f_uas(struct usb_function *f)
 {
@@ -1386,10 +1383,8 @@ static struct se_portal_group *usbg_make_tpg(
        struct usbg_tpg *tpg;
        unsigned long tpgt;
        int ret;
-#ifndef USBF_TCM_INCLUDED
        struct f_tcm_opts *opts;
        unsigned i;
-#endif
 
        if (strstr(name, "tpgt_") != name)
                return ERR_PTR(-EINVAL);
@@ -1400,7 +1395,6 @@ static struct se_portal_group *usbg_make_tpg(
                pr_err("gadgets, you can't do this here.\n");
                return ERR_PTR(-EBUSY);
        }
-#ifndef USBF_TCM_INCLUDED
        ret = -ENODEV;
        mutex_lock(&tpg_instances_lock);
        for (i = 0; i < TPG_INSTANCES; ++i)
@@ -1417,26 +1411,16 @@ static struct se_portal_group *usbg_make_tpg(
 
        if (opts->has_dep && !try_module_get(opts->dependent))
                goto unlock_dep;
-#endif
 
        tpg = kzalloc(sizeof(struct usbg_tpg), GFP_KERNEL);
        ret = -ENOMEM;
        if (!tpg)
-#ifdef USBF_TCM_INCLUDED
-               return ERR_PTR(-ENOMEM);
-#else
                goto unref_dep;
-#endif
        mutex_init(&tpg->tpg_mutex);
        atomic_set(&tpg->tpg_port_count, 0);
        tpg->workqueue = alloc_workqueue("tcm_usb_gadget", 0, 1);
-       if (!tpg->workqueue) {
-#ifndef USBF_TCM_INCLUDED
+       if (!tpg->workqueue)
                goto free_tpg;
-#endif
-               kfree(tpg);
-               return NULL;
-       }
 
        tpg->tport = tport;
        tpg->tport_tpgt = tpgt;
@@ -1446,23 +1430,16 @@ static struct se_portal_group *usbg_make_tpg(
         * pretend to be SAS..
         */
        ret = core_tpg_register(wwn, &tpg->se_tpg, SCSI_PROTOCOL_SAS);
-       if (ret < 0) {
-#ifndef USBF_TCM_INCLUDED
+       if (ret < 0)
                goto free_workqueue;
-#endif
-               destroy_workqueue(tpg->workqueue);
-               kfree(tpg);
-               return NULL;
-       }
-#ifndef USBF_TCM_INCLUDED
+
        tpg_instances[i].tpg = tpg;
        tpg->fi = tpg_instances[i].func_inst;
        mutex_unlock(&opts->dep_lock);
        mutex_unlock(&tpg_instances_lock);
-#endif
        the_only_tpg_I_currently_have = tpg;
        return &tpg->se_tpg;
-#ifndef USBF_TCM_INCLUDED
+
 free_workqueue:
        destroy_workqueue(tpg->workqueue);
 free_tpg:
@@ -1475,7 +1452,6 @@ unlock_inst:
        mutex_unlock(&tpg_instances_lock);
 
        return ERR_PTR(ret);
-#endif
 }
 
 static int tcm_usbg_drop_nexus(struct usbg_tpg *);
@@ -1484,16 +1460,13 @@ static void usbg_drop_tpg(struct se_portal_group *se_tpg)
 {
        struct usbg_tpg *tpg = container_of(se_tpg,
                                struct usbg_tpg, se_tpg);
-#ifndef USBF_TCM_INCLUDED
        unsigned i;
        struct f_tcm_opts *opts;
-#endif
 
        tcm_usbg_drop_nexus(tpg);
        core_tpg_deregister(se_tpg);
        destroy_workqueue(tpg->workqueue);
 
-#ifndef USBF_TCM_INCLUDED
        mutex_lock(&tpg_instances_lock);
        for (i = 0; i < TPG_INSTANCES; ++i)
                if (tpg_instances[i].tpg == tpg)
@@ -1506,7 +1479,7 @@ static void usbg_drop_tpg(struct se_portal_group *se_tpg)
        module_put(opts->dependent);
        mutex_unlock(&opts->dep_lock);
        mutex_unlock(&tpg_instances_lock);
-#endif
+
        kfree(tpg);
        the_only_tpg_I_currently_have = NULL;
 }
@@ -2066,13 +2039,10 @@ static int tcm_bind(struct usb_configuration *c, struct usb_function *f)
        struct f_uas            *fu = to_f_uas(f);
        struct usb_gadget       *gadget = c->cdev->gadget;
        struct usb_ep           *ep;
-#ifndef USBF_TCM_INCLUDED
        struct f_tcm_opts       *opts;
-#endif
        int                     iface;
        int                     ret;
 
-#ifndef USBF_TCM_INCLUDED
        opts = container_of(f->fi, struct f_tcm_opts, func_inst);
 
        mutex_lock(&opts->dep_lock);
@@ -2081,7 +2051,7 @@ static int tcm_bind(struct usb_configuration *c, struct usb_function *f)
                return -ENODEV;
        }
        mutex_unlock(&opts->dep_lock);
-#endif
+
        if (tcm_us_strings[0].id == 0) {
                ret = usb_string_ids_tab(c->cdev, tcm_us_strings);
                if (ret < 0)
@@ -2149,18 +2119,6 @@ ep_fail:
        return -ENOTSUPP;
 }
 
-#ifdef USBF_TCM_INCLUDED
-
-static void tcm_old_unbind(struct usb_configuration *c, struct usb_function *f)
-{
-       struct f_uas *fu = to_f_uas(f);
-
-       usb_free_all_descriptors(f);
-       kfree(fu);
-}
-
-#endif
-
 struct guas_setup_wq {
        struct work_struct work;
        struct f_uas *fu;
@@ -2229,37 +2187,6 @@ static int tcm_setup(struct usb_function *f,
        return usbg_bot_setup(f, ctrl);
 }
 
-#ifdef USBF_TCM_INCLUDED
-
-static int tcm_bind_config(struct usb_configuration *c)
-{
-       struct f_uas *fu;
-       int ret;
-
-       fu = kzalloc(sizeof(*fu), GFP_KERNEL);
-       if (!fu)
-               return -ENOMEM;
-       fu->function.name = "Target Function";
-       fu->function.bind = tcm_bind;
-       fu->function.unbind = tcm_old_unbind;
-       fu->function.set_alt = tcm_set_alt;
-       fu->function.setup = tcm_setup;
-       fu->function.disable = tcm_disable;
-       fu->function.strings = tcm_strings;
-       fu->tpg = the_only_tpg_I_currently_have;
-
-       ret = usb_add_function(c, &fu->function);
-       if (ret)
-               goto err;
-
-       return 0;
-err:
-       kfree(fu);
-       return ret;
-}
-
-#else
-
 static void tcm_free_inst(struct usb_function_instance *f)
 {
        struct f_tcm_opts *opts;
@@ -2417,5 +2344,3 @@ module_exit(tcm_exit);
 
 MODULE_LICENSE("GPL");
 MODULE_AUTHOR("Sebastian Andrzej Siewior");
-
-#endif