serialport-rs icon indicating copy to clipboard operation
serialport-rs copied to clipboard

Enumate the serialport not correct in raspberry CM4

Open zrz4066 opened this issue 2 years ago • 7 comments

let ports = serialport::available_ports().expect("No ports found!"); for p in ports { println!("{}", p.port_name); }

After run the code ,I got the serial port name. The port name is not correct. "/sys/class" is redundant. There are other serial port such as /dev/ttyAMA1 /dev/AMA2,but it does't enumerate all serial port actually. pi@raspberrypi:~ $ sudo ./rpidemo Blinking an LED on a Raspberry Pi Compute Module 4. /sys/class/tty/ttyUSB3 /sys/class/tty/ttyUSB1 /sys/class/tty/ttyUSB2 /sys/class/tty/ttyUSB0

zrz4066 avatar Oct 19 '22 03:10 zrz4066

I'm sorry for the late reply @zrz4066! Which release of serialport-rs were you using back then? Could you please give our example list_ports a try? On a Raspberry Pi 3+ running Raspian Buster, it lists me the expected USB serial devices:

$ cargo run --example list_ports
[...]
Found 3 ports:
  /dev/ttyAMA0
    Type: Unknown
  /dev/ttyUSB1
    Type: USB
    VID:10c4 PID:ea60
     Serial Number: [...]
      Manufacturer: Cygnal Integrated Products, Inc.
           Product: CP2102/CP2109 UART Bridge Controller [CP210x family]
  /dev/ttyUSB0
    Type: USB
    VID:0403 PID:6001
     Serial Number: FT[...]
      Manufacturer: Future Technology Devices International, Ltd
           Product: FT232 Serial (UART) IC

Which operating system release are you running on your Raspberry Pi? If the output differs there, then this is something to look further into.

I've got the output above even with our release 4.2.0 which was out at the time you were writing this issue.

sirhcel avatar Jul 04 '23 12:07 sirhcel

Finally managed to fabricate the output from the description with the list_ports.rs example and disabled support for libudev:

$ cargo run --no-default-features --example list_ports
    Finished dev [unoptimized + debuginfo] target(s) in 0.06s
     Running `target/debug/examples/list_ports`
Found 5 ports:
  /sys/class/tty/ttyUSB1
    Type: Unknown
  /sys/class/tty/ttyS0
    Type: Unknown
[...]

It looks like the actual enumeration just returns directory names from /sys/class/tty. These are not the device file paths needed for instantiating the devices like /dev/ttyUSB0. What likely needs to be done:

  • Check if there is a symlink pointing to the actual device file from inside /sys/class/tty/ttyX?
  • Or just build the device file name /dev/ttyX from /sys/class/tty/ttyX
    • Cross check that the device numbers from /sys/class/tty/ttyX/dev match?

sirhcel avatar Aug 08 '23 22:08 sirhcel

Version 4.2.2 Exec code: example list_ports (no-default-features) Result : No ports found. (actually have ttymxc1 ttymxc2) Hardware:NXP.I.MX6ULL
Kernel version:4.5.1 Build Env : --target=arm-unknown-linux-musleabihf

Thanks for your Answer at #119 and hope it can help you.

pandakka avatar Aug 10 '23 07:08 pandakka

Result : No ports found. (actually have ttymxc1 ttymxc2)

I would have expected them to be listed in /sys/class/tty @pandakka. How does for example /sys/class/tty/ttymxc1 look like? Could you please capture a directory listing (ls -l) there? I'm wondering why the enumeration fails.

sirhcel avatar Aug 10 '23 20:08 sirhcel

@sirhcel Sure ! But I need to go outside these days.Once back I will write in this issues.

pandakka avatar Aug 11 '23 07:08 pandakka

I found the time to boot up an i.MX8 board. It runs a Linux with BusyBox and in /sys/class/tty, the links for ttymcx0 and ttymxc2 are present and the linked directories look like they would result in these devices being enumerated'

# uname -a
Linux phyboard-polis-imx8mm-3 4.19.35-bsp-yocto-fsl-i.mx8mm-pd20.1.0 #1 SMP PREEMPT Tue Jun 30 01:59:19 UTC 2020 aarch64 GNU/Linux
# ls -l /sys/class/tty/ttymxc*
lrwxrwxrwx    1 root     root             0 Aug 23 22:11 /sys/class/tty/ttymxc0 -> ../../devices/platform/30860000.serial/tty/ttymxc0/
lrwxrwxrwx    1 root     root             0 Aug 23 22:11 /sys/class/tty/ttymxc2 -> ../../devices/platform/30880000.serial/tty/ttymxc2/
# ls -l /sys/class/tty/ttymxc0/device /sys/class/tty/ttymxc2/device
lrwxrwxrwx    1 root     root             0 Aug 23 22:14 /sys/class/tty/ttymxc0/device -> ../../../30860000.serial/
lrwxrwxrwx    1 root     root             0 Aug 23 22:16 /sys/class/tty/ttymxc2/device -> ../../../30880000.serial/

Linux on this board is pretty bare and getting list_ports to build looks like a pretty bunch of work ahead. So I'm stopping here for now.

How does things look on your system @pandakka?

sirhcel avatar Aug 23 '23 20:08 sirhcel

Sorry for the late reply! It seems looks like same as mine. Due to the system is pretty bare, that libudev may not work which cause the list_ports can't find the port. Right? Thank you for you answar!

pandakka avatar Sep 28 '23 03:09 pandakka