多年来,usbserial 东西在 Ubuntu 中对我来说运行得非常好,以至于我几乎忘记了如何对其进行故障排除。然而,我刚刚安装了 Chrubuntu,现在我的 USB 串口不仅能神奇地工作了。
这是我认为您需要的信息:
uname -a
Linux ChrUbuntu 3.4.0 #1 SMP Sun Aug 26 19:17:55 EDT 2012 x86_64 x86_64 x86_64 GNU/Linux
我通常希望看到 cp210x 驱动程序。 (正如我将在下面展示的,modprobe 似乎没有加载它。)
root@ChrUbuntu:/lib/modules/3.4.0/kernel/drivers/usb/serial# ls
option.ko pl2303.ko qcserial.ko sierra.ko usb_wwan.ko
LSSB
Bus 001 Device 002: ID 8087:0024 Intel Corp. Integrated Rate Matching Hub
Bus 002 Device 002: ID 8087:0024 Intel Corp. Integrated Rate Matching Hub
Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
Bus 002 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
Bus 001 Device 003: ID 04ca:3006 Lite-On Technology Corp.
Bus 001 Device 004: ID 064e:d251 Suyin Corp.
Bus 002 Device 003: ID 10c4:ea60 Cygnal Integrated Products, Inc. CP210x Composite Device
消息
[ 649.111665] usb 2-1.3: new full-speed USB device number 3 using ehci_hcd
[ 649.199149] usb 2-1.3: New USB device found, idVendor=10c4, idProduct=ea60
[ 649.199161] usb 2-1.3: New USB device strings: Mfr=1, Product=2, SerialNumber=3
[ 649.199169] usb 2-1.3: Product: CP2103 USB to UART Bridge Controller
[ 649.199175] usb 2-1.3: Manufacturer: Silicon Labs
[ 649.199179] usb 2-1.3: SerialNumber: 0001
断开设备连接后,dmesg 中会记录一行新信息:
[ 2858.730137] usb 2-1.3: USB disconnect, device number 3
lsmod
Module Size Used by
fuse 59885 2
rfcomm 25259 0
snd_hda_codec_hdmi 29062 1
snd_hda_codec_realtek 49177 1
memconsole 12352 0
snd_hda_intel 24601 3
snd_hda_codec 71435 3 snd_hda_codec_hdmi,snd_hda_codec_realtek,snd_hda_intel
snd_hwdep 12351 1 snd_hda_codec
ath9k 118119 0
uvcvideo 59368 0
videodev 81368 1 uvcvideo
snd_pcm 61468 3 snd_hda_codec_hdmi,snd_hda_intel,snd_hda_codec
videobuf2_core 25280 1 uvcvideo
videobuf2_vmalloc 12313 1 uvcvideo
videobuf2_memops 12475 1 videobuf2_vmalloc
mac80211 318094 1 ath9k
ath9k_common 12689 1 ath9k
ath9k_hw 351731 2 ath9k,ath9k_common
sdhci_pci 16409 0
sdhci 25037 1 sdhci_pci
ath 21105 3 ath9k,ath9k_common,ath9k_hw
mmc_core 71579 2 sdhci_pci,sdhci
btusb 16409 0
joydev 16409 0
nm10_gpio 12313 0
tg3 118809 0
snd_timer 21055 1 snd_pcm
snd_page_alloc 12757 2 snd_hda_intel,snd_pcm
bluetooth 143138 13 rfcomm,btusb
cfg80211 141223 3 ath9k,mac80211,ath
rtc_cmos 16409 0
假设我的CP210x驱动程序需要的模块是usbserial,我尝试了以下方法:
root@ChrUbuntu:/# modprobe usbserial
root@ChrUbuntu:/#
root@ChrUbuntu:/# lsmod | grep usbserial
root@ChrUbuntu:/#
预期的 /dev/ttyUSB0 丢失(在尝试 modprobe usbserial 之前和之后):
根@ChrUbuntu:/dev# ls
agpgart ecryptfs loop4 port sda2 tpm0 tty19 tty30 tty42 tty54 tty9 vcs6
block fb0 loop5 ppp sda3 tty tty2 tty31 tty43 tty55 uinput vcs7
bsg fd loop6 ptmx sda4 tty0 tty20 tty32 tty44 tty56 urandom vcsa
bus full loop7 pts sda5 tty1 tty21 tty33 tty45 tty57 usbmon0 vcsa1
char fuse loop-control random sda6 tty10 tty22 tty34 tty46 tty58 usbmon1 vcsa2
chromeos-low-mem hpet mapper rfkill sda7 tty11 tty23 tty35 tty47 tty59 usbmon2 vcsa3
console input mcelog rtc sda8 tty12 tty24 tty36 tty48 tty6 v4l vcsa4
core kmsg mem rtc0 sda9 tty13 tty25 tty37 tty49 tty60 vcs vcsa5
cpu log net sda shm tty14 tty26 tty38 tty5 tty61 vcs1 vcsa6
cpu_dma_latency loop0 network_latency sda1 snd tty15 tty27 tty39 tty50 tty62 vcs2 vcsa7
disk loop1 network_throughput sda10 stderr tty16 tty28 tty4 tty51 tty63 vcs3 video0
dm-0 loop2 null sda11 stdin tty17 tty29 tty40 tty52 tty7 vcs4 zero
dri loop3 nvram sda12 stdout tty18 tty3 tty41 tty53 tty8 vcs5
我通常会使用这样的 udev 规则,现在我会使用 ttyUSB0 作为我感兴趣的设备的端口。显然,如果像现在一样缺少 ttyUSB*,这些将无法工作。
KERNEL=="ttyUSB[0-9]*", DRIVERS=="cp210x", ATTRS{interface}=="CP2103 USB to UART Bridge Controller", MODE="0666", NAME:="ttyUSB0"
KERNEL=="ttyUSB[0-9]*", DRIVERS=="pl2303", SUBSYSTEMS=="usb-serial", MODE="0666", NAME:="ttyUSB1"
显然,解决方案是构建内核模块 usbserial.ko 和 cp210x.ko。然而,ChrUbuntu 基于 Ubuntu 12.04,但内核为 3.4。我似乎无法弄清楚在 ChrUbuntu 中构建模块所需的所有变量。
答案1
目录中缺少cp210x.ko
和内核模块:usbserial.ko
/lib/modules/`uname -r`/kernel/drivers/usb/serial/
似乎表明 ChrUbuntu 版本提供的内核是在编译时没有启用这些功能的。
将 OP 问题中提供的输出与 Ubuntu 12.10 进行比较似乎支持了这一点:
ChrUbuntu
root@ChrUbuntu:/lib/modules/3.4.0/kernel/drivers/usb/serial# ls
option.ko pl2303.ko qcserial.ko sierra.ko usb_wwan.ko
乌班图12.10
$ ls /lib/modules/`uname -r`/kernel/drivers/usb/serial/
aircable.ko empeg.ko ipaq.ko mct_u232.ko option.ko sierra.ko visor.ko
ark3116.ko f81232.ko ipw.ko metro-usb.ko oti6858.ko spcp8x5.ko vivopay-serial.ko
belkin_sa.ko ftdi_sio.ko ir-usb.ko mos7720.ko pl2303.ko ssu100.ko whiteheat.ko
ch341.ko funsoft.ko iuu_phoenix.ko mos7840.ko qcaux.ko symbolserial.ko zio.ko
cp210x.ko garmin_gps.ko keyspan.ko moto_modem.ko qcserial.ko ti_usb_3410_5052.ko
cyberjack.ko hp4x.ko keyspan_pda.ko navman.ko quatech2.ko usb_debug.ko
cypress_m8.ko io_edgeport.ko kl5kusb105.ko omninet.ko safe_serial.ko usbserial.ko
digi_acceleport.ko io_ti.ko kobil_sct.ko opticon.ko siemens_mpi.ko usb_wwan.ko
鉴于此,您需要cp210x.ko
从源代码构建内核模块,然后手动安装它。
请参阅标题为 Unix 和 Linux 的问答:Ubuntu make 失败,没有这样的文件或目录 /lib/modules/3.4.0/build,了解如何完成此任务的详细信息。