←back to thread

287 points zdw | 2 comments | | HN request time: 0s | source
Show context
walrus01 ◴[] No.42743231[source]
On the general topic of USB to 1000BASE-T (and now 2.5 GBaseT) dongles, for people who care about performance, it's good to know about the distinction between those that are USB devices and those that are PCI-Express devices.

Basically, what do you get if you hotplug it into a laptop running a current linux kernel and do "sudo lsusb -v" vs "sudo lspci -v"?

The ones that are native PCIE devices offer much better performance, up to 2.5 GBASET line rate, and will communicate with the host over the implementation of thunderbolt over USB.

The ones that are USB only might work okay, but there's a reason they're cheap.

Of course a cheaper laptop also won't have any implementation of thunderbolt on it, so that's something to consider as well.

replies(4): >>42743476 #>>42743639 #>>42744549 #>>42745212 #
Tijdreiziger ◴[] No.42743476[source]
Could you elaborate on why the USB ones are worse?

Per Wikipedia, USB 3.0 (from 2008) can reach 5 Gbit/s, so (naively?) one would expect them to reach 2.5 GbE line rate easily, right?

replies(2): >>42743591 #>>42743627 #
ComputerGuru ◴[] No.42743591[source]
USB doesn’t provide any DMA (until USB 4) and requires more host cpu resources to meet the same bandwidth. It also has less consistent performance by virtue of the USB protocol itself.
replies(1): >>42743848 #
mianos ◴[] No.42743848[source]
I am confused by this, I worked on a Linux USB driver that used DMA in 2003.
replies(1): >>42743983 #
1. ComputerGuru ◴[] No.42743983[source]
DMA from device to host directly rather than from host USB controller to host memory.
replies(1): >>42744081 #
2. mianos ◴[] No.42744081[source]
When I worked on it, the USB controller was just a pci bus device that once set up, the incoming data, from a USB ADC, streamed the data in blocks directly to memory. Maybe they took all that back out.