a9523d14c4
This is setting the stage for a cleanup of FPREM and FPREM1 helpers while being sure that they behave same as bare metal. The test constructs operands using combinations of corner cases for the floating-point bitfields and prints operands, result and FPU status word for FPREM and FPREM1. The outputs can then be compared between bare metal and QEMU. The 'run-test-i386-fprem' make target does just that. Signed-off-by: Catalin Patulea <catalinp@google.com> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
159 lines
3.9 KiB
Makefile
159 lines
3.9 KiB
Makefile
-include ../../config-host.mak
|
|
-include $(SRC_PATH)/rules.mak
|
|
|
|
$(call set-vpath, $(SRC_PATH)/tests/tcg)
|
|
|
|
QEMU=../../i386-linux-user/qemu-i386
|
|
QEMU_X86_64=../../x86_64-linux-user/qemu-x86_64
|
|
CC_X86_64=$(CC_I386) -m64
|
|
|
|
QEMU_INCLUDES += -I../..
|
|
CFLAGS=-Wall -O2 -g -fno-strict-aliasing
|
|
#CFLAGS+=-msse2
|
|
LDFLAGS=
|
|
|
|
# TODO: automatically detect ARM and MIPS compilers, and run those too
|
|
|
|
# runcom maps page 0, so it requires root privileges
|
|
# also, pi_10.com runs indefinitely
|
|
|
|
I386_TESTS=hello-i386 \
|
|
linux-test \
|
|
testthread \
|
|
sha1-i386 \
|
|
test-i386 \
|
|
test-i386-fprem \
|
|
test-mmap \
|
|
# runcom
|
|
|
|
# native i386 compilers sometimes are not biarch. assume cross-compilers are
|
|
ifneq ($(ARCH),i386)
|
|
I386_TESTS+=run-test-x86_64
|
|
endif
|
|
|
|
TESTS = test_path
|
|
ifneq ($(call find-in-path, $(CC_I386)),)
|
|
TESTS += $(I386_TESTS)
|
|
endif
|
|
|
|
all: $(patsubst %,run-%,$(TESTS))
|
|
test: all
|
|
|
|
# rules to run tests
|
|
|
|
.PHONY: $(patsubst %,run-%,$(TESTS))
|
|
|
|
run-%: %
|
|
-$(QEMU) ./$*
|
|
|
|
run-hello-i386: hello-i386
|
|
run-linux-test: linux-test
|
|
run-testthread: testthread
|
|
run-sha1-i386: sha1-i386
|
|
|
|
run-test-i386: test-i386
|
|
./test-i386 > test-i386.ref
|
|
-$(QEMU) test-i386 > test-i386.out
|
|
@if diff -u test-i386.ref test-i386.out ; then echo "Auto Test OK"; fi
|
|
|
|
run-test-i386-fprem: test-i386-fprem
|
|
./test-i386-fprem > test-i386-fprem.ref
|
|
-$(QEMU) test-i386-fprem > test-i386-fprem.out
|
|
@if diff -u test-i386-fprem.ref test-i386-fprem.out ; then echo "Auto Test OK"; fi
|
|
|
|
run-test-x86_64: test-x86_64
|
|
./test-x86_64 > test-x86_64.ref
|
|
-$(QEMU_X86_64) test-x86_64 > test-x86_64.out
|
|
@if diff -u test-x86_64.ref test-x86_64.out ; then echo "Auto Test OK"; fi
|
|
|
|
run-test-mmap: test-mmap
|
|
-$(QEMU) ./test-mmap
|
|
-$(QEMU) -p 8192 ./test-mmap 8192
|
|
-$(QEMU) -p 16384 ./test-mmap 16384
|
|
-$(QEMU) -p 32768 ./test-mmap 32768
|
|
|
|
run-runcom: runcom
|
|
-$(QEMU) ./runcom $(SRC_PATH)/tests/pi_10.com
|
|
|
|
run-test_path: test_path
|
|
./test_path
|
|
|
|
# rules to compile tests
|
|
|
|
test_path: test_path.o
|
|
$(CC_I386) $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
|
|
test_path.o: test_path.c
|
|
$(CC_I386) $(QEMU_INCLUDES) $(GLIB_CFLAGS) $(CFLAGS) -c -o $@ $^
|
|
|
|
hello-i386: hello-i386.c
|
|
$(CC_I386) -nostdlib $(CFLAGS) -static $(LDFLAGS) -o $@ $<
|
|
strip $@
|
|
|
|
testthread: testthread.c
|
|
$(CC_I386) $(CFLAGS) $(LDFLAGS) -o $@ $< -lpthread
|
|
|
|
# i386/x86_64 emulation test (test various opcodes) */
|
|
test-i386: test-i386.c test-i386-code16.S test-i386-vm86.S \
|
|
test-i386.h test-i386-shift.h test-i386-muldiv.h
|
|
$(CC_I386) $(QEMU_INCLUDES) $(CFLAGS) $(LDFLAGS) -o $@ \
|
|
$(<D)/test-i386.c $(<D)/test-i386-code16.S $(<D)/test-i386-vm86.S -lm
|
|
|
|
test-i386-fprem: test-i386-fprem.c
|
|
$(CC_I386) $(QEMU_INCLUDES) $(CFLAGS) $(LDFLAGS) -o $@ $^
|
|
|
|
test-x86_64: test-i386.c \
|
|
test-i386.h test-i386-shift.h test-i386-muldiv.h
|
|
$(CC_X86_64) $(QEMU_INCLUDES) $(CFLAGS) $(LDFLAGS) -o $@ $(<D)/test-i386.c -lm
|
|
|
|
# generic Linux and CPU test
|
|
linux-test: linux-test.c
|
|
$(CC_I386) $(CFLAGS) $(LDFLAGS) -o $@ $< -lm
|
|
|
|
# vm86 test
|
|
runcom: runcom.c
|
|
$(CC_I386) $(CFLAGS) $(LDFLAGS) -o $@ $<
|
|
|
|
test-mmap: test-mmap.c
|
|
$(CC_I386) -m32 $(CFLAGS) -Wall -O2 $(LDFLAGS) -o $@ $<
|
|
|
|
# speed test
|
|
sha1-i386: sha1.c
|
|
$(CC_I386) $(CFLAGS) $(LDFLAGS) -o $@ $<
|
|
|
|
sha1: sha1.c
|
|
$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $<
|
|
|
|
speed: sha1 sha1-i386
|
|
time ./sha1
|
|
time $(QEMU) ./sha1-i386
|
|
|
|
# arm test
|
|
hello-arm: hello-arm.o
|
|
arm-linux-ld -o $@ $<
|
|
|
|
hello-arm.o: hello-arm.c
|
|
arm-linux-gcc -Wall -g -O2 -c -o $@ $<
|
|
|
|
test-arm-iwmmxt: test-arm-iwmmxt.s
|
|
cpp < $< | arm-linux-gnu-gcc -Wall -static -march=iwmmxt -mabi=aapcs -x assembler - -o $@
|
|
|
|
# MIPS test
|
|
hello-mips: hello-mips.c
|
|
mips-linux-gnu-gcc -nostdlib -static -mno-abicalls -fno-PIC -mabi=32 -Wall -Wextra -g -O2 -o $@ $<
|
|
|
|
hello-mipsel: hello-mips.c
|
|
mipsel-linux-gnu-gcc -nostdlib -static -mno-abicalls -fno-PIC -mabi=32 -Wall -Wextra -g -O2 -o $@ $<
|
|
|
|
# testsuite for the CRIS port.
|
|
test-cris:
|
|
$(MAKE) -C cris check
|
|
|
|
# testsuite for the LM32 port.
|
|
test-lm32:
|
|
$(MAKE) -C lm32 check
|
|
|
|
clean:
|
|
rm -f *~ *.o test-i386.out test-i386.ref \
|
|
test-x86_64.log test-x86_64.ref qruncom $(TESTS)
|