私は このチュートリアル をフォローしています。しかし、ステップ9で行き詰まり、どういうわけかUSBをマウントできません。
USBをマウントしようとするたびに、次のエラーが発生します。
root@OpenWrt:~# mount /dev/sda2 /mnt/sda2
mount: mounting /dev/sda2 on /mnt/sda2 failed: Invalid argument
USBは問題なく接続されているようですが、どういうわけかsda2(ext4)パーティションをマウントできません。
パーティションも問題ないようです:
root@OpenWrt:~# blkid
/dev/mtdblock2: TYPE="squashfs"
/dev/sda1: UUID="e39964e8-1b51-4b1f-b034-0147fa394eea" TYPE="swap"
/dev/sda2: UUID="157cfc0d-f33d-4103-950d-6ae01baa7177" TYPE="ext4"
そして、これは私のdmesg
出力です:
root@OpenWrt:~# dmesg | grep sda
[ 9.360000] sd 0:0:0:0: [sda] 7987200 512-byte logical blocks: (4.08 GB/3.80 GiB)
[ 9.370000] sd 0:0:0:0: [sda] Write Protect is off
[ 9.370000] sd 0:0:0:0: [sda] Mode Sense: 23 00 00 00
[ 9.370000] sd 0:0:0:0: [sda] Write cache: disabled, read cache: enabled, doesn't support DPO or FUA
[ 9.400000] sda: sda1 sda2
[ 9.410000] sd 0:0:0:0: [sda] Attached SCSI removable disk
[ 41.850000] EXT4-fs (sda2): couldn't mount as ext3 due to feature incompatibilities
[ 41.870000] EXT4-fs (sda2): couldn't mount as ext2 due to feature incompatibilities
[ 41.880000] EXT4-fs (sda2): couldn't mount RDWR because of unsupported optional features (400)
[ 270.660000] EXT4-fs (sda2): couldn't mount as ext3 due to feature incompatibilities
[ 270.670000] EXT4-fs (sda2): couldn't mount as ext2 due to feature incompatibilities
[ 270.670000] EXT4-fs (sda2): couldn't mount RDWR because of unsupported optional features (400)
[ 585.040000] EXT4-fs (sda2): couldn't mount as ext3 due to feature incompatibilities
[ 585.050000] EXT4-fs (sda2): couldn't mount as ext2 due to feature incompatibilities
[ 585.060000] EXT4-fs (sda2): couldn't mount RDWR because of unsupported optional features (400)
[ 586.540000] EXT4-fs (sda2): couldn't mount as ext3 due to feature incompatibilities
[ 586.550000] EXT4-fs (sda2): couldn't mount as ext2 due to feature incompatibilities
[ 586.560000] EXT4-fs (sda2): couldn't mount RDWR because of unsupported optional features (400)
[ 651.570000] EXT4-fs (sda2): couldn't mount as ext3 due to feature incompatibilities
[ 651.580000] EXT4-fs (sda2): couldn't mount as ext2 due to feature incompatibilities
[ 651.590000] EXT4-fs (sda2): couldn't mount RDWR because of unsupported optional features (400)
これは私の fdisk -l
出力:
WARNING: GPT (GUID Partition Table) detected on '/dev/sda'! The util fdisk doesn't support GPT. Use GNU Parted.
Disk /dev/sda: 4089 MB, 4089446400 bytes
255 heads, 63 sectors/track, 497 cylinders, total 7987200 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00000000
Device Boot Start End Blocks Id System
/dev/sda1 1 7987199 3993599+ ee GPT
エラーメッセージは<Linux kernel source code>/fs/ext4/super.c
の次の行から表示されます。
if (ext4_has_unknown_ext4_ro_compat_features(sb)) {
ext4_msg(sb, KERN_ERR, "couldn't mount RDWR because of "
"unsupported optional features (%x)",
(le32_to_cpu(EXT4_SB(sb)->s_es->s_feature_ro_compat) &
~EXT4_FEATURE_RO_COMPAT_SUPP));
エラーメッセージの数値のプレースホルダーは%x
であるため、実際のエラーメッセージの数値400は16進数の0x400です。そして、それはEXT4_FEATURE_RO_COMPAT_
定数によって識別される機能の場合です。
これらの定数の定義は<Linux kernel source code>/fs/ext4/ext4.h
にあります。
#define EXT4_FEATURE_RO_COMPAT_METADATA_CSUM 0x0400
Sourcejediで言及されているdir_nlink
機能は0x400ではなく0x20です。
#define EXT4_FEATURE_RO_COMPAT_DIR_NLINK 0x0020
そのため、MR3020は、オペレーティングシステムがext4メタデータチェックサムを処理できないため、ファイルシステムを読み取り/書き込みモードでマウントできませんでした。そのため、USBスティックの作成に使用したLinuxシステムを使用して、この機能をオフにする必要があります。 USBスティックをそのシステムに戻し(ext4ファイルシステムをマウントしないでください)、次のコマンドを実行します。
tune2fs -O^metadata_csum /dev/sdX2
(Xは、LinuxシステムのUSBスティックの実際の識別子に置き換えてください。)
このコマンドを正常に実行すると、USBスティックのext4ファイルシステムでmetadata_csum
機能が無効になり、MR3020がそれを使用できるようになります。
マウント試行はext3とext2のみを試行し、ext4は試行しないようです。カーネルにext4がありますか? (/proc/filesystems
にリストされています。)/dev/sda2
に/etc/fstab
がextとしてリストされている可能性がありますか?
パーティションを作成した後、ext4でフォーマットしましたか?
mkfs.ext4 /dev/sda2
次に、ファイルシステムタイプmount -t ext4 /dev/sda2 /mnt/sda2
を明示的に指定して、マウントまたはext4でのマウントを試みます。