sovereignx/Makefile

125 lines
3.2 KiB
Makefile
Raw Normal View History

2016-11-01 18:35:16 +00:00
SHELL := /bin/bash -o pipefail
2016-09-03 09:11:14 +01:00
AS := $(DEVKITARM)/bin/arm-none-eabi-as
ASFLAGS := -mcpu=arm7tdmi
2016-11-01 18:35:16 +00:00
CC1 := tools/agbcc/bin/agbcc
override CFLAGS += -mthumb-interwork -Wimplicit -O2 -fhex-asm
2016-09-03 09:11:14 +01:00
CPP := $(DEVKITARM)/bin/arm-none-eabi-cpp
CPPFLAGS := -I tools/agbcc/include -iquote include -nostdinc -undef
LD := $(DEVKITARM)/bin/arm-none-eabi-ld
2016-11-01 18:35:16 +00:00
LDFLAGS := -T ld_script.ld -Map pokeemerald.map
2016-09-03 09:11:14 +01:00
OBJCOPY := $(DEVKITARM)/bin/arm-none-eabi-objcopy
LIBGCC := tools/agbcc/lib/libgcc.a
2015-11-14 05:57:22 +00:00
SHA1 := sha1sum -c
2016-11-01 18:35:16 +00:00
GFX := tools/gbagfx/gbagfx
AIF := tools/aif2pcm/aif2pcm
MID := tools/mid2agb/mid2agb
SCANINC := tools/scaninc/scaninc
2016-09-03 09:11:14 +01:00
PREPROC := tools/preproc/preproc
2016-11-01 18:35:16 +00:00
RAMSCRGEN := tools/ramscrgen/ramscrgen
2016-09-03 09:11:14 +01:00
2015-11-14 05:57:22 +00:00
# Clear the default suffixes.
.SUFFIXES:
# Secondary expansion is required for dependency variables in object rules.
.SECONDEXPANSION:
2016-09-03 09:11:14 +01:00
.PRECIOUS: %.1bpp %.4bpp %.8bpp %.gbapal %.lz %.rl
.PHONY: rom clean compare tidy
C_SRCS := $(wildcard src/*.c)
C_OBJS := $(C_SRCS:%.c=%.o)
2016-11-01 15:29:13 +00:00
ASM_SRCS := $(wildcard asm/*.s)
ASM_OBJS := $(ASM_SRCS:%.s=%.o)
DATA_ASM_SRCS := $(wildcard data/*.s)
DATA_ASM_OBJS := $(DATA_ASM_SRCS:%.s=%.o)
2016-09-03 09:11:14 +01:00
OBJS := $(C_OBJS) $(ASM_OBJS) $(DATA_ASM_OBJS)
2016-01-08 09:08:16 +00:00
ROM := pokeemerald.gba
ELF := $(ROM:.gba=.elf)
2015-11-14 05:57:22 +00:00
rom: $(ROM)
2015-11-14 05:57:22 +00:00
# For contributors to make sure a change didn't affect the contents of the ROM.
compare: $(ROM)
2015-11-14 05:57:22 +00:00
@$(SHA1) rom.sha1
2016-11-01 18:35:16 +00:00
clean: tidy
2015-11-24 02:31:37 +00:00
find . \( -iname '*.1bpp' -o -iname '*.4bpp' -o -iname '*.8bpp' -o -iname '*.gbapal' -o -iname '*.lz' -o -iname '*.latfont' -o -iname '*.hwjpnfont' -o -iname '*.fwjpnfont' \) -exec rm {} +
2015-11-14 05:57:22 +00:00
2016-09-03 09:11:14 +01:00
tidy:
2016-11-01 18:35:16 +00:00
rm -f ld_script.ld sym_bss.ld sym_common.ld sym_ewram.ld
2016-09-03 09:11:14 +01:00
rm -f $(ROM) $(ELF) $(OBJS) $(C_SRCS:%.c=%.i) pokeemerald.map
2015-11-14 05:57:22 +00:00
include graphics_file_rules.mk
2016-09-03 09:11:14 +01:00
%.s: ;
%.bin: ;
2015-11-14 05:57:22 +00:00
%.png: ;
%.pal: ;
%.1bpp: %.png ; $(GFX) $< $@
%.4bpp: %.png ; $(GFX) $< $@
%.8bpp: %.png ; $(GFX) $< $@
%.gbapal: %.pal ; $(GFX) $< $@
%.lz: % ; $(GFX) $< $@
2016-09-03 09:11:14 +01:00
%.rl: % ; $(GFX) $< $@
2016-11-01 15:17:40 +00:00
src/libc.o: CC1 := tools/agbcc/bin/old_agbcc
src/libc.o: CFLAGS := -O2
2016-09-03 09:11:14 +01:00
src/siirtc.o: CFLAGS := -mthumb-interwork
2016-09-03 09:11:14 +01:00
src/agb_flash.o: CFLAGS := -O -mthumb-interwork
src/agb_flash_1m.o: CFLAGS := -O -mthumb-interwork
src/agb_flash_mx.o: CFLAGS := -O -mthumb-interwork
2016-09-03 09:11:14 +01:00
src/m4a_2.o: CC1 := tools/agbcc/bin/old_agbcc
src/m4a_4.o: CC1 := tools/agbcc/bin/old_agbcc
2016-09-03 09:11:14 +01:00
$(C_OBJS): %.o : %.c
@$(CPP) $(CPPFLAGS) $< -o $*.i
@$(PREPROC) $*.i charmap.txt | $(CC1) $(CFLAGS) -o $*.s
@echo -e ".text\n\t.align\t2, 0\n" >> $*.s
$(AS) $(ASFLAGS) -o $@ $*.s
2017-01-14 19:53:20 +00:00
ifeq ($(NODEP),)
%.o: dep = $(shell $(SCANINC) $*.s)
else
%.o: dep :=
endif
2015-11-14 05:57:22 +00:00
2016-09-03 09:11:14 +01:00
$(ASM_OBJS): %.o: %.s $$(dep)
2015-11-14 05:57:22 +00:00
$(AS) $(ASFLAGS) -o $@ $<
2016-09-03 09:11:14 +01:00
$(DATA_ASM_OBJS): %.o: %.s $$(dep)
$(PREPROC) $< charmap.txt | $(AS) $(ASFLAGS) -o $@
2016-11-01 18:35:16 +00:00
sym_bss.ld: sym_bss.txt
$(RAMSCRGEN) .bss sym_bss.txt >$@
sym_common.ld: sym_common.txt $(C_OBJS) $(wildcard common_syms/*.txt)
$(RAMSCRGEN) COMMON sym_common.txt -c src,common_syms >$@
sym_ewram.ld: sym_ewram.txt
$(RAMSCRGEN) ewram_data sym_ewram.txt >$@
ld_script.ld: ld_script.txt sym_bss.ld sym_common.ld sym_ewram.ld
sed -f ld_script.sed ld_script.txt >ld_script.ld
$(ELF): ld_script.ld $(OBJS)
$(LD) $(LDFLAGS) -o $@ $(OBJS) $(LIBGCC)
$(ROM): $(ELF)
$(OBJCOPY) -O binary --gap-fill 0xFF --pad-to 0x9000000 $< $@