ida_alloc_range() may return other than -ENOMEM error code.
Unshadow it in the wwan_create_port().
Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Reviewed-by: Sergey Ryazanov <ryazanov.s.a@gmail.com>
Reviewed-by: Loic Poulain <loic.poulain@linaro.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
 {
        struct wwan_device *wwandev;
        struct wwan_port *port;
-       int minor, err = -ENOMEM;
        char namefmt[0x20];
+       int minor, err;
 
        if (type > WWAN_PORT_MAX || !ops)
                return ERR_PTR(-EINVAL);
 
        /* A port is exposed as character device, get a minor */
        minor = ida_alloc_range(&minors, 0, WWAN_MAX_MINORS - 1, GFP_KERNEL);
-       if (minor < 0)
+       if (minor < 0) {
+               err = minor;
                goto error_wwandev_remove;
+       }
 
        port = kzalloc(sizeof(*port), GFP_KERNEL);
        if (!port) {
+               err = -ENOMEM;
                ida_free(&minors, minor);
                goto error_wwandev_remove;
        }