Cannot reserve memory for camkes VM guest
Hi All, I'm trying to bring up camkes VM Linux guest on Firefly RK3399 board which is with a GICv3 ARMv8. I'm using the "rockpro64" target and my work is based on [1] and [2]. When I run the "capdl-loader-image-arm-rockpro64", there's error "Range not available at 0xfef10000, size 0x10000". Bootstrapping kernel Booting all finished, dropped to user space Undelivered IRQ: 132 Install gic v3 sel4utils_reserve_range_at_no_alloc@vspace.c:595 Range not available at 0xfef10000, size 0x10000 vm_reserve_memory_at@guest_memory.c:328 Failed to allocate vm reservation: Unable to create vspace reservation at address 0xfef10000 of size 65536 vm_install_vgic_v3@vgic_v3.c:87 Error installing vgic Assertion failed: !err (/mnt/data3/projects/rk3399/build/seL4/camkes-vm-app/projects/vm/components/VM_Arm/src/main.c: main_continued: 1098) Here's my projects/seL4_projects_libs/libsel4vmmplatsupport/plat_include/rockpro64/sel4vmmplatsupport/plat/devices.h content: #define GIC_VERSION_3 #define GIC_PADDR 0xfee00000 #define GIC_DIST_PADDR (GIC_PADDR + 0x00000000) #define GIC_DIST_SIZE 0x10000 #define GIC_REDIST_PADDR 0xfef00000 #define GIC_REDIST_SIZE 0xC0000 #define GIC_REDIST_SGI_PADDR (GIC_REDIST_PADDR + 0x00010000) #define GIC_REDIST_SGI_SIZE 0x10000 I think the problem is related to GIC_REDIST_SIZE. I set it to 0xC0000 according to the rockpro64 device tree file in kernel/tools/dts/rockpro64.dts interrupt-controller@fee00000 { compatible = "arm,gic-v3"; #interrupt-cells = < 0x04 >; #address-cells = < 0x02 >; #size-cells = < 0x02 >; ranges; interrupt-controller; reg = < 0x00 0xfee00000 0x00 0x10000 0x00 0xfef00000 0x00 0xc0000 0x00 0xfff00000 0x00 0x10000 0x00 0xfff10000 0x00 0x10000 0x00 0xfff20000 0x00 0x10000 >; interrupts = < 0x01 0x09 0x04 0x00 >; phandle = < 0x01 >; I tried to reduce it to 0x10000 and it can boot to VM guest but the guest Linux will fail in gic_iterate_rdists() because it cannot read from GIC's GICR_TYPER register correctly. Did I miss anything? Any suggestion is highly appreciated. Thank you very much! [1] https://github.com/seL4/seL4/pull/378 [2] https://github.com/seL4/seL4_projects_libs/tree/sylvain/gicv3 Regards, Alex
Hello Alex, What is GIC_REDIST_SGI_PADDR? The VMM emulates GICD and GICR (per core). If my memory serves right, the Linux kernel code looks for an end flag when scanning the GICR region, that is probably why the scan fails if you change the size. I suggest you start with single core and trim the device tree to just include serial, timer, GIC, memory, and core nodes. Regards, Yanyan From: Alex Ling via Devel<mailto:devel@sel4.systems> Sent: Friday, 16 July 2021 10:16 PM To: devel@sel4.systems<mailto:devel@sel4.systems> Subject: [seL4] Cannot reserve memory for camkes VM guest Hi All, I'm trying to bring up camkes VM Linux guest on Firefly RK3399 board which is with a GICv3 ARMv8. I'm using the "rockpro64" target and my work is based on [1] and [2]. When I run the "capdl-loader-image-arm-rockpro64", there's error "Range not available at 0xfef10000, size 0x10000". Bootstrapping kernel Booting all finished, dropped to user space Undelivered IRQ: 132 Install gic v3 sel4utils_reserve_range_at_no_alloc@vspace.c:595 Range not available at 0xfef10000, size 0x10000 vm_reserve_memory_at@guest_memory.c:328 Failed to allocate vm reservation: Unable to create vspace reservation at address 0xfef10000 of size 65536 vm_install_vgic_v3@vgic_v3.c:87 Error installing vgic Assertion failed: !err (/mnt/data3/projects/rk3399/build/seL4/camkes-vm-app/projects/vm/components/VM_Arm/src/main.c: main_continued: 1098) Here's my projects/seL4_projects_libs/libsel4vmmplatsupport/plat_include/rockpro64/sel4vmmplatsupport/plat/devices.h content: #define GIC_VERSION_3 #define GIC_PADDR 0xfee00000 #define GIC_DIST_PADDR (GIC_PADDR + 0x00000000) #define GIC_DIST_SIZE 0x10000 #define GIC_REDIST_PADDR 0xfef00000 #define GIC_REDIST_SIZE 0xC0000 #define GIC_REDIST_SGI_PADDR (GIC_REDIST_PADDR + 0x00010000) #define GIC_REDIST_SGI_SIZE 0x10000 I think the problem is related to GIC_REDIST_SIZE. I set it to 0xC0000 according to the rockpro64 device tree file in kernel/tools/dts/rockpro64.dts interrupt-controller@fee00000 { compatible = "arm,gic-v3"; #interrupt-cells = < 0x04 >; #address-cells = < 0x02 >; #size-cells = < 0x02 >; ranges; interrupt-controller; reg = < 0x00 0xfee00000 0x00 0x10000 0x00 0xfef00000 0x00 0xc0000 0x00 0xfff00000 0x00 0x10000 0x00 0xfff10000 0x00 0x10000 0x00 0xfff20000 0x00 0x10000 >; interrupts = < 0x01 0x09 0x04 0x00 >; phandle = < 0x01 >; I tried to reduce it to 0x10000 and it can boot to VM guest but the guest Linux will fail in gic_iterate_rdists() because it cannot read from GIC's GICR_TYPER register correctly. Did I miss anything? Any suggestion is highly appreciated. Thank you very much! [1] https://github.com/seL4/seL4/pull/378 [2] https://github.com/seL4/seL4_projects_libs/tree/sylvain/gicv3 Regards, Alex _______________________________________________ Devel mailing list -- devel@sel4.systems To unsubscribe send an email to devel-leave@sel4.systems
Hi Yanyan, Thanks for your reply. I've already used only 1 core and a minimal device tree. Here's my apps/Arm/vm_minimal/rockpro64/devices.camkes: #include <configurations/vm.h> #define VM_INITRD_MAX_SIZE 0x1900000 //25 MB #define VM_RAM_BASE 0xb0000000 #define VM_RAM_SIZE 0x10000000 #define VM_RAM_OFFSET 0 #define VM_DTB_ADDR 0xbf000000 //(LINUX_RAM_BASE + 0x0f000000) #define VM_INITRD_ADDR 0xbd700000 // DTB_ADDR - INITRD_MAX_SIZE assembly { composition {} configuration { vm0.linux_address_config = { "linux_ram_base" : VAR_STRINGIZE(VM_RAM_BASE), "linux_ram_paddr_base" : VAR_STRINGIZE(VM_RAM_BASE), "linux_ram_size" : VAR_STRINGIZE(VM_RAM_SIZE), "linux_ram_offset" : VAR_STRINGIZE(VM_RAM_OFFSET), "dtb_addr" : VAR_STRINGIZE(VM_DTB_ADDR), "initrd_max_size" : VAR_STRINGIZE(VM_INITRD_MAX_SIZE), "initrd_addr" : VAR_STRINGIZE(VM_INITRD_ADDR) }; vm0.linux_image_config = { "linux_bootcmdline" : "earlycon=uart8250,mmio32,0xff1a0000 earlyprintk=serial,ttyS2,1500000 debug loglevel=8 console=ttyS2,1500000", "linux_stdout" : "serial2:1500000n8", }; vm0.num_vcpus = 1; vm0.dtb = dtb([ {"path": "/serial@ff1a0000"}, ]); vm0.untyped_mmios = ["0xfff20000:16", // Interrupt Controller Virtual CPU interface (Virtual Machine view) "0xb0000000:27"]; /* vm0.irqs = [27]; // INTERRUPT_VTIMER */ } } My components/VM_Arm/plat_include/rockpro64/plat/vmlinux.h: #define LINUX_RAM_BASE 0xb0000000 #define LINUX_RAM_PADDR_BASE LINUX_RAM_BASE #define LINUX_RAM_SIZE 0x10000000 #define PLAT_RAM_END 0xc0000000 #define LINUX_RAM_OFFSET 0 #define DTB_ADDR 0xbf000000 #define INITRD_MAX_SIZE 0x1900000 //25 MB #define INITRD_ADDR (DTB_ADDR - INITRD_MAX_SIZE) //0xBD700000 #define IRQ_SPI_OFFSET 32 #define GIC_IRQ_PHANDLE 0x01 static const int linux_pt_irqs[] = { /*27, // VTCNT */ }; static const int free_plat_interrupts[] = { 50 + IRQ_SPI_OFFSET }; static const char *plat_keep_devices[] = { "/timer", "/xin24m", "/amba", "/pmu_a53", "/pmu_a72", "/psci", }; static const char *plat_keep_device_and_disable[] = {}; static const char *plat_keep_device_and_subtree[] = { "/interrupt-controller@fee00000", }; static const char *plat_keep_device_and_subtree_and_disable[] = {}; GIC_REDIST_SGI_PADDR is introduced in a GICv3 virtualization support code change at https://github.com/seL4/seL4_projects_libs/commit/143d48c0f99d3e35a9fd27deb7.... Do you know what does the error "sel4utils_reserve_range_at_no_alloc@vspace.c:595 Range not available at 0xfef10000, size 0x10000" mean? Thanks. Regards, Alex
participants (2)
-
Alex Ling
-
Yanyan Shen