Re: [kvm-unit-tests PATCH] lib/devicetree: Support 64 bit addresses for the initrd

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Drew,

On Tue, Feb 15, 2022 at 01:53:00PM +0100, Andrew Jones wrote:
> On Tue, Feb 15, 2022 at 10:07:16AM +0000, Alexandru Elisei wrote:
> > 
> > I've started working on the next iteration of the kvmtool test
> > runner support series, I'll do my best to make sure kvmtool wll be able to run
> > the tests when kvm-unit-tests has been configured with --arch=arm.
> >
> 
> Excellent!
> 
> BTW, I went ahead an pushed a patch to misc/queue to improve the initrd
> address stuff
> 
> https://gitlab.com/rhdrjones/kvm-unit-tests/-/commit/6f8f74ed2d9953830a3c74669f25439d9ad68dec
> 
> It may be necessary for you if kvmtool shares its fdt creation between
> aarch64 and aarch32 guests, emitting 8 byte initrd addresses for both,
> even though the aarch32 guest puts the fdt below 4G.

While trying your patch (it works, but with the caveat below), I remembered that
kvmtool is not able to run kvm-unit-tests for arm. That's because the code is
not relocatable (like it is for arm64) and the text address is hardcoded in the
makefile.

In past, to run the arm tests with kvmtool, I was doing this change:

diff --git a/arm/Makefile.arm b/arm/Makefile.arm
index 3a4cc6b26234..6c580b067413 100644
--- a/arm/Makefile.arm
+++ b/arm/Makefile.arm
@@ -14,7 +14,7 @@ CFLAGS += $(machine)
 CFLAGS += -mcpu=$(PROCESSOR)
 CFLAGS += -mno-unaligned-access
 
-arch_LDFLAGS = -Ttext=40010000
+arch_LDFLAGS = -Ttext=80008000
 
 define arch_elf_check =
 endef

Any suggestions how to fix that? One way would be to change the LDFLAGS based on
$TARGET. Another way would be to make the arm tests relocatable, I tried to do
that in the past but I couldn't make any progress.

Separate from that, I also tried to run the 32 bit arm tests with run_tests.sh.
The runner uses qemu-system-arm (because $ARCH_NAME is arm in
scripts/arch-run.bash::search_qemu_binary()), but uses kvm as the accelerator
(because /dev/kvm exists in scrips/arch-run.bash::kvm_available()). This fails
with the error:

qemu-system-arm: -accel kvm: invalid accelerator kvm

I don't think that's supposed to happen, as kvm_available() specifically returns
true if $HOST = aarch64 and $ARCH = arm. Any suggestions?

Thanks,
Alex

> 
> Thanks,
> drew
> 



[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux