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 += -O2 -msoft-float -mabi=no-altivec -mno-altivec 23CFLAGS += -I $(SRCDIR)/lib -I $(SRCDIR)/lib/libfdt -I lib 24CFLAGS += -Wa,-mregnames 25 26# We want to keep intermediate files 27.PRECIOUS: %.o 28 29asm-offsets = lib/$(ARCH)/asm-offsets.h 30include $(SRCDIR)/scripts/asm-offsets.mak 31 32cflatobjs += lib/util.o 33cflatobjs += lib/getchar.o 34cflatobjs += lib/alloc_phys.o 35cflatobjs += lib/alloc.o 36cflatobjs += lib/devicetree.o 37cflatobjs += lib/powerpc/io.o 38cflatobjs += lib/powerpc/hcall.o 39cflatobjs += lib/powerpc/setup.o 40cflatobjs += lib/powerpc/rtas.o 41cflatobjs += lib/powerpc/processor.o 42cflatobjs += lib/powerpc/handlers.o 43cflatobjs += lib/powerpc/smp.o 44 45OBJDIRS += lib/powerpc 46 47FLATLIBS = $(libcflat) $(LIBFDT_archive) 48%.elf: CFLAGS += $(arch_CFLAGS) 49%.elf: LDFLAGS = $(arch_LDFLAGS) -nostdlib -pie -n 50%.elf: %.o $(FLATLIBS) $(SRCDIR)/powerpc/flat.lds $(cstart.o) $(reloc.o) 51 $(CC) $(CFLAGS) -c -o $(@:.elf=.aux.o) $(SRCDIR)/lib/auxinfo.c \ 52 -DPROGNAME=\"$@\" 53 $(LD) $(LDFLAGS) -o $@ \ 54 -T $(SRCDIR)/powerpc/flat.lds --build-id=none \ 55 $(filter %.o, $^) $(FLATLIBS) $(@:.elf=.aux.o) 56 $(RM) $(@:.elf=.aux.o) 57 @chmod a-x $@ 58 @echo -n Checking $@ for unsupported reloc types... 59 @if $(OBJDUMP) -R $@ | grep R_ | grep -v R_PPC64_RELATIVE; then \ 60 false; \ 61 else \ 62 echo " looks good."; \ 63 fi 64 65$(TEST_DIR)/boot_rom.bin: $(TEST_DIR)/boot_rom.elf 66 dd if=/dev/zero of=$@ bs=256 count=1 67 $(OBJCOPY) -O binary $^ $@.tmp 68 cat $@.tmp >> $@ 69 $(RM) $@.tmp 70 71$(TEST_DIR)/boot_rom.elf: CFLAGS = -mbig-endian 72$(TEST_DIR)/boot_rom.elf: $(TEST_DIR)/boot_rom.o 73 $(LD) -EB -nostdlib -Ttext=0x100 --entry=start --build-id=none -o $@ $< 74 @chmod a-x $@ 75 76powerpc_clean: libfdt_clean asm_offsets_clean 77 $(RM) $(TEST_DIR)/*.{o,elf} $(TEST_DIR)/boot_rom.bin \ 78 $(TEST_DIR)/.*.d lib/powerpc/.*.d 79 80generated-files = $(asm-offsets) 81$(tests-all:.elf=.o) $(cstart.o) $(cflatobjs): $(generated-files) 82