Re: pyserial.tools.list_port improvement for FreeBSD

From: Tomek CEDRO <tomek_at_cedro.info>
Date: Mon, 21 Oct 2024 20:21:16 UTC
On Mon, Oct 21, 2024 at 9:04 PM Dirk-Willem van Gulik
<dirkx@webweaving.org> wrote:
> On 21 Oct 2024, at 11:54, Poul-Henning Kamp <phk@phk.freebsd.dk> wrote:
> > I have had reason to muck about with pyserial. One result is much better pyserial.tools.list_port implementation for FreeBSD.
> > I would appreciate it, if somebody else could give it a spin, before I upstream:
> >       https://github.com/bsdphk/pyserial
>
> Works for me (provided /usr/sbin is in the path); and nicely picks up a ugen0.2 that the ESP32 tooling would always need an explicit path for prior despite it having a tty name.

Very cool PHK! But I have some more ideas below :-) :-P

% uname -a
FreeBSD octagon 13.3-RELEASE-p7 FreeBSD 13.3-RELEASE-p7 GENERIC amd64

On current 3.5 system py311 package:

>>> list_ports.main()
/dev/cuaU0
/dev/cuaU1
/dev/cuaU2
/dev/cuaU3
/dev/cuaU4
/dev/cuau0
6 ports found

On Your repo from 3.9 venv:

(venv3.9embedded) python3 list_ports_freebsd.py
/dev/cuaU0 - ugen0.7: usb
/dev/cuaU1 - ugen0.8: usb
/dev/cuaU2 - ugen0.9: usb
/dev/cuaU3 - ugen0.10: usb
/dev/cuaU4 - ugen0.11: usb
/dev/cuau0 - cuau0: uart

Now lets take a look at two example descriptors:

% usbconfig -d ugen0.7 dump_device_desc
ugen0.7: <Silicon Labs CP2102 USB to UART Bridge Controller> at
usbus0, cfg=0 md=HOST spd=FULL (12Mbps) pwr=ON (100mA)

  bLength = 0x0012
  bDescriptorType = 0x0001
  bcdUSB = 0x0110
  bDeviceClass = 0x0000  <Probed by interface class>
  bDeviceSubClass = 0x0000
  bDeviceProtocol = 0x0000
  bMaxPacketSize0 = 0x0040
  idVendor = 0x10c4
  idProduct = 0xea60
  bcdDevice = 0x0100
  iManufacturer = 0x0001  <Silicon Labs>
  iProduct = 0x0002  <CP2102 USB to UART Bridge Controller>
  iSerialNumber = 0x0003  <0001>
  bNumConfigurations = 0x0001

% usbconfig -d ugen0.8 dump_device_desc
ugen0.8: <Espressif USB JTAG/serial debug unit> at usbus0, cfg=0
md=HOST spd=FULL (12Mbps) pwr=ON (500mA)

  bLength = 0x0012
  bDescriptorType = 0x0001
  bcdUSB = 0x0200
  bDeviceClass = 0x00ef  <Miscellaneous device>
  bDeviceSubClass = 0x0002
  bDeviceProtocol = 0x0001
  bMaxPacketSize0 = 0x0040
  idVendor = 0x303a
  idProduct = 0x1001
  bcdDevice = 0x0101
  iManufacturer = 0x0001  <Espressif>
  iProduct = 0x0002  <USB JTAG/serial debug unit>
  iSerialNumber = 0x0003  <60:XX:F9:CC:XX:XX>
  bNumConfigurations = 0x0001

% usbconfig -d ugen0.9 dump_device_desc
ugen0.9: <STMicroelectronics STM32 STLink> at usbus0, cfg=0 md=HOST
spd=FULL (12Mbps) pwr=ON (300mA)

  bLength = 0x0012
  bDescriptorType = 0x0001
  bcdUSB = 0x0200
  bDeviceClass = 0x00ef  <Miscellaneous device>
  bDeviceSubClass = 0x0002
  bDeviceProtocol = 0x0001
  bMaxPacketSize0 = 0x0040
  idVendor = 0x0483
  idProduct = 0x374b
  bcdDevice = 0x0100
  iManufacturer = 0x0001  <STMicroelectronics>
  iProduct = 0x0002  <STM32 STLink>
  iSerialNumber = 0x0003  <0667XXXX49558575671XXXXX>
  bNumConfigurations = 0x0001

It would be amazingly useful to also have SerialNumber, VID/PID,
Manufacturer + Product printed out in a single line delimeted for easy
parse (maybe a table?), something like:

/dev/cuaU0: ugen0.9, usb, tty?, 0667XXXX49558575671XXXXX, 0483:374b,
STMicroelectronics STM32 STLink.

We are building distributed build and testing farm for NuttX RTOS
where different boards are attached over multiport USB HUB(s). Build
will be repeated with different tools and commits in order to verify a
firmware image build, then firmware will be flashed to a physical
board in order to perform on-board runtime tests. Logs will be
gathered and sent back to a server for analysis (PASS / FAIL + logs).

This comes as complementary action to build only verification on
GitHub and recent cuts in CI availability (we exceed CI quota by a lot
with just standard PR verification). Plus we will have real world
hardware runtime verification :-)

Also we plan to use https://github.com/mvp/uhubctl for single USB HUB
port control. I did not play with that guy yet, is supposed to work on
FreeBSD, will have to add support for my i-Tec U3CHARGEHUB16.

ugen device is nice to know, but it will change depending on what will
be attached to what port, maybe even change in time as HUB ports are
cycled, SN is better for target board/interface identification in
scripting :-)

Thank you :-)
Tomek

-- 
CeDeROM, SQ7MHZ, http://www.tomek.cedro.info