qemu

FORK: QEMU emulator
git clone https://git.neptards.moe/neptards/qemu.git
Log | Files | Refs | Submodules | LICENSE

Makefile.target (2309B)


      1 # -*- Mode: makefile -*-
      2 #
      3 # ARM - included from tests/tcg/Makefile
      4 #
      5 
      6 ARM_SRC=$(SRC_PATH)/tests/tcg/arm
      7 
      8 # Set search path for all sources
      9 VPATH 		+= $(ARM_SRC)
     10 
     11 float_madds: CFLAGS+=-mfpu=neon-vfpv4
     12 
     13 # Basic Hello World
     14 ARM_TESTS = hello-arm
     15 hello-arm: CFLAGS+=-marm -ffreestanding
     16 hello-arm: LDFLAGS+=-nostdlib
     17 
     18 # IWMXT floating point extensions
     19 ARM_TESTS += test-arm-iwmmxt
     20 test-arm-iwmmxt: CFLAGS+=-marm -march=iwmmxt -mabi=aapcs -mfpu=fpv4-sp-d16
     21 test-arm-iwmmxt: test-arm-iwmmxt.S
     22 	$(CC) $(CFLAGS) $< -o $@ $(LDFLAGS)
     23 
     24 # Float-convert Tests
     25 ARM_TESTS += fcvt
     26 fcvt: LDFLAGS+=-lm
     27 # fcvt: CFLAGS+=-march=armv8.2-a+fp16 -mfpu=neon-fp-armv8
     28 run-fcvt: fcvt
     29 	$(call run-test,fcvt,$(QEMU) $<)
     30 	$(call diff-out,fcvt,$(ARM_SRC)/fcvt.ref)
     31 
     32 # PC alignment test
     33 ARM_TESTS += pcalign-a32
     34 pcalign-a32: CFLAGS+=-marm
     35 
     36 ifeq ($(CONFIG_ARM_COMPATIBLE_SEMIHOSTING),y)
     37 
     38 # Semihosting smoke test for linux-user
     39 semihosting: CFLAGS += -mthumb
     40 
     41 ARM_TESTS += semihosting-arm
     42 semihosting-arm: CFLAGS += -marm -I$(SRC_PATH)/tests/tcg/$(TARGET_NAME)
     43 semihosting-arm: semihosting.c
     44 	$(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS)
     45 
     46 run-semihosting-arm: semihosting-arm
     47 	$(call run-test,$<,$(QEMU) $< 2> $<.err)
     48 
     49 run-plugin-semihosting-arm-with-%:
     50 	$(call run-test, $@, $(QEMU) $(QEMU_OPTS) \
     51 		-plugin $(PLUGIN_LIB)/$(call extract-plugin,$@) \
     52 		 $(call strip-plugin,$<) 2> $<.err)
     53 
     54 ARM_TESTS += semiconsole-arm
     55 
     56 semiconsole: CFLAGS += -mthumb
     57 
     58 semiconsole-arm: CFLAGS += -marm -I$(SRC_PATH)/tests/tcg/$(TARGET_NAME)
     59 semiconsole-arm: semihosting.c
     60 	$(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS)
     61 
     62 run-semiconsole-arm: semiconsole-arm
     63 	$(call skip-test, $<, "MANUAL ONLY")
     64 
     65 run-plugin-semiconsole-arm-with-%:
     66 	$(call skip-test, $<, "MANUAL ONLY")
     67 
     68 endif
     69 
     70 ARM_TESTS += commpage
     71 
     72 # Vector SHA1
     73 sha1-vector: CFLAGS=-O3
     74 sha1-vector: sha1.c
     75 	$(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS)
     76 run-sha1-vector: sha1-vector run-sha1
     77 	$(call run-test, $<, $(QEMU) $(QEMU_OPTS) $<)
     78 	$(call diff-out, sha1-vector, sha1.out)
     79 
     80 ARM_TESTS += sha1-vector
     81 
     82 # Vector versions of sha512 (-O3 triggers vectorisation)
     83 sha512-vector: CFLAGS=-O3
     84 sha512-vector: sha512.c
     85 	$(CC) $(CFLAGS) $(EXTRA_CFLAGS) $< -o $@ $(LDFLAGS)
     86 
     87 ARM_TESTS += sha512-vector
     88 
     89 TESTS += $(ARM_TESTS)
     90 
     91 # On ARM Linux only supports 4k pages
     92 EXTRA_RUNS+=run-test-mmap-4096