Commit 4d50f4fc authored by Johan Hovold's avatar Johan Hovold

USB: serial: ftdi_sio: assume hi-speed type

In preparation for adding further Hi-Speed types, assume a 120 MHz clock
and set the channel index by default and instead override these values
as needed for legacy types.
Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
parent a146cc4d
...@@ -1551,13 +1551,15 @@ static int ftdi_determine_type(struct usb_serial_port *port) ...@@ -1551,13 +1551,15 @@ static int ftdi_determine_type(struct usb_serial_port *port)
version = le16_to_cpu(udev->descriptor.bcdDevice); version = le16_to_cpu(udev->descriptor.bcdDevice);
ifnum = serial->interface->cur_altsetting->desc.bInterfaceNumber; ifnum = serial->interface->cur_altsetting->desc.bInterfaceNumber;
priv->baud_base = 48000000 / 2; /* Assume Hi-Speed type */
priv->channel = 0; priv->baud_base = 120000000 / 2;
priv->channel = CHANNEL_A + ifnum;
switch (version) { switch (version) {
case 0x200: case 0x200:
priv->chip_type = FT232A; priv->chip_type = FT232A;
priv->baud_base = 48000000 / 2;
priv->channel = 0;
/* /*
* FT232B devices have a bug where bcdDevice gets set to 0x200 * FT232B devices have a bug where bcdDevice gets set to 0x200
* when iSerialNumber is 0. Assume it is an FT232B in case the * when iSerialNumber is 0. Assume it is an FT232B in case the
...@@ -1570,37 +1572,36 @@ static int ftdi_determine_type(struct usb_serial_port *port) ...@@ -1570,37 +1572,36 @@ static int ftdi_determine_type(struct usb_serial_port *port)
break; break;
case 0x400: case 0x400:
priv->chip_type = FT232B; priv->chip_type = FT232B;
priv->baud_base = 48000000 / 2;
priv->channel = 0;
break; break;
case 0x500: case 0x500:
priv->chip_type = FT2232C; priv->chip_type = FT2232C;
priv->channel = CHANNEL_A + ifnum; priv->baud_base = 48000000 / 2;
break; break;
case 0x600: case 0x600:
priv->chip_type = FT232R; priv->chip_type = FT232R;
priv->baud_base = 48000000 / 2;
priv->channel = 0;
break; break;
case 0x700: case 0x700:
priv->chip_type = FT2232H; priv->chip_type = FT2232H;
priv->channel = CHANNEL_A + ifnum;
priv->baud_base = 120000000 / 2;
break; break;
case 0x800: case 0x800:
priv->chip_type = FT4232H; priv->chip_type = FT4232H;
priv->channel = CHANNEL_A + ifnum;
priv->baud_base = 120000000 / 2;
break; break;
case 0x900: case 0x900:
priv->chip_type = FT232H; priv->chip_type = FT232H;
priv->channel = CHANNEL_A + ifnum;
priv->baud_base = 120000000 / 2;
break; break;
case 0x1000: case 0x1000:
priv->chip_type = FTX; priv->chip_type = FTX;
priv->channel = CHANNEL_A + ifnum; priv->baud_base = 48000000 / 2;
break; break;
default: default:
if (version < 0x200) { if (version < 0x200) {
priv->chip_type = SIO; priv->chip_type = SIO;
priv->baud_base = 12000000 / 16; priv->baud_base = 12000000 / 16;
priv->channel = 0;
} else { } else {
dev_err(&port->dev, "unknown device type: 0x%02x\n", version); dev_err(&port->dev, "unknown device type: 0x%02x\n", version);
return -ENODEV; return -ENODEV;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment