tech-kern archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
Support for ramdisks in PVH boot
Hi tech-kern@,
This post is related to iMil's recent work on PVH support for NetBSD/amd64.
I was unable to use his work to boot on ramdisks directly with QEMU's -
initrd flag, when using -kernel.
Well after a deep dive into it, I think I am almost there:
https://git.edgebsd.org/gitweb/?
p=src.git;a=commitdiff;h=629621f41089af50584214a4d32b50ae8ee414f2
This patch:
- extends sys/arch/amd64/amd64/genassym.cf for additional knowledge of
Xen's hvm_start_info (notably nr_modules and modlist_paddr)
- extends .start_genpvh in locore.S to copy the module entries, and their
respective command lines and contents
- teaches x86_machdep.c to load Xen modules when a VM_GUEST_GENPVH guest
The code is not working yet unfortunately.
On an Intel-macOS host:
$ qemu-system-x86_64 -m 512 -accel hvf -cpu host -display none -serial \
stdio -kernel netbsd-GENERIC -initrd ramdisk-cgdroot.fs -append \
"console=com rw -v" -action reboot=shutdown -D qemu.log -d \
cpu_reset,in_asm,guest_errors,unimp -drive \
file=ld0.img,format=raw,if=virtio
[...]
[ 4.5370781] boot device: ld0
[ 4.5370781] md0: internal 5000 KB image area
[ 4.5370781] root on md0a dumps on md0b
[ 4.5370781] uvm_fault(0xffffffff81912da0, 0xffffffff9faf8000, 1) -> e
[ 4.5370781] fatal page fault in supervisor mode
[ 4.5370781] trap type 6 code 0 rip 0xffffffff80ff3274 cs 0x8 rflags
0x10206 cr2 0xffffffff9faf8ff8 ilevel 0 rsp 0xffffffff81a07c38
[ 4.5484101] curlwp 0xffffffff8188bfc0 pid 0.0 lowest kstack
0xffffffff81a022c0
kernel: page fault trap, code=0
Stopped in pid 0.0 (system) at ffffffff80ff3274: movq
fffffffffffffff8
(%rsi,%rdx,1),%r10
It seems to fail in bdev_strategy(); as of right now I do not know why.
I suspect my assembly code in locore.S to need review in particular.
Therefore: your help in completing this is very welcome.
Cheers & HTH,
--
khorben
Home |
Main Index |
Thread Index |
Old Index