编译了Ubuntu20.04的源码成功烧录后,出现问题:不断重启。内核日志输出如下:
[ 3.903443] No filesystem could mount root, tried:
[ 3.903446] ext3
[ 3.903450] ext2
[ 3.903455] ext4
[ 3.903459] squashfs
[ 3.903463] vfat
[ 3.903468] iso9660
[ 3.903472] ntfs
[ 3.903477] fuseblk
[ 3.903481] xfs
[ 3.903485] btrfs
[ 3.903489]
[ 3.903498] Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(179,6)
[ 3.921350] CPU: 2 PID: 1 Comm: swapper/0 Not tainted 5.10.66 #4
[ 3.921881] Hardware name: Rockchip RK3588 IR88MX01 LP4X V10 Board (DT)
[ 3.922468] Call trace:
[ 3.922694] dump_backtrace+0x0/0x1e4
[ 3.923027] show_stack+0x24/0x30
[ 3.923329] dump_stack_lvl+0xd4/0x124
[ 3.923661] dump_stack+0x18/0x3c
[ 3.923959] panic+0x15c/0x384
[ 3.924238] mount_block_root+0x150/0x1ec
[ 3.924592] handle_initrd+0x70/0x1f8
[ 3.924924] initrd_load+0x60/0x84
[ 3.925233] prepare_namespace+0x58/0x1a4
[ 3.925587] kernel_init_freeable+0x134/0x168
[ 3.925974] kernel_init+0x20/0x118
[ 3.926283] ret_from_fork+0x10/0x30
查看编译信息,原因是cpio命令没有,但是./edge build -k编译内核命令还是编译过了,导致recovery.img生成不正常,大小为31M,正常情况下为61M
[EDGE DEBUG] Start boot image ...
[EDGE DEBUG] ./make_initrd.sh arm64
./make_initrd.sh: line 7: cpio: command not found
/root/rk3588-edge/rootfs/debian/initrd
[EDGE DEBUG] /root/rk3588-edge/rkbin/tools/mkimage -f /root/rk3588-edge/out/rk3588/RK3588-IR88MX01/images/boot_its -E -p 0x1000 /root/rk3588-edge/out/rk3588/RK3588-IR88MX01/images/recovery.img
解决方法安装cpio
apt install cpio
然后再编译内核
./edge build -k