usbhs_pkt_push() had inconsistent return under spin lock.
This patch fix it up.
Special thanks to Dan
Cc: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
        struct device *dev = usbhs_priv_to_dev(priv);
        unsigned long flags;
 
-       /********************  spin lock ********************/
-       usbhs_lock(priv, flags);
-
        if (!done) {
                dev_err(dev, "no done function\n");
                return;
        }
 
+       /********************  spin lock ********************/
+       usbhs_lock(priv, flags);
+
        if (!pipe->handler) {
                dev_err(dev, "no handler function\n");
                pipe->handler = &usbhsf_null_handler;