Skip to content

Commit 3295f1b

Browse files
alexhenriegregkh
authored andcommitted
usb: misc: uss720: check for incompatible versions of the Belkin F5U002
The incompatible device in my possession has a sticker that says "F5U002 Rev 2" and "P80453-B", and lsusb identifies it as "050d:0002 Belkin Components IEEE-1284 Controller". There is a bug report from 2007 from Michael Trausch who was seeing the exact same errors that I saw in 2024 trying to use this cable. Link: https://lore.kernel.org/all/46DE5830.9060401@trausch.us/ Signed-off-by: Alex Henrie <alexhenrie24@gmail.com> Link: https://lore.kernel.org/r/20240326150723.99939-5-alexhenrie24@gmail.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent d24f059 commit 3295f1b

File tree

1 file changed

+13
-7
lines changed

1 file changed

+13
-7
lines changed

drivers/usb/misc/uss720.c

Lines changed: 13 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -677,7 +677,7 @@ static int uss720_probe(struct usb_interface *intf,
677677
struct parport_uss720_private *priv;
678678
struct parport *pp;
679679
unsigned char reg;
680-
int i;
680+
int ret;
681681

682682
dev_dbg(&intf->dev, "probe: vendor id 0x%x, device id 0x%x\n",
683683
le16_to_cpu(usbdev->descriptor.idVendor),
@@ -688,8 +688,8 @@ static int uss720_probe(struct usb_interface *intf,
688688
usb_put_dev(usbdev);
689689
return -ENODEV;
690690
}
691-
i = usb_set_interface(usbdev, intf->altsetting->desc.bInterfaceNumber, 2);
692-
dev_dbg(&intf->dev, "set interface result %d\n", i);
691+
ret = usb_set_interface(usbdev, intf->altsetting->desc.bInterfaceNumber, 2);
692+
dev_dbg(&intf->dev, "set interface result %d\n", ret);
693693

694694
interface = intf->cur_altsetting;
695695

@@ -728,12 +728,18 @@ static int uss720_probe(struct usb_interface *intf,
728728
set_1284_register(pp, 7, 0x00, GFP_KERNEL);
729729
set_1284_register(pp, 6, 0x30, GFP_KERNEL); /* PS/2 mode */
730730
set_1284_register(pp, 2, 0x0c, GFP_KERNEL);
731-
/* debugging */
732-
get_1284_register(pp, 0, &reg, GFP_KERNEL);
731+
732+
/* The Belkin F5U002 Rev 2 P80453-B USB parallel port adapter shares the
733+
* device ID 050d:0002 with some other device that works with this
734+
* driver, but it itself does not. Detect and handle the bad cable
735+
* here. */
736+
ret = get_1284_register(pp, 0, &reg, GFP_KERNEL);
733737
dev_dbg(&intf->dev, "reg: %7ph\n", priv->reg);
738+
if (ret < 0)
739+
return ret;
734740

735-
i = usb_find_last_int_in_endpoint(interface, &epd);
736-
if (!i) {
741+
ret = usb_find_last_int_in_endpoint(interface, &epd);
742+
if (!ret) {
737743
dev_dbg(&intf->dev, "epaddr %d interval %d\n",
738744
epd->bEndpointAddress, epd->bInterval);
739745
}

0 commit comments

Comments
 (0)