xref: /kvm-unit-tests/arm/Makefile.common (revision b36f35a82ff4cec5f71a68aa782332e2bc3488f7)
1#
2# arm common makefile
3#
4# Authors: Andrew Jones <drjones@redhat.com>
5#
6
7tests-common  = $(TEST_DIR)/selftest.flat
8tests-common += $(TEST_DIR)/spinlock-test.flat
9tests-common += $(TEST_DIR)/pci-test.flat
10tests-common += $(TEST_DIR)/pmu.flat
11tests-common += $(TEST_DIR)/gic.flat
12tests-common += $(TEST_DIR)/psci.flat
13tests-common += $(TEST_DIR)/sieve.flat
14tests-common += $(TEST_DIR)/pl031.flat
15
16tests-all = $(tests-common) $(tests)
17all: directories $(tests-all)
18
19$(TEST_DIR)/sieve.elf: AUXFLAGS = 0x1
20
21##################################################################
22AUXFLAGS ?= 0x0
23
24CFLAGS += -std=gnu99
25CFLAGS += -ffreestanding
26CFLAGS += -O2
27CFLAGS += -I $(SRCDIR)/lib -I $(SRCDIR)/lib/libfdt -I lib
28
29# We want to keep intermediate files
30.PRECIOUS: %.elf %.o
31
32asm-offsets = lib/$(ARCH)/asm-offsets.h
33include $(SRCDIR)/scripts/asm-offsets.mak
34
35cflatobjs += lib/util.o lib/getchar.o
36cflatobjs += lib/alloc_phys.o
37cflatobjs += lib/alloc_page.o
38cflatobjs += lib/vmalloc.o
39cflatobjs += lib/alloc.o
40cflatobjs += lib/devicetree.o
41cflatobjs += lib/migrate.o
42cflatobjs += lib/pci.o
43cflatobjs += lib/pci-host-generic.o
44cflatobjs += lib/pci-testdev.o
45cflatobjs += lib/virtio.o
46cflatobjs += lib/virtio-mmio.o
47cflatobjs += lib/chr-testdev.o
48cflatobjs += lib/arm/io.o
49cflatobjs += lib/arm/setup.o
50cflatobjs += lib/arm/mmu.o
51cflatobjs += lib/arm/bitops.o
52cflatobjs += lib/arm/psci.o
53cflatobjs += lib/arm/smp.o
54cflatobjs += lib/arm/delay.o
55cflatobjs += lib/arm/gic.o lib/arm/gic-v2.o lib/arm/gic-v3.o
56
57OBJDIRS += lib/arm
58
59libeabi = lib/arm/libeabi.a
60eabiobjs = lib/arm/eabi_compat.o
61
62FLATLIBS = $(libcflat) $(LIBFDT_archive) $(libeabi)
63%.elf: LDFLAGS = -nostdlib $(arch_LDFLAGS)
64%.elf: %.o $(FLATLIBS) $(SRCDIR)/arm/flat.lds $(cstart.o)
65	$(CC) $(CFLAGS) -c -o $(@:.elf=.aux.o) $(SRCDIR)/lib/auxinfo.c \
66		-DPROGNAME=\"$(@:.elf=.flat)\" -DAUXFLAGS=$(AUXFLAGS)
67	$(LD) $(LDFLAGS) -o $@ -T $(SRCDIR)/arm/flat.lds \
68		$(filter %.o, $^) $(FLATLIBS) $(@:.elf=.aux.o)
69	$(RM) $(@:.elf=.aux.o)
70	@chmod a-x $@
71
72%.flat: %.elf
73	$(call arch_elf_check, $^)
74	$(OBJCOPY) -O binary $^ $@
75	@chmod a-x $@
76
77$(libeabi): $(eabiobjs)
78	$(AR) rcs $@ $^
79
80arm_clean: asm_offsets_clean
81	$(RM) $(TEST_DIR)/*.{o,flat,elf} $(libeabi) $(eabiobjs) \
82	      $(TEST_DIR)/.*.d lib/arm/.*.d
83
84generated-files = $(asm-offsets)
85$(tests-all:.flat=.o) $(cstart.o) $(cflatobjs): $(generated-files)
86