Problema de conexão com o armazenamento externo USB3 no Linux (problema do driver UAS)

23

No Ubuntu 15.10, quando eu quero formatar usando o sistema de arquivos NTFS um disco 4TO externo conectado por USB3 (em uma estação de acoplamento de disco rígido StarTech USB / eSATA), tenho muitos erros de E / S e o formato falha.

Tentei o GParted v 0.19 e o GParted no CD ao vivo mais recente gparted-live-0.23.0-1-i586.iso, com o mesmo problema.

Depois disso, e usando o GParted no Ubuntu 15.10 e a mesma conexão USB3, tentei formatar como ext4sem problemas. Isso é realmente estranho.

Como não sei se as mkfs.ext4ferramentas usadas pelo GParted para formatar o disco testam o disco como (ou não) mkntfs, primeiro suponho que o problema esteja vinculado ao novo disco. Talvez este novo disco esteja causando problemas. Então, eu tento rodar e2fsck -cneste disco rígido. No Ubuntu 15.10, e2fsck -ccongela em 0,45%, e não sei por quê.

Portanto, usando outra versão do Ubuntu (15.04) no mesmo PC, tento conectar o mesmo disco 4TO usando a conexão eSATA do encaixe StarTech HDD. Desta vez, e2fsck -cfunciona corretamente.

Após algumas horas, você pode ver o resultado:

sudo e2fsck -c /dev/sdc1
e2fsck 1.42.12 (29-Aug-2014)
ColdCase : récupération du journal
Vérification des blocs défectueux (test en mode lecture seule) : complété                                             
ColdCase: Updating bad block inode.
Passe 1 : vérification des i-noeuds, des blocs et des tailles
Passe 2 : vérification de la structure des répertoires
Passe 3 : vérification de la connectivité des répertoires
Passe 4 : vérification des compteurs de référence
Passe 5 : vérification de l'information du sommaire de groupe

ColdCase: ***** LE SYSTÈME DE FICHIERS A ÉTÉ MODIFIÉ *****
ColdCase : 11/244195328 fichiers (0.0% non contigus), 15377150/976754176 blocs

Eu não sou um especialista em badblocksaídas, mas parece que não há nenhum bloco ruim neste disco?

Então, se o problema não for o disco rígido, talvez o problema possa ser vinculado ao mkntfsusado pelo USB3? Que outros testes posso tentar?

Algumas informações sobre o dock USB:

➜  ~  lsusb
...
Bus 002 Device 002: ID 174c:55aa ASMedia Technology Inc. ASM1051E SATA 6Gb/s bridge, ASM1053E SATA 6Gb/s bridge, ASM1153 SATA 3Gb/s bridge
...


➜  ~  sudo lsusb -v -d 174c:55aa
Mot de passe [sudo] pour reyman : 

Bus 002 Device 002: ID 174c:55aa ASMedia Technology Inc. ASM1051E SATA 6Gb/s bridge, ASM1053E SATA 6Gb/s bridge, ASM1153 SATA 3Gb/s bridge
Device Descriptor:
  bLength                18
  bDescriptorType         1
  bcdUSB               3.00
  bDeviceClass            0 (Defined at Interface level)
  bDeviceSubClass         0 
  bDeviceProtocol         0 
  bMaxPacketSize0         9
  idVendor           0x174c ASMedia Technology Inc.
  idProduct          0x55aa ASM1051E SATA 6Gb/s bridge, ASM1053E SATA 6Gb/s bridge, ASM1153 SATA 3Gb/s bridge
  bcdDevice            1.00
  iManufacturer           2 asmedia
  iProduct                3 ASM1053E
  iSerial                 1 123456789012
  bNumConfigurations      1
  Configuration Descriptor:
    bLength                 9
    bDescriptorType         2
    wTotalLength          121
    bNumInterfaces          1
    bConfigurationValue     1
    iConfiguration          0 
    bmAttributes         0xc0
      Self Powered
    MaxPower               36mA
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        0
      bAlternateSetting       0
      bNumEndpoints           2
      bInterfaceClass         8 Mass Storage
      bInterfaceSubClass      6 SCSI
      bInterfaceProtocol     80 Bulk-Only
      iInterface              0 
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x81  EP 1 IN
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0400  1x 1024 bytes
        bInterval               0
        bMaxBurst              15
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x02  EP 2 OUT
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0400  1x 1024 bytes
        bInterval               0
        bMaxBurst              15
    Interface Descriptor:
      bLength                 9
      bDescriptorType         4
      bInterfaceNumber        0
      bAlternateSetting       1
      bNumEndpoints           4
      bInterfaceClass         8 Mass Storage
      bInterfaceSubClass      6 SCSI
      bInterfaceProtocol     98 
      iInterface              0 
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x81  EP 1 IN
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0400  1x 1024 bytes
        bInterval               0
        bMaxBurst              15
        MaxStreams             16
        Data-in pipe (0x03)
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x02  EP 2 OUT
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0400  1x 1024 bytes
        bInterval               0
        bMaxBurst              15
        MaxStreams             16
        Data-out pipe (0x04)
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x83  EP 3 IN
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0400  1x 1024 bytes
        bInterval               0
        bMaxBurst              15
        MaxStreams             16
        Status pipe (0x02)
      Endpoint Descriptor:
        bLength                 7
        bDescriptorType         5
        bEndpointAddress     0x04  EP 4 OUT
        bmAttributes            2
          Transfer Type            Bulk
          Synch Type               None
          Usage Type               Data
        wMaxPacketSize     0x0400  1x 1024 bytes
        bInterval               0
        bMaxBurst               0
        Command pipe (0x01)
Binary Object Store Descriptor:
  bLength                 5
  bDescriptorType        15
  wTotalLength           22
  bNumDeviceCaps          2
  USB 2.0 Extension Device Capability:
    bLength                 7
    bDescriptorType        16
    bDevCapabilityType      2
    bmAttributes   0x00000002
      Link Power Management (LPM) Supported
  SuperSpeed USB Device Capability:
    bLength                10
    bDescriptorType        16
    bDevCapabilityType      3
    bmAttributes         0x00
    wSpeedsSupported   0x000e
      Device can operate at Full Speed (12Mbps)
      Device can operate at High Speed (480Mbps)
      Device can operate at SuperSpeed (5Gbps)
    bFunctionalitySupport   1
      Lowest fully-functional device speed is Full Speed (12Mbps)
    bU1DevExitLat          10 micro seconds
    bU2DevExitLat        2047 micro seconds
Device Status:     0x0001
  Self Powered

Informações sobre o disco em questão: /dev/sdd

➜  ~  sudo fdisk -l /dev/sdd
Disque /dev/sdd : 3,7 TiB, 4000787030016 octets, 7814037168 secteurs
Unités : sectors of 1 * 512 = 512 octets
Sector size (logical/physical): 512 bytes / 4096 bytes
I/O size (minimum/optimal): 4096 bytes / 33553920 bytes
Disklabel type: gpt
Disk identifier: ACD5760B-2898-435E-82C6-CB3119758C9B

Périphérique Start        Fin   Secteurs  Size Type
/dev/sdd1     2048 7814035455 7814033408  3,7T Linux filesystem

dmesgretorna muitos erros sobre o disco; veja este extrato:

[   68.856381] scsi host6: uas_eh_bus_reset_handler start
[   68.968376] usb 2-2: reset SuperSpeed USB device number 2 using xhci_hcd
[   68.989825] scsi host6: uas_eh_bus_reset_handler success
[   99.881608] sd 6:0:0:0: [sdd] tag#12 uas_eh_abort_handler 0 uas-tag 13 inflight: CMD OUT 
[   99.881618] sd 6:0:0:0: [sdd] tag#12 CDB: Write(16) 8a 00 00 00 00 00 e8 c4 08 00 00 00 00 08 00 00
[   99.881856] sd 6:0:0:0: [sdd] tag#5 uas_eh_abort_handler 0 uas-tag 6 inflight: CMD OUT 
[   99.881861] sd 6:0:0:0: [sdd] tag#5 CDB: Write(16) 8a 00 00 00 00 00 cd 01 08 f0 00 00 00 10 00 00
[   99.881967] sd 6:0:0:0: [sdd] tag#4 uas_eh_abort_handler 0 uas-tag 5 inflight: CMD OUT 
[   99.881972] sd 6:0:0:0: [sdd] tag#4 CDB: Write(16) 8a 00 00 00 00 00 cd 01 08 00 00 00 00 f0 00 00
[   99.882085] sd 6:0:0:0: [sdd] tag#3 uas_eh_abort_handler 0 uas-tag 4 inflight: CMD OUT 
[   99.882090] sd 6:0:0:0: [sdd] tag#3 CDB: Write(16) 8a 00 00 00 00 00 cd 01 07 10 00 00 00 f0 00 00
[   99.882171] sd 6:0:0:0: [sdd] tag#2 uas_eh_abort_handler 0 uas-tag 3 inflight: CMD OUT 
[   99.882175] sd 6:0:0:0: [sdd] tag#2 CDB: Write(16) 8a 00 00 00 00 00 cd 01 06 20 00 00 00 f0 00 00
[   99.882255] sd 6:0:0:0: [sdd] tag#1 uas_eh_abort_handler 0 uas-tag 2 inflight: CMD OUT 
[   99.882258] sd 6:0:0:0: [sdd] tag#1 CDB: Write(16) 8a 00 00 00 00 00 cd 01 05 30 00 00 00 f0 00 00
[   99.882338] sd 6:0:0:0: [sdd] tag#0 uas_eh_abort_handler 0 uas-tag 1 inflight: CMD OUT 
[   99.882342] sd 6:0:0:0: [sdd] tag#0 CDB: Write(16) 8a 00 00 00 00 00 cd 01 04 40 00 00 00 f0 00 00
[   99.882419] sd 6:0:0:0: [sdd] tag#11 uas_eh_abort_handler 0 uas-tag 12 inflight: CMD OUT 
[   99.882423] sd 6:0:0:0: [sdd] tag#11 CDB: Write(16) 8a 00 00 00 00 00 cd 00 f9 00 00 00 00 f0 00 00
[   99.882480] sd 6:0:0:0: [sdd] tag#10 uas_eh_abort_handler 0 uas-tag 11 inflight: CMD OUT 
[   99.882483] sd 6:0:0:0: [sdd] tag#10 CDB: Write(16) 8a 00 00 00 00 00 cd 00 f9 f0 00 00 00 f0 00 00
[   99.882530] sd 6:0:0:0: [sdd] tag#9 uas_eh_abort_handler 0 uas-tag 10 inflight: CMD OUT 
[   99.882532] sd 6:0:0:0: [sdd] tag#9 CDB: Write(16) 8a 00 00 00 00 00 cd 00 fa e0 00 00 00 f0 00 00
[   99.882593] sd 6:0:0:0: [sdd] tag#8 uas_eh_abort_handler 0 uas-tag 9 inflight: CMD 
[   99.882596] sd 6:0:0:0: [sdd] tag#8 CDB: Write(16) 8a 00 00 00 00 00 cd 00 fb d0 00 00 00 f0 00 00
[   99.882667] scsi host6: uas_eh_bus_reset_handler start
[   99.994700] usb 2-2: reset SuperSpeed USB device number 2 using xhci_hcd
[  100.015613] scsi host6: uas_eh_bus_reset_handler success
[  135.962175] sd 6:0:0:0: [sdd] tag#5 uas_eh_abort_handler 0 uas-tag 6 inflight: CMD OUT 
[  135.962185] sd 6:0:0:0: [sdd] tag#5 CDB: Write(16) 8a 00 00 00 00 00 cd 40 78 f0 00 00 00 10 00 00
[  135.962428] sd 6:0:0:0: [sdd] tag#4 uas_eh_abort_handler 0 uas-tag 5 inflight: CMD OUT 
[  135.962436] sd 6:0:0:0: [sdd] tag#4 CDB: Write(16) 8a 00 00 00 00 00 cd 40 78 00 00 00 00 f0 00 00
[  135.962567] sd 6:0:0:0: [sdd] tag#3 uas_eh_abort_handler 0 uas-tag 4 inflight: CMD OUT 
[  135.962576] sd 6:0:0:0: [sdd] tag#3 CDB: Write(16) 8a 00 00 00 00 00 cd 40 77 10 00 00 00 f0 00 00
[  135.962682] sd 6:0:0:0: [sdd] tag#2 uas_eh_abort_handler 0 uas-tag 3 inflight: CMD OUT 
[  135.962690] sd 6:0:0:0: [sdd] tag#2 CDB: Write(16) 8a 00 00 00 00 00 cd 40 76 20 00 00 00 f0 00 00
[  135.962822] sd 6:0:0:0: [sdd] tag#1 uas_eh_abort_handler 0 uas-tag 2 inflight: CMD 
[  135.962830] sd 6:0:0:0: [sdd] tag#1 CDB: Write(16) 8a 00 00 00 00 00 cd 40 75 30 00 00 00 f0 00 00
[  160.904916] sd 6:0:0:0: [sdd] tag#0 uas_eh_abort_handler 0 uas-tag 1 inflight: CMD OUT 
[  160.904926] sd 6:0:0:0: [sdd] tag#0 CDB: Write(16) 8a 00 00 00 00 00 00 00 29 08 00 00 00 08 00 00
[  160.905068] scsi host6: uas_eh_bus_reset_handler start

Encontrei essas informações neste post do fórum , que há algum problema com o UAS e os novos kernels do Linux? Parece que o problema é conhecido em muitos lugares na internet; o USB3 + Linux parece problemático em muitos casos - mas para os kernels antigos. Alguma idéia para resolver esse problema em um kernel mais recente?

Meu kernel é:

➜  ~  uname -r 
4.2.0-16-generic

Hmm, parece que o UAS está quebrado para diferentes chips USB3 de ASMedia Technology Inc.; você pode ver mais informações aqui .

Suponho que esse seja o meu problema, mas como posso resolvê-lo agora e qual chip é usado para a implementação do USB3 no dock da StarTech?

reyman64
fonte

Respostas:

9

Encontrei este problema hoje em um kernel 4.8.0.

De acordo com este post do fórum , pode ser contornado por

$ echo options usb-storage quirks=357d:7788:u | sudo tee /etc/modprobe.d/blacklist_uas_357d.conf
$ sudo update-initramfs -u

e reiniciando.

YtvwlD
fonte
3
Observe que o parâmetro quirks precisa ser definido para o ID específico do dispositivo incorreto, encontrado via lsusb.
Boann
14

Eu tive esse mesmo problema no Mint 18, mas a solução que encontrei provavelmente pode ser aplicada ao * Ubuntu 15/16, bem como a distribuições Linux semelhantes. Para mim, no entanto, estava recebendo um bloqueio irrecuperável do sistema logo após ver os erros do UAS no dmesg.

Meu gabinete possui um chip ASMedia ASM1053, que parece ter problemas com o módulo UAS do meu kernel (4.4.0-72-genérico).

Depois de um pouco de pesquisa, combinei duas soluções que encontrei: esta, mencionada pelo YtvwlD e esta .

Primeiro, você deve obter o ID do hardware do seu dispositivo usando o comando lsusb . Depois de fazer isso, localize seu externo / gabinete / ponte. Pode aparecer como abaixo:

Bus 002 Device 002: ID 174c:5136 ASMedia Technology Inc. ASM1053 SATA 6Gb/s bridge

No meu caso, o ID é 174c: 5136 .

Depois disso, você deve criar um arquivo em /etc/modprobe.d/ para que o dispositivo apropriado fique na lista negra de usar o UAS (o que está causando problemas), atualize a imagem initramfs usando update-initramfs e , em seguida, reinicie para que a alteração tenha efeito.

$ echo options usb-storage quirks=174c:5136:u | sudo tee /etc/modprobe.d/blacklist_uas.conf
$ sudo update-initramfs -u
$ sudo reboot

Obviamente, substitua "174c: 5136" pelo ID do hardware da sua ponte / gabinete / externo. Se feito corretamente, você verá uma mensagem como esta do dmesg ao conectar seu dispositivo após a reinicialização:

[   93.985002] usb 4-1: UAS is blacklisted for this device, using usb-storage instead

Não tive nenhum problema com meu gabinete desde então.

Cinos Modnar
fonte
Parece que também estou enfrentando esse problema no Debian 9.4 4.14.18-sunxi64. :(
TCB13
Corrigido o problema no meu kernel aqui: unix.stackexchange.com/a/441772/23085 . Parece que alguns kernels foram usb-storageincorporados ao invés de carregados como um módulo e o procedimento é um pouco diferente.
TCB13
1
Embora esse corte hediondo e redutor de desempenho, aplicado a todas as máquinas, permita que o gabinete funcione basicamente, ainda é um corte hediondo e redutor de desempenho, que deve ser aplicado a todas as máquinas. E se eu inicializar uma distribuição ao vivo do Linux, esperando poder fazer backup ou recuperar arquivos? Esse hack não funcionará lá. Então, para quem devo relatar esse problema? Devo denunciá-lo como um bug do kernel do Linux? Devo deixar uma análise negativa do gabinete, anunciada como compatível com Linux? De quem é esse problema?
Boann
trabalhou para mim com: 174c: 55aa ponte ASMedia Technology Inc. ponte ASM1051E SATA 6Gb / s, ponte ASM1053E SATA 6Gb / s, ponte ASM1153 SATA 3Gb / s
Dr. Tyrell
1
@Boann qualquer dispositivo que o kernel tente usar com o protocolo UAS que não funcione corretamente é tecnicamente um hardware quebrado. O hardware não deve anunciar suporte ao UAS, a menos que realmente funcione. Você ainda pode relatar isso aos mantenedores do subsistema usb do kernel do Linux que possuem uma lista de hardware conhecido como ruim que ainda pode ser usado se tratado especialmente. Você também pode optar por várias soluções alternativas usando o quirksparâmetro usb_storagemodule, exatamente a mesma coisa será ativada automaticamente se os desenvolvedores do kernel souberem do problema. O desempenho ainda será reduzido e / ou os recursos ausentes.
Mikko Rantalainen