usb: fix improper return value when kzalloc fails
authorPan Bian <bianpan2016@163.com>
Tue, 29 Nov 2016 12:56:10 +0000 (20:56 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 29 Nov 2016 16:36:43 +0000 (17:36 +0100)
The comment says function wa_nep_queue() should return 0 if ok, and <0
errno code on error. However, its implementation always returns 0, even
if the call to kzalloc() fails. As a result, the return value may be
inconsistent with the execution status, which may mislead the callers.
This patch fixes the bug, returning -ENOMEM when the call to kzalloc()
fails.

Signed-off-by: Pan Bian <bianpan2016@163.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/wusbcore/wa-nep.c

index ed4622279c63c0bb4abc76e90fba8cca4493e537..e3819fc182b0b76169dc2b9396261c0604f47ada 100644 (file)
@@ -198,6 +198,7 @@ static int wa_nep_queue(struct wahc *wa, size_t size)
        if (nw == NULL) {
                if (printk_ratelimit())
                        dev_err(dev, "No memory to queue notification\n");
+               result = -ENOMEM;
                goto out;
        }
        INIT_WORK(&nw->work, wa_notif_dispatch);