xref: /kvm-unit-tests/arm/Makefile.common (revision bb4c17e3783ce4578065f8ea55b6227dc0f53ad8)
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
56cflatobjs += lib/arm/timer.o
57
58OBJDIRS += lib/arm
59
60libeabi = lib/arm/libeabi.a
61eabiobjs = lib/arm/eabi_compat.o
62
63FLATLIBS = $(libcflat) $(LIBFDT_archive) $(libeabi)
64%.elf: LDFLAGS = -nostdlib $(arch_LDFLAGS)
65%.elf: %.o $(FLATLIBS) $(SRCDIR)/arm/flat.lds $(cstart.o)
66	$(CC) $(CFLAGS) -c -o $(@:.elf=.aux.o) $(SRCDIR)/lib/auxinfo.c \
67		-DPROGNAME=\"$(@:.elf=.flat)\" -DAUXFLAGS=$(AUXFLAGS)
68	$(LD) $(LDFLAGS) -o $@ -T $(SRCDIR)/arm/flat.lds \
69		$(filter %.o, $^) $(FLATLIBS) $(@:.elf=.aux.o)
70	$(RM) $(@:.elf=.aux.o)
71	@chmod a-x $@
72
73%.flat: %.elf
74	$(call arch_elf_check, $^)
75	$(OBJCOPY) -O binary $^ $@
76	@chmod a-x $@
77
78$(libeabi): $(eabiobjs)
79	$(AR) rcs $@ $^
80
81arm_clean: asm_offsets_clean
82	$(RM) $(TEST_DIR)/*.{o,flat,elf} $(libeabi) $(eabiobjs) \
83	      $(TEST_DIR)/.*.d lib/arm/.*.d
84
85generated-files = $(asm-offsets)
86$(tests-all:.flat=.o) $(cstart.o) $(cflatobjs): $(generated-files)
87