Skip to content

Commit bc170f9

Browse files
committed
Merge branch 'r8152-improve-the-code'
Hayes Wang says: ==================== r8152: improve the code These are some minor improvements depending on commit ec51fbd ("r8152: add USB device driver for config selection"). ==================== Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Jakub Kicinski <[email protected]>
2 parents b3c588c + 0276744 commit bc170f9

File tree

1 file changed

+5
-41
lines changed

1 file changed

+5
-41
lines changed

drivers/net/usb/r8152.c

Lines changed: 5 additions & 41 deletions
Original file line numberDiff line numberDiff line change
@@ -8232,43 +8232,6 @@ static bool rtl_check_vendor_ok(struct usb_interface *intf)
82328232
return true;
82338233
}
82348234

8235-
static bool rtl_vendor_mode(struct usb_interface *intf)
8236-
{
8237-
struct usb_host_interface *alt = intf->cur_altsetting;
8238-
struct usb_device *udev;
8239-
struct usb_host_config *c;
8240-
int i, num_configs;
8241-
8242-
if (alt->desc.bInterfaceClass == USB_CLASS_VENDOR_SPEC)
8243-
return rtl_check_vendor_ok(intf);
8244-
8245-
/* The vendor mode is not always config #1, so to find it out. */
8246-
udev = interface_to_usbdev(intf);
8247-
c = udev->config;
8248-
num_configs = udev->descriptor.bNumConfigurations;
8249-
if (num_configs < 2)
8250-
return false;
8251-
8252-
for (i = 0; i < num_configs; (i++, c++)) {
8253-
struct usb_interface_descriptor *desc = NULL;
8254-
8255-
if (c->desc.bNumInterfaces > 0)
8256-
desc = &c->intf_cache[0]->altsetting->desc;
8257-
else
8258-
continue;
8259-
8260-
if (desc->bInterfaceClass == USB_CLASS_VENDOR_SPEC) {
8261-
usb_driver_set_configuration(udev, c->desc.bConfigurationValue);
8262-
break;
8263-
}
8264-
}
8265-
8266-
if (i == num_configs)
8267-
dev_err(&intf->dev, "Unexpected Device\n");
8268-
8269-
return false;
8270-
}
8271-
82728235
static int rtl8152_pre_reset(struct usb_interface *intf)
82738236
{
82748237
struct r8152 *tp = usb_get_intfdata(intf);
@@ -9618,18 +9581,19 @@ static int rtl8152_probe(struct usb_interface *intf,
96189581
const struct usb_device_id *id)
96199582
{
96209583
struct usb_device *udev = interface_to_usbdev(intf);
9621-
u8 version = rtl8152_get_version(intf);
96229584
struct r8152 *tp;
96239585
struct net_device *netdev;
9586+
u8 version;
96249587
int ret;
96259588

9626-
if (version == RTL_VER_UNKNOWN)
9589+
if (intf->cur_altsetting->desc.bInterfaceClass != USB_CLASS_VENDOR_SPEC)
96279590
return -ENODEV;
96289591

9629-
if (intf->cur_altsetting->desc.bInterfaceClass != USB_CLASS_VENDOR_SPEC)
9592+
if (!rtl_check_vendor_ok(intf))
96309593
return -ENODEV;
96319594

9632-
if (!rtl_vendor_mode(intf))
9595+
version = rtl8152_get_version(intf);
9596+
if (version == RTL_VER_UNKNOWN)
96339597
return -ENODEV;
96349598

96359599
usb_reset_device(udev);

0 commit comments

Comments
 (0)