フォローしていますこのチュートリアルしかし、ステップ 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
答え1
エラー メッセージは次の行から発生します<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 です。これは、定数によって識別される機能の 1 つです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 スティックの実際の識別子に置き換えます。)
このコマンドを正常に実行すると、metadata_csum
USB スティックの ext4 ファイルシステムで機能が無効になり、MR3020 で使用できるようになります。
答え2
マウント試行は ext3 と ext2 のみで、ext4 は試行されないようです。カーネルに ext4 は含まれていますか? ( に記載されています。)次のように記載されて/proc/filesystems
いる可能性があります。/dev/sda2
/etc/fstab
拡張子3?
答え3
私も TL-MR3020 v3 でこの問題が発生しましたが、ext4 ではなく ext3 パーティションを作成することで解決し、ドライブを正常にマウントできました。
これは私が実行した手順です (OpenWRT Web サイトの手順に従い、ext4 を ext3 に置き換えただけです)。
root@OpenWrt:~# mkfs.ext3 /dev/sda1
mke2fs 1.44.5 (15-Dec-2018)
/dev/sda1 contains a ext4 file system
created on Sun Sep 27 06:13:56 2020
Proceed anyway? (y,N) y
Creating filesystem with 511744 4k blocks and 128000 inodes
Filesystem UUID: 2bbb533d-925f-43fb-946a-4190fe612186
Superblock backups stored on blocks:
32768, 98304, 163840, 229376, 294912
Allocating group tables: done
Writing inode tables: done
Creating journal (8192 blocks): done
Writing superblocks and filesystem accounting information: done
root@OpenWrt:~# block detect | uci import fstab
root@OpenWrt:~# uci set fstab.@mount[0].enabled='1' && uci set fstab.@global[0].anon_mount='1' && uci commit fstab
root@OpenWrt:~# /etc/init.d/fstab boot
root@OpenWrt:~# df -h
Filesystem Size Used Available Use% Mounted on
/dev/root 2.5M 2.5M 0 100% /rom
tmpfs 29.3M 1.1M 28.2M 4% /tmp
/dev/mtdblock4 3.8M 1.2M 2.5M 33% /overlay
overlayfs:/overlay 3.8M 1.2M 2.5M 33% /
tmpfs 512.0K 0 512.0K 0% /dev
/dev/sda1 1.9G 3.0M 1.8G 0% /mnt/sda1
root@OpenWrt:~#
これは古い質問だとは思いますが、誰かの役に立つかもしれません
答え4
パーティションを作成した後、ext4 でフォーマットしましたか?
mkfs.ext4 /dev/sda2
次に、ファイルシステムの種類を明示的に指定してマウントするか、ext4でマウントしてみてください。mount -t ext4 /dev/sda2 /mnt/sda2