web-dev-qa-db-ja.com

fdiskがUSBストレージを見つけることができません

LinuxのUSBストレージの問題により、1日以上かかりました。dmesgはUSBが検出されたと言っていますが、fdisk -lUSBストレージが見つかりません。

私のカーネルは2.4.32です。

このUSBストレージに関する情報は、procからも見つけることができます。

# cat /proc/scsi/usb-storage-0/0 
   Host scsi0: usb-storage
       Vendor: USB 2.0
      Product: USB Flash Drive
Serial Number: 00000000001485
     Protocol: Transparent SCSI
    Transport: Bulk
         GUID: 048d11670000000000001485
     Attached: Yes

lsmodの表示:

# lsmod | grep usb
usb-storage            27800   0 
usbcore                56864   0  [ehci-hcd uhci usb-storage]
scsi_mod              108120   1  [usb-storage]

scsi

 # cat /proc/scsi/scsi     
    Attached devices: 
    Host: scsi0 Channel: 00 Id: 00 Lun: 00
      Vendor: USB 2.0  Model: USB Flash Drive  Rev: 0.00
      Type:   Direct-Access                    ANSI SCSI revision: 02

「fdisk-l/dev/sda」では何も表示されず、「strace fdisk -l/dev/sda」では次のように表示されます。

open("/dev/sda", O_RDONLY|O_LARGEFILE)  = -1 ENXIO (No such device or address)

dmesgのテール

hub.c: new USB device 00:1d.7-2, assigned address 2
usb.c: kmalloc IF af910660, numif 1
usb.c: new device strings: Mfr=1, Product=2, SerialNumber=3
usb.c: USB device number 2 default language ID 0x409
Manufacturer: USB 2.0
Product: USB Flash Drive
SerialNumber: 00000000001485
scsi0 : SCSI emulation for USB Mass Storage devices
  Vendor: USB 2.0   Model: USB Flash Drive   Rev: 0.00
  Type:   Direct-Access                      ANSI SCSI revision: 02
WARNING: USB Mass Storage data integrity not assured
USB Mass Storage device found at 2
usb.c: usb-storage driver claimed interface af910660
usb.c: kusbd: /sbin/hotplug add 2
hub.c: port 3, portstatus 100, change 0, 12 Mb/s
hub.c: port 4, portstatus 100, change 0, 12 Mb/s
hub.c: port 5, portstatus 100, change 0, 12 Mb/s
hub.c: port 6, portstatus 100, change 0, 12 Mb/s
hub.c: port 7, portstatus 100, change 0, 12 Mb/s
hub.c: port 8, portstatus 100, change 0, 12 Mb/s
2
whatacold

最後に、私はこの問題を解決しました! :-P

私は_insmod scsi_mod.o_と_sd_mod.o_であることが判明しましたが、カーネルはすでにSCSIをサポートしていました。

ため息〜

また、scsi_modはsd_modの前にinsmod'edし、ehci_hcd.oはusb-storage.oの前に置く必要があることもわかりました。そうでない場合、dmesgはusb.c: USB device not accepting new address=2 (error=-71)と言います。

4
whatacold

Usbstickを挿入するときは、dmesgを詳しく見てください。私の推測では、tは/ dev/sdaで配管されていません。

0
Ben

「カーネルは2.4.32です」-本当に?もう少し現代的なものを使用できませんか?

「cat/proc/scsi/scsi」を見てみましたか? 「fdisk-l/dev/sda」はどうですか?

「fdisk-l」自体は、システム内のすべてのディスクのようなデバイスを常に試行するとは限りません。特定のデバイスを与えると、それを強制的に調べて、パーティションテーブルを通知します。

0
pjc50