我是qemu的新手,我正在尝试学习内核编程,我创建了一个忙碌的initrd,但是当我在cpio中添加一个大的tarbal~80Mb时,qemu无法加载。
我想在ind中包含golang,以便我可以测试新内核。
这就是发生的事情:
mfrw@kp ~/os/busybox/test_build
% ls
bin linuxrc sbin usr
mfrw@kp ~/os/busybox/test_build
% !find
find . | cpio -o -H newc | gzip > rootfs_bb.gz
cpio: File ./rootfs_bb.gz grew, 1261568 new bytes not copied
7374 blocks
mfrw@kp ~/os/busybox/test_build
% ls -ltrh
total 2.6M
drwxr-xr-x 2 mfrw mfrw 4.0K Mar 18 01:56 bin
lrwxrwxrwx 1 mfrw mfrw 11 Mar 18 01:56 linuxrc -> bin/busybox
drwxr-xr-x 2 mfrw mfrw 4.0K Mar 18 01:56 sbin
drwxr-xr-x 4 mfrw mfrw 4.0K Mar 18 15:24 usr
-rw-r--r-- 1 mfrw mfrw 2.6M Mar 18 15:31 rootfs_bb.gz
mfrw@kp ~/os/busybox/test_build
%
然后我使用qemu和一个rootfs = 2.6 M
的新制作的内核运行它mfrw@kp ~/os/linux_staging % qemu-system-x86_64 -nographic -no-reboot -kernel arch/x86/boot/bzImage -initrd ./../busybox/test_build/rootfs_bb.gz -append "panic=1 console=ttyS0 rdinit=/bin/sh"
[ 0.000000] Linux version 4.11.0-rc2+ (mfrw@kp) (gcc version 6.3.1 20170109 (GCC) ) #7 SMP Sat Mar 18 02:34:27 IST 2017
[ 0.000000] Command line: panic=1 console=ttyS0 rdinit=/bin/sh
[ 0.000000] x86/fpu: x87 FPU will use FXSAVE
[ 0.000000] e820: BIOS-provided physical RAM map:
[ 0.000000] BIOS-e820: [mem 0x0000000000000000-0x000000000009fbff] usable
...... the kernel boots fine
但是当我在rootfs中包含golang的tar.gz时,它会高达80M,然后无法启动
mfrw@kp ~/os/busybox/test_build
% cp ~/go/go1.6.linux-amd64.tar.gz usr
mfrw@kp ~/os/busybox/test_build
% !fin
find . | cpio -o -H newc | gzip > rootfs_bb.gz
170406 blocks
mfrw@kp ~/os/busybox/test_build
% ls -ltrh
total 82M
drwxr-xr-x 2 mfrw mfrw 4.0K Mar 18 01:56 bin
lrwxrwxrwx 1 mfrw mfrw 11 Mar 18 01:56 linuxrc -> bin/busybox
drwxr-xr-x 2 mfrw mfrw 4.0K Mar 18 01:56 sbin
drwxr-xr-x 4 mfrw mfrw 4.0K Mar 18 15:34 usr
-rw-r--r-- 1 mfrw mfrw 82M Mar 18 15:34 rootfs_bb.gz
mfrw@kp ~/os/busybox/test_build
%
我尝试使用相同的命令运行它,但无法运行...
mfrw@kp ~/os/linux_staging % qemu-system-x86_64 -nographic -no-reboot -kernel arch/x86/boot/bzImage -initrd ./../busybox/test_build/rootfs_bb.gz -append "panic=1 console=ttyS0 rdinit=/bin/sh"
.... no .. output
我做错了什么?请指点:)
答案 0 :(得分:0)
我终于找到了解决方案,没有给它足够的内存,所以它失败了。 我终于用
运行了它-m size = 512
它运行良好