xref: /kvm-unit-tests/powerpc/Makefile.common (revision 4da0bc9a24a78cf61f046898b24c45577b645492)
1#
2# powerpc common makefile
3#
4# Authors: Andrew Jones <drjones@redhat.com>
5#
6
7tests-common = \
8	$(TEST_DIR)/selftest.elf \
9	$(TEST_DIR)/spapr_hcall.elf \
10	$(TEST_DIR)/rtas.elf \
11	$(TEST_DIR)/emulator.elf \
12	$(TEST_DIR)/tm.elf \
13	$(TEST_DIR)/sprs.elf
14
15tests-all = $(tests-common) $(tests)
16all: directories $(TEST_DIR)/boot_rom.bin $(tests-all)
17
18##################################################################
19
20CFLAGS += -std=gnu99
21CFLAGS += -ffreestanding
22CFLAGS += -Wextra
23CFLAGS += -O2
24CFLAGS += -I $(SRCDIR)/lib -I $(SRCDIR)/lib/libfdt -I lib
25CFLAGS += -Wa,-mregnames
26
27# We want to keep intermediate files
28.PRECIOUS: %.o
29
30asm-offsets = lib/$(ARCH)/asm-offsets.h
31include $(SRCDIR)/scripts/asm-offsets.mak
32
33cflatobjs += lib/util.o
34cflatobjs += lib/alloc.o
35cflatobjs += lib/devicetree.o
36cflatobjs += lib/powerpc/io.o
37cflatobjs += lib/powerpc/hcall.o
38cflatobjs += lib/powerpc/setup.o
39cflatobjs += lib/powerpc/rtas.o
40cflatobjs += lib/powerpc/processor.o
41cflatobjs += lib/powerpc/handlers.o
42cflatobjs += lib/powerpc/smp.o
43
44OBJDIRS += lib/powerpc
45
46FLATLIBS = $(libcflat) $(LIBFDT_archive)
47%.elf: CFLAGS += $(arch_CFLAGS)
48%.elf: LDFLAGS = $(arch_LDFLAGS) -nostdlib -pie -n
49%.elf: %.o $(FLATLIBS) $(SRCDIR)/powerpc/flat.lds $(cstart.o) $(reloc.o)
50	$(CC) $(CFLAGS) -c -o $(@:.elf=.aux.o) $(SRCDIR)/lib/auxinfo.c \
51		-DPROGNAME=\"$@\"
52	$(LD) $(LDFLAGS) -o $@ \
53		-T $(SRCDIR)/powerpc/flat.lds --build-id=none \
54		$(filter %.o, $^) $(FLATLIBS) $(@:.elf=.aux.o)
55	$(RM) $(@:.elf=.aux.o)
56	@echo -n Checking $@ for unsupported reloc types...
57	@if $(OBJDUMP) -R $@ | grep R_ | grep -v R_PPC64_RELATIVE; then	\
58		false;							\
59	else								\
60		echo " looks good.";					\
61	fi
62
63$(TEST_DIR)/boot_rom.bin: $(TEST_DIR)/boot_rom.elf
64	dd if=/dev/zero of=$@ bs=256 count=1
65	$(OBJCOPY) -O binary $^ $@.tmp
66	cat $@.tmp >> $@
67	$(RM) $@.tmp
68
69$(TEST_DIR)/boot_rom.elf: CFLAGS = -mbig-endian
70$(TEST_DIR)/boot_rom.elf: $(TEST_DIR)/boot_rom.o
71	$(LD) -EB -nostdlib -Ttext=0x100 --entry=start --build-id=none -o $@ $<
72
73powerpc_clean: libfdt_clean asm_offsets_clean
74	$(RM) $(TEST_DIR)/*.{o,elf} $(TEST_DIR)/boot_rom.bin \
75	      $(TEST_DIR)/.*.d lib/powerpc/.*.d
76
77generated-files = $(asm-offsets)
78$(tests-all:.elf=.o) $(cstart.o) $(cflatobjs): $(generated-files)
79