selftests/nolibc: add test support for ppc64le
Kernel uses ARCH=powerpc for both 32-bit and 64-bit PowerPC, here adds a ppc64le variant for little endian 64-bit PowerPC, users can pass XARCH=ppc64le to test it. The powernv machine of qemu-system-ppc64le is used for there is just a working powernv_defconfig. As the document [1] shows: PowerNV (as Non-Virtualized) is the “bare metal” platform using the OPAL firmware. It runs Linux on IBM and OpenPOWER systems and it can be used as an hypervisor OS, running KVM guests, or simply as a host OS. Notes, - since the VSX support may be disabled in kernel side, to avoid "illegal instruction" errors due to missing VSX kernel support, let's simply let compiler not generate vector/scalar (VSX) instructions via the '-mno-vsx' option. - little endian ppc64 prefers elfv2 to elfv1 if the toolchain (e.g. gcc 13.1.0) supports it, let's align with kernel, otherwise, our elfv1 binary will not run on kernel with elfv2 ABI. [1]: https://qemu.readthedocs.io/en/latest/system/ppc/powernv.html Suggested-by: Willy Tarreau <w@1wt.eu> Link: https://lore.kernel.org/lkml/20230722120747.GC17311@1wt.eu/ Reviewed-by: Thomas Weißschuh <linux@weissschuh.net> Signed-off-by: Zhangjin Wu <falcon@tinylab.org> Signed-off-by: Willy Tarreau <w@1wt.eu>
This commit is contained in:
parent
587e984591
commit
8a5040cb3f
@ -35,6 +35,7 @@ XARCH = $(or $(XARCH_$(ARCH)),$(ARCH))
|
|||||||
|
|
||||||
# map from user input variants to their kernel supported architectures
|
# map from user input variants to their kernel supported architectures
|
||||||
ARCH_ppc = powerpc
|
ARCH_ppc = powerpc
|
||||||
|
ARCH_ppc64le = powerpc
|
||||||
ARCH := $(or $(ARCH_$(XARCH)),$(XARCH))
|
ARCH := $(or $(ARCH_$(XARCH)),$(XARCH))
|
||||||
|
|
||||||
# kernel image names by architecture
|
# kernel image names by architecture
|
||||||
@ -45,6 +46,7 @@ IMAGE_arm64 = arch/arm64/boot/Image
|
|||||||
IMAGE_arm = arch/arm/boot/zImage
|
IMAGE_arm = arch/arm/boot/zImage
|
||||||
IMAGE_mips = vmlinuz
|
IMAGE_mips = vmlinuz
|
||||||
IMAGE_ppc = vmlinux
|
IMAGE_ppc = vmlinux
|
||||||
|
IMAGE_ppc64le = arch/powerpc/boot/zImage
|
||||||
IMAGE_riscv = arch/riscv/boot/Image
|
IMAGE_riscv = arch/riscv/boot/Image
|
||||||
IMAGE_s390 = arch/s390/boot/bzImage
|
IMAGE_s390 = arch/s390/boot/bzImage
|
||||||
IMAGE_loongarch = arch/loongarch/boot/vmlinuz.efi
|
IMAGE_loongarch = arch/loongarch/boot/vmlinuz.efi
|
||||||
@ -59,6 +61,7 @@ DEFCONFIG_arm64 = defconfig
|
|||||||
DEFCONFIG_arm = multi_v7_defconfig
|
DEFCONFIG_arm = multi_v7_defconfig
|
||||||
DEFCONFIG_mips = malta_defconfig
|
DEFCONFIG_mips = malta_defconfig
|
||||||
DEFCONFIG_ppc = pmac32_defconfig
|
DEFCONFIG_ppc = pmac32_defconfig
|
||||||
|
DEFCONFIG_ppc64le = powernv_defconfig
|
||||||
DEFCONFIG_riscv = defconfig
|
DEFCONFIG_riscv = defconfig
|
||||||
DEFCONFIG_s390 = defconfig
|
DEFCONFIG_s390 = defconfig
|
||||||
DEFCONFIG_loongarch = defconfig
|
DEFCONFIG_loongarch = defconfig
|
||||||
@ -75,6 +78,7 @@ QEMU_ARCH_arm64 = aarch64
|
|||||||
QEMU_ARCH_arm = arm
|
QEMU_ARCH_arm = arm
|
||||||
QEMU_ARCH_mips = mipsel # works with malta_defconfig
|
QEMU_ARCH_mips = mipsel # works with malta_defconfig
|
||||||
QEMU_ARCH_ppc = ppc
|
QEMU_ARCH_ppc = ppc
|
||||||
|
QEMU_ARCH_ppc64le = ppc64le
|
||||||
QEMU_ARCH_riscv = riscv64
|
QEMU_ARCH_riscv = riscv64
|
||||||
QEMU_ARCH_s390 = s390x
|
QEMU_ARCH_s390 = s390x
|
||||||
QEMU_ARCH_loongarch = loongarch64
|
QEMU_ARCH_loongarch = loongarch64
|
||||||
@ -88,6 +92,7 @@ QEMU_ARGS_arm64 = -M virt -cpu cortex-a53 -append "panic=-1 $(TEST:%=NOLIBC
|
|||||||
QEMU_ARGS_arm = -M virt -append "panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
QEMU_ARGS_arm = -M virt -append "panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
||||||
QEMU_ARGS_mips = -M malta -append "panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
QEMU_ARGS_mips = -M malta -append "panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
||||||
QEMU_ARGS_ppc = -M g3beige -append "console=ttyS0 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
QEMU_ARGS_ppc = -M g3beige -append "console=ttyS0 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
||||||
|
QEMU_ARGS_ppc64le = -M powernv -append "console=hvc0 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
||||||
QEMU_ARGS_riscv = -M virt -append "console=ttyS0 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
QEMU_ARGS_riscv = -M virt -append "console=ttyS0 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
||||||
QEMU_ARGS_s390 = -M s390-ccw-virtio -m 1G -append "console=ttyS0 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
QEMU_ARGS_s390 = -M s390-ccw-virtio -m 1G -append "console=ttyS0 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
||||||
QEMU_ARGS_loongarch = -M virt -append "console=ttyS0,115200 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
QEMU_ARGS_loongarch = -M virt -append "console=ttyS0,115200 panic=-1 $(TEST:%=NOLIBC_TEST=%)"
|
||||||
@ -104,6 +109,7 @@ Q=@
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
CFLAGS_ppc = -m32 -mbig-endian -mno-vsx $(call cc-option,-mmultiple)
|
CFLAGS_ppc = -m32 -mbig-endian -mno-vsx $(call cc-option,-mmultiple)
|
||||||
|
CFLAGS_ppc64le = -m64 -mlittle-endian -mno-vsx $(call cc-option,-mabi=elfv2)
|
||||||
CFLAGS_s390 = -m64
|
CFLAGS_s390 = -m64
|
||||||
CFLAGS_mips = -EL
|
CFLAGS_mips = -EL
|
||||||
CFLAGS_STACKPROTECTOR ?= $(call cc-option,-mstack-protector-guard=global $(call cc-option,-fstack-protector-all))
|
CFLAGS_STACKPROTECTOR ?= $(call cc-option,-mstack-protector-guard=global $(call cc-option,-fstack-protector-all))
|
||||||
|
Loading…
Reference in New Issue
Block a user