Re: FTDI FT2232C issue

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Apr 3, 2013 at 12:16 PM, Yegor Yefremov
<yegorslists@xxxxxxxxxxxxxx> wrote:
> On Wed, Apr 3, 2013 at 9:12 AM, Yegor Yefremov
> <yegorslists@xxxxxxxxxxxxxx> wrote:
>> On Tue, Apr 2, 2013 at 4:36 PM, Alan Stern <stern@xxxxxxxxxxxxxxxxxxx> wrote:
>>> On Tue, 2 Apr 2013, Yegor Yefremov wrote:
>>>
>>>> On Tue, Apr 2, 2013 at 4:14 PM, Alan Stern <stern@xxxxxxxxxxxxxxxxxxx> wrote:
>>>> > On Tue, 2 Apr 2013, Yegor Yefremov wrote:
>>>> >
>>>> >> I'm making a burn-in test (see serialtest.py
>>>> >> http://pastebin.com/pz47gaar) for our devices, that have built-in FTDI
>>>> >> chips. If FT2232C is attached directly to the USB host controller
>>>> >> port, the tests run properly. If I connect the chip to a USB-hub some
>>>> >> of the tests show timeout errors (read() routine). On the newer host
>>>> >> with USB3.0 this issue occurs on all USB ports where I attach FT2232C.
>>>> >> I tried kernels 3.2, 3.5 and 3.8.
>>>> >>
>>>> >> The test procedure opens two ports, exchanges data and closes ports.
>>>> >> If I don't open/close ports I don't encounter this issue.
>>>> >>
>>>> >> The FT4232H has no problems whether I attach it to USB HC or via HUB.
>>>> >> Any idea how to workaround the problem?
>>>> >
>>>> > If you use a different type of hub, does the test work?
>>>>
>>>> So far I tested with 3 different hub chips SMSC, GL (USB2.0) and one
>>>> USB3.0 hub - no difference.
>>>
>>> In that case, try collecting two usbmon traces showing what happens
>>> during the test.  In one trace, connect the FT2232C directly to the
>>> computer port; in the other, go through the GL hub.  See
>>> Documentation/usb/usbmon.txt for instructions.
>>
>> Will do.
>
> The proper script with cycles support '-n'
> http://dl.dropbox.com/u/6486923/serialtest.py
> raw text HCD: http://dl.dropbox.com/u/6486923/ftdi_sniff_hcd.out
> tcpdump HCD: http://dl.dropbox.com/u/6486923/ftdi_sniff_hcd.pcap
>
> HCD sniffs show 2 cycles
>
> raw text HUB: http://dl.dropbox.com/u/6486923/ftdi_sniff_hub.out
> tcpdump HUB: http://dl.dropbox.com/u/6486923/ftdi_sniff_hub.pcap
>
> HUB sniffs have different number of cycles regarding when the test failed.
>
> Let me know if you need more info or sniffs.

I reworked my test script, so that I can tell timeout from wrong
string. I have two cases now. On my am335x based system I get timeout
with 3.2 kernel and errors like here
(http://www.newit.co.uk/forum/index.php?topic=313.0) for 3.8.

On x86 I get fully wrong string. For example, I send "test string" and
get something like that 57 D6 2E 17 A4 2E 5D AE 5A EB F6 on the other
port.

I've also update the sniffs. They contain 20 cycles each. Let's take
this sniff ftdi_sniff_hub.out

As far as I understand it, it is normal case, where the data was
received correctly:

f1172780 1591104533 S Bo:1:004:2 -115 11 = 74657374 20737472 696e67
f1172780 1591104593 C Bo:1:004:2 0 11 >
f1172400 1591105218 C Bi:1:004:3 0 8 = b1607465 73742073
f1172400 1591105223 S Bi:1:004:3 -115 512 <
f1172b00 1591105226 C Bi:1:004:1 0 2 = b100
f1172b00 1591105227 S Bi:1:004:1 -115 512 <
f1172400 1591106217 C Bi:1:004:3 0 7 = b1607472 696e67

Here everything will be received, but byte per byte:

f1172780 1591706391 S Bo:1:004:2 -115 11 = 74657374 20737472 696e67
f1172780 1591706487 C Bo:1:004:2 0 11 >
f1172400 1591707111 C Bi:1:004:3 0 2 = b160
f1172400 1591707115 S Bi:1:004:3 -115 512 <
f1172b00 1591707117 C Bi:1:004:1 0 2 = b100
f1172b00 1591707118 S Bi:1:004:1 -115 512 <
f1172400 1591708112 C Bi:1:004:3 0 3 = b16074
f1172400 1591708117 S Bi:1:004:3 -115 512 <
f1172b00 1591708120 C Bi:1:004:1 0 2 = b100
f1172b00 1591708121 S Bi:1:004:1 -115 512 <
f1172400 1591709112 C Bi:1:004:3 0 3 = b16065
f1172400 1591709116 S Bi:1:004:3 -115 512 <
f1172b00 1591709118 C Bi:1:004:1 0 2 = b100
f1172b00 1591709119 S Bi:1:004:1 -115 512 <
f1172400 1591710111 C Bi:1:004:3 0 3 = b16073
f1172400 1591710116 S Bi:1:004:3 -115 512 <
f1172b00 1591710118 C Bi:1:004:1 0 2 = b100
f1172b00 1591710119 S Bi:1:004:1 -115 512 <
f1172400 1591711112 C Bi:1:004:3 0 3 = b16074
f1172400 1591711116 S Bi:1:004:3 -115 512 <
f1172b00 1591711118 C Bi:1:004:1 0 2 = b100
f1172b00 1591711119 S Bi:1:004:1 -115 512 <
f1172400 1591712113 C Bi:1:004:3 0 3 = b16020
f1172400 1591712117 S Bi:1:004:3 -115 512 <
f1172b00 1591712119 C Bi:1:004:1 0 2 = b100
f1172b00 1591712120 S Bi:1:004:1 -115 512 <
f1172400 1591713112 C Bi:1:004:3 0 3 = b16073
f1172400 1591713116 S Bi:1:004:3 -115 512 <
f1172b00 1591713119 C Bi:1:004:1 0 2 = b100
f1172b00 1591713120 S Bi:1:004:1 -115 512 <
f1172400 1591714112 C Bi:1:004:3 0 3 = b16074
f1172400 1591714117 S Bi:1:004:3 -115 512 <
f1172b00 1591714119 C Bi:1:004:1 0 2 = b100
f1172b00 1591714120 S Bi:1:004:1 -115 512 <
f1172400 1591715111 C Bi:1:004:3 0 3 = b16072
f1172400 1591715116 S Bi:1:004:3 -115 512 <
f1172b00 1591715118 C Bi:1:004:1 0 2 = b100
f1172b00 1591715119 S Bi:1:004:1 -115 512 <
f1172400 1591716115 C Bi:1:004:3 0 2 = b160
f1172400 1591716118 S Bi:1:004:3 -115 512 <
f1172b00 1591716121 C Bi:1:004:1 0 2 = b160
f1172b00 1591716122 S Bi:1:004:1 -115 512 <
f1172400 1591717111 C Bi:1:004:3 0 3 = b16069
f1172400 1591717116 S Bi:1:004:3 -115 512 <
f1172b00 1591717118 C Bi:1:004:1 0 2 = b160
f1172b00 1591717119 S Bi:1:004:1 -115 512 <
f1172400 1591718112 C Bi:1:004:3 0 3 = b1606e
f1172400 1591718116 S Bi:1:004:3 -115 512 <
f1172b00 1591718118 C Bi:1:004:1 0 2 = b160
f1172b00 1591718119 S Bi:1:004:1 -115 512 <
f1172400 1591719112 C Bi:1:004:3 0 3 = b16067
f1172400 1591719116 S Bi:1:004:3 -115 512 <

And here the second port seems to receive junk:

f1172780 1592210316 S Bo:1:004:2 -115 11 = 74657374 20737472 696e67
f1172780 1592210379 C Bo:1:004:2 0 11 >
f1172400 1592210878 C Bi:1:004:3 0 6 = b16895cd d181
f1172400 1592210883 S Bi:1:004:3 -115 512 <
f1172400 1592211128 C Bi:1:004:3 0 3 = b1609a
f1172400 1592211132 S Bi:1:004:3 -115 512 <
f1172b00 1592211134 C Bi:1:004:1 0 2 = b100
f1172b00 1592211135 S Bi:1:004:1 -115 512 <
f1172400 1592212128 C Bi:1:004:3 0 8 = b160d1c9 a5b99dff

I've also found a hub, that looks like 12M hub, but it produces the
same error pattern (wrong chars):

/:  Bus 04.Port 1: Dev 1, Class=root_hub, Driver=uhci_hcd/2p, 12M
    |__ Port 1: Dev 6, If 0, Class=hub, Driver=hub/4p, 12M
        |__ Port 1: Dev 7, If 0, Class=vend., Driver=ftdi_sio, 12M
        |__ Port 1: Dev 7, If 1, Class=vend., Driver=ftdi_sio, 12M
/:  Bus 03.Port 1: Dev 1, Class=root_hub, Driver=uhci_hcd/2p, 12M
/:  Bus 02.Port 1: Dev 1, Class=root_hub, Driver=uhci_hcd/2p, 12M
/:  Bus 01.Port 1: Dev 1, Class=root_hub, Driver=ehci_hcd/6p, 480M

On USB3.0 host I get 9 chars instead of 11 and they are also wrong.

Rx/Tx test: baudrate 115200
Wrong string len: 11
95 CD D1 81 9A D1 C9 A5 B9 9D FF
Rx/Tx /dev/ttyUSB0 > /dev/ttyUSB1: FAILED
Rx/Tx test: baudrate 115200
Rx/Tx /dev/ttyUSB1 > /dev/ttyUSB0: O.K.
Rx/Tx test: baudrate 9600
Rx/Tx /dev/ttyUSB0 > /dev/ttyUSB1: O.K.
Rx/Tx test: baudrate 9600
Rx/Tx /dev/ttyUSB1 > /dev/ttyUSB0: O.K.

Should I make a sniff with them? Should I make a sniff with FT4232H?

Yegor
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux