1)安装编译器:
sudo apt install gcc-aarch64-linux-gnu
2)构建uboot源码:
make CROSS_COMPILE=aarch64-linux-gnu- qemu_arm64_defconfig
make CROSS_COMPILE=aarch64-linux-gnu- -j4
3)编译设备树:
dtc -I dts -O dtb -o virt-gicv3.dtb virt-gicv3.dts
4)编译xen:
cd stout_xen
XEN_TARGET_ARCH=arm64 ./configure
启动调试选项:
cd xen
make menuconfig XEN_TARGET_ARCH=arm64
Debugging Options --->
[*] Developer Checks
[*] Early printk (Early printk via PL011 UART) ---> │ │
│ │ (0x9000000) Early printk, physical base address of debug UART
编译xen:
cd ../
make xen XEN_TARGET_ARCH=arm64 CROSS_COMPILE=aarch64-linux-gnu- debug=y -j4
制作Xen uImage镜像:
mkimage -A arm -T kernel -a 0x40200000 -e 0x40200000 -C none -d xen/xen xen/xen-uImage
5)在qemu上运行xen
u-boot启动xen:
qemu-system-aarch64 -machine virt -machine virtualization=true -cpu cortex-a57 -machine type=virt -m 2048 -smp 4 -bios u-boot.bin -device loader,file=xen,force-raw=on,addr=0x40200000 -device loader,file=virt-gicv3.dtb,addr=0x44000000 -nographic
U-Boot 2019.10-dirty (Feb 09 2022 - 22:58:16 -0800)
DRAM: 2 GiB
Flash: 128 MiB
*** Warning - bad CRC, using default environment
In: pl011@9000000
Out: pl011@9000000
Err: pl011@9000000
Net: No ethernet found.
Hit any key to stop autoboot: 0
=> booti 0x40200000 - 0x44000000
跳转至xen启动地址:
booti 0x40200000 - 0x44000000
U-Boot 2019.10-dirty (Feb 09 2022 - 22:58:16 -0800)
DRAM: 2 GiB
Flash: 128 MiB
*** Warning - bad CRC, using default environment
In: pl011@9000000
Out: pl011@9000000
Err: pl011@9000000
Net: No ethernet found.
Hit any key to stop autoboot: 0
=> booti 0x40200000 - 0x44000000
## Flattened Device Tree blob at 44000000
Booting using the fdt blob at 0x44000000
Loading Device Tree to 00000000bedf7000, end 00000000bedfbdc1 ... OK
Starting kernel ...
- UART enabled -
- Boot CPU booting -
- Current EL 00000008 -
- Initialize CPU -
- Turning on paging -
- Zero BSS -
- Ready -
(XEN) Checking for initrd in /chosen
(XEN) RAM: 0000000040000000 - 00000000bfffffff
(XEN)
(XEN) MODULE[0]: 0000000040200000 - 000000004034f4c8 Xen
(XEN) MODULE[1]: 00000000bedf7000 - 00000000bedf9000 Device Tree
(XEN)
(XEN)
(XEN) Command line: <NULL>
(XEN) Domain heap initialised
(XEN) Booting using Device Tree
(XEN) Platform: Generic System
(XEN) Taking dtuart configuration from /chosen/stdout-path
(XEN) Looking for dtuart at "/pl011@9000000", options ""
Xen 4.16-unstable
(XEN) Xen version 4.16-unstable (hdwei@) (aarch64-linux-gnu-gcc (Linaro GCC 7.2-2017.11) 7.2.1 20171011) debug=y Wed Feb 9 23:53:24 PST 2022
(XEN) Latest ChangeSet: Fri Aug 20 16:18:12 2021 +0200 git:93713f4
(XEN) build-id: 1a5fd87d208b92a49b47ac8ba1c71310357b8edc
(XEN) Processor: 00000000411fd070: "ARM Limited", variant: 0x1, part 0xd07,rev 0x0
(XEN) 64-bit Execution:
(XEN) Processor Features: 0000000000000222 0000000000000000
(XEN) Exception Levels: EL3:No EL2:64+32 EL1:64+32 EL0:64+32
(XEN) Extensions: FloatingPoint AdvancedSIMD
(XEN) Debug Features: 0000000010305106 0000000000000000
(XEN) Auxiliary Features: 0000000000000000 0000000000000000
(XEN) Memory Model Features: 0000000000001124 0000000000000000
(XEN) ISA Features: 0000000000011120 0000000000000000
(XEN) 32-bit Execution:
(XEN) Processor Features: 0000000000000131:0000000000011001
(XEN) Instruction Sets: AArch32 A32 Thumb Thumb-2 Jazelle
(XEN) Extensions: GenericTimer
(XEN) Debug Features: 0000000003010066
(XEN) Auxiliary Features: 0000000000000000
(XEN) Memory Model Features: 0000000010101105 0000000040000000
(XEN) 0000000001260000 0000000002102211
(XEN) ISA Features: 0000000002101110 0000000013112111 0000000021232042
(XEN) 0000000001112131 0000000000011142 0000000000011121
(XEN) Using SMC Calling Convention v1.0
(XEN) Using PSCI v0.2
(XEN) SMP: Allowing 4 CPUs
(XEN) enabled workaround for: ARM erratum 832075
(XEN) enabled workaround for: ARM erratum 834220
(XEN) enabled workaround for: ARM erratum 1319367
(XEN) Generic Timer IRQ: phys=30 hyp=26 virt=27 Freq: 62500 KHz
(XEN) gic-v3.c:1763: GICv3: driver requires system register support
(XEN)
(XEN) ****************************************
(XEN) Panic on CPU 0:
(XEN) Failed to initialize the GIC drivers
(XEN) ****************************************
(XEN)
(XEN) Reboot in five seconds...