4

こんにちは、Linux USB ガジェット機能を使用して USB フラッシュ ドライブをエミュレートしています。非常に低いパフォーマンスを除いて、正常に動作しています。

dd によって作成された 4Gb ファイルを使用し、その上に ext2 または vfat (両方を試しました) パーティションを作成しました。次のコマンドシーケンスを使用してマウントするよりも:

# modprobe dummy_hcd is_super_speed=1 # I tried is_high_speed=1, and no parameter too
# modprobe g_mass_storage file=/home/del/img/flash stall=0 # tried w/o stall=0 too
# mount /dev/sdc1 /mnt/tmp

その後、dmesg でエラーなしで作成された /dev/sdc および /dev/sdc1 デバイスを取得します。

[1256700.986581] usb 3-1: reset high-speed USB device number 5 using dummy_hcd
[1256701.022551]  gadget: high-speed config #1: Linux File-Backed Storage
[1256701.242481] usb 3-1: reset high-speed USB device number 5 using dummy_hcd
[1256701.278422]  gadget: high-speed config #1: Linux File-Backed Storage
[1256701.422339]  gadget: high-speed config #1: Linux File-Backed Storage
[1256934.915697] usb 3-1: reset high-speed USB device number 5 using dummy_hcd
[1256934.951628]  gadget: high-speed config #1: Linux File-Backed Storage
[1256935.915155] usb 3-1: reset high-speed USB device number 5 using dummy_hcd
[1256935.951090]  gadget: high-speed config #1: Linux File-Backed Storage
[1256936.095018]  gadget: high-speed config #1: Linux File-Backed Storage
[1317073.396892] usb-storage 3-1:1.0: Quirks match for vid 0525 pid a4a5: 10000
[1317073.396995] scsi53 : usb-storage 3-1:1.0
[1317074.411883] scsi 53:0:0:0: Direct-Access     Linux    File-CD Gadget   0302 PQ: 0 ANSI: 2
[1317074.412669] sd 53:0:0:0: Attached scsi generic sg3 type 0
[1317074.431910] sd 53:0:0:0: [sdc] 8388608 512-byte logical blocks: (4.29 GB/4.00 GiB)
[1317074.443816] sd 53:0:0:0: [sdc] Write Protect is off
[1317074.443821] sd 53:0:0:0: [sdc] Mode Sense: 0f 00 00 00
[1317074.455839] sd 53:0:0:0: [sdc] Write cache: enabled, read cache: enabled, doesn't support DPO or FUA
[1317074.551757]  sdc: sdc1
[1317074.683704] sd 53:0:0:0: [sdc] Attached SCSI removable disk

問題は、IO パフォーマンスが非常に低いことです。200Mb ファイルの書き込みにはかなりの時間がかかります。

$ ls -lh file
-rw-rw-r-- 1 root del 206M Sep  4 09:34 file
$ time sudo cp file /mnt/tmp/
real    11m59.618s
user    0m0.000s
sys     0m0.260s

これは約300K /秒です。ただし、同じシステム上の同じファイルは、1 分もかからずに実際の USB フラッシュにコピーされます。

Iotop は次のように表示します。

 TID  PRIO  USER     DISK READ  DISK WRITE  SWAPIN     IO>    COMMAND                
 9986 be/4 root        0.00 B/s  262.05 K/s  0.00 % 99.86 % cp file /mnt/tmp/
20651 be/4 root       51.77 K/s  238.95 K/s  0.00 % 93.23 % [file-storage]

g_mass_storage でエミュレートされた USB ドライブのパフォーマンスを向上させるためにできることはありますか?

PS:カーネルを使用しています

$ uname -rm
3.2.0-4-686-pae i686
4

1 に答える 1

3

こっちも一緒。

6:00 に 1 泊した後、解決策がありました。

modprobe g_mass_storage file=/home/del/img/flash stall=0 buflen=65536

これにより、最大5MByte /秒になりました

modprobe g_mass_storage file=/home/del/img/flash stall=0 nofua=1

これにより、最大11MByte /秒になりました

「buflen」と「nofua」の組み合わせはあまり役に立ちませんでした。ここで読む「nufua」について:http://lxr.free-electrons.com/source/drivers/usb/gadget/file_storage.c?v=3.5

ウルトラソフト /

于 2014-04-19T00:29:21.197 に答える