USB para Serial no Chrubuntu - / dev / ttyUSB0 ausente

3

O material usbserial tem funcionado tão bem para mim no Ubuntu há vários anos que eu quase esqueci como solucionar o problema. Acabei de instalar o Chrubuntu, no entanto, e agora o meu trabalho não está apenas trabalhando magicamente.

Aqui estão as informações que você precisa:

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

Eu normalmente esperaria ver o driver cp210x. (Como mostrarei abaixo, o modprobe não parece carregá-lo).

root@ChrUbuntu:/lib/modules/3.4.0/kernel/drivers/usb/serial# ls
option.ko  pl2303.ko  qcserial.ko  sierra.ko  usb_wwan.ko

lsusb

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

dmesg

[  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

depois de desconectar o dispositivo, uma nova linha é registrada no 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 

Assumindo que o módulo que eu preciso para o driver CP210x é usbserial, eu tentei isso:

root@ChrUbuntu:/# modprobe usbserial
root@ChrUbuntu:/# 

root@ChrUbuntu:/# lsmod | grep usbserial
root@ChrUbuntu:/# 

O / dev / ttyUSB0 esperado está faltando (antes e depois da tentativa do modprobe usbserial):

root @ 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

Eu normalmente usaria regras do udev como essas e usaria ttyUSB0 como minha porta para o dispositivo de interesse agora. Obviamente, isso não funcionará se ttyUSB * estiver ausente, como é agora.

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"

A solução aparentemente é construir os módulos do kernel usbserial.ko e cp210x.ko. No entanto, o ChrUbuntu é baseado no Ubuntu 12.04, mas com o kernel 3.4. Eu não consigo descobrir todas as variáveis necessárias para construir os módulos no ChrUbuntu.

    
por MountainX 12.05.2013 / 21:07

1 resposta

1

A falta dos módulos do kernel cp210x.ko e usbserial.ko no diretório:

/lib/modules/'uname -r'/kernel/drivers/usb/serial/

parece indicar que os kernels fornecidos com as versões do ChrUbuntu foram construídos não tendo esses recursos ativados em tempo de compilação.

Comparar a saída fornecida na pergunta pelo OP com o Ubuntu 12.10 parece confirmar isso:

ChrUbuntu

root@ChrUbuntu:/lib/modules/3.4.0/kernel/drivers/usb/serial# ls
option.ko  pl2303.ko  qcserial.ko  sierra.ko  usb_wwan.ko

Ubuntu 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

Dado isso, você precisará criar o módulo do kernel cp210x.ko a partir do código-fonte e, em seguida, instalá-lo manualmente.

Veja este Unix & Linux Q & A intitulado: O Ubuntu faz uma falha com esse arquivo ou diretório /lib/modules/3.4.0/build , para detalhes sobre como realizar essa tarefa.

    
por 13.05.2013 / 04:06