Skip to content

Commit db8d3a2

Browse files
MichaelZaidmanJiri Kosina
authored andcommitted
HID: ft260: fix device removal due to USB disconnect
This commit fixes a functional regression introduced by the commit 82f09a6 ("HID: ft260: improve error handling of ft260_hid_feature_report_get()") when upon USB disconnect, the FTDI FT260 i2c device is still available within the /dev folder. In my company's product, where the host USB to FT260 USB connection is hard-wired in the PCB, the issue is not reproducible. To reproduce it, I used the VirtualBox Ubuntu 20.04 VM and the UMFT260EV1A development module for the FTDI FT260 chip: Plug the UMFT260EV1A module into a USB port and attach it to VM. The VM shows 2 i2c devices under the /dev: michael@michael-VirtualBox:~$ ls /dev/i2c-* /dev/i2c-0 /dev/i2c-1 The i2c-0 is not related to the FTDI FT260: michael@michael-VirtualBox:~$ cat /sys/bus/i2c/devices/i2c-0/name SMBus PIIX4 adapter at 4100 The i2c-1 is created by hid-ft260.ko: michael@michael-VirtualBox:~$ cat /sys/bus/i2c/devices/i2c-1/name FT260 usb-i2c bridge on hidraw1 Now, detach the FTDI FT260 USB device from VM. We expect the /dev/i2c-1 to disappear, but it's still here: michael@michael-VirtualBox:~$ ls /dev/i2c-* /dev/i2c-0 /dev/i2c-1 And the kernel log shows: [ +0.001202] usb 2-2: USB disconnect, device number 3 [ +0.000109] ft260 0003:0403:6030.0002: failed to retrieve system status [ +0.000316] ft260 0003:0403:6030.0003: failed to retrieve system status It happens because the commit 82f09a6 changed the ft260_get_system_config() return logic. This caused the ft260_is_interface_enabled() to exit with error upon the FT260 device USB disconnect, which in turn, aborted the ft260_remove() before deleting the FT260 i2c device and cleaning its sysfs stuff. This commit restores the FT260 USB removal functionality and improves the ft260_is_interface_enabled() code to handle correctly all chip modes defined by the device interface configuration pins DCNF0 and DCNF1. Signed-off-by: Michael Zaidman <[email protected]> Acked-by: Aaron Jones (FTDI-UK) <[email protected]> Signed-off-by: Jiri Kosina <[email protected]>
1 parent 7cc8524 commit db8d3a2

File tree

1 file changed

+7
-16
lines changed

1 file changed

+7
-16
lines changed

drivers/hid/hid-ft260.c

Lines changed: 7 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -742,7 +742,7 @@ static int ft260_is_interface_enabled(struct hid_device *hdev)
742742
int ret;
743743

744744
ret = ft260_get_system_config(hdev, &cfg);
745-
if (ret)
745+
if (ret < 0)
746746
return ret;
747747

748748
ft260_dbg("interface: 0x%02x\n", interface);
@@ -754,23 +754,16 @@ static int ft260_is_interface_enabled(struct hid_device *hdev)
754754
switch (cfg.chip_mode) {
755755
case FT260_MODE_ALL:
756756
case FT260_MODE_BOTH:
757-
if (interface == 1) {
757+
if (interface == 1)
758758
hid_info(hdev, "uart interface is not supported\n");
759-
return 0;
760-
}
761-
ret = 1;
759+
else
760+
ret = 1;
762761
break;
763762
case FT260_MODE_UART:
764-
if (interface == 0) {
765-
hid_info(hdev, "uart is unsupported on interface 0\n");
766-
ret = 0;
767-
}
763+
hid_info(hdev, "uart interface is not supported\n");
768764
break;
769765
case FT260_MODE_I2C:
770-
if (interface == 1) {
771-
hid_info(hdev, "i2c is unsupported on interface 1\n");
772-
ret = 0;
773-
}
766+
ret = 1;
774767
break;
775768
}
776769
return ret;
@@ -1004,11 +997,9 @@ static int ft260_probe(struct hid_device *hdev, const struct hid_device_id *id)
1004997

1005998
static void ft260_remove(struct hid_device *hdev)
1006999
{
1007-
int ret;
10081000
struct ft260_device *dev = hid_get_drvdata(hdev);
10091001

1010-
ret = ft260_is_interface_enabled(hdev);
1011-
if (ret <= 0)
1002+
if (!dev)
10121003
return;
10131004

10141005
sysfs_remove_group(&hdev->dev.kobj, &ft260_attr_group);

0 commit comments

Comments
 (0)