summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYamaArashi <shadow962@live.com>2016-06-18 21:09:31 -0700
committerYamaArashi <shadow962@live.com>2016-06-18 21:09:31 -0700
commitfa78910a6b08c5d812f64f28398f0a0583a8d6e4 (patch)
treeb58e06f02b35730924acb524512ff07a526b4ad7
parent91554406d3d4dab452980edd3893d471dbad7baf (diff)
parent3c38d6b8146141f08031060cccd7adce298c0fab (diff)
Merge branch 'master' of https://github.com/pret/pokeruby
-rw-r--r--Makefile88
-rw-r--r--generated.mk4
-rw-r--r--rom.sha11
3 files changed, 52 insertions, 41 deletions
diff --git a/Makefile b/Makefile
index 74f562537..e4152c658 100644
--- a/Makefile
+++ b/Makefile
@@ -8,7 +8,8 @@ CPP := $(DEVKITARM)/bin/arm-none-eabi-cpp
CPPFLAGS := -I tools/agbcc/include -iquote include -nostdinc -undef
LD := $(DEVKITARM)/bin/arm-none-eabi-ld
-LDFLAGS := -T ld_script.txt -T iwram_syms.txt -T ewram_syms.txt
+pokeruby_LDFLAGS := -T ld_script_ruby.txt -T iwram_syms.txt -T ewram_syms.txt
+pokesapphire_LDFLAGS := -T ld_script_sapphire.txt -T iwram_syms.txt -T ewram_syms.txt
OBJCOPY := $(DEVKITARM)/bin/arm-none-eabi-objcopy
@@ -30,7 +31,7 @@ PREPROC := tools/preproc/preproc
.PRECIOUS: %.1bpp %.4bpp %.8bpp %.gbapal %.lz
-.PHONY: all rom clean compare generated
+.PHONY: all clean compare ruby sapphire
C_SRCS := $(wildcard src/*.c)
C_OBJS := $(C_SRCS:%.c=%.o)
@@ -41,31 +42,27 @@ ASM_OBJS := asm/crt0.o asm/rom3.o asm/rom4.o asm/rom_8074BAC.o asm/rom5.o \
DATA_ASM_OBJS := data/data1.o data/data2.o data/graphics.o data/sound_data.o
OBJS := $(C_OBJS) $(ASM_OBJS) $(DATA_ASM_OBJS)
+pokeruby_OBJS := $(OBJS:.o=_ruby.o)
+pokesapphire_OBJS := $(OBJS:.o=_sapphire.o)
-ruby:
- $(MAKE) generated
- $(MAKE) ruby_rom
+ROM := pokeruby.gba pokesapphire.gba
+ELF := $(ROM:.gba=.elf)
-ruby_rom: ROM := pokeruby.gba
-ruby_rom: ELF := pokeruby.elf
-ruby_rom: pokeruby.gba
-
-sapphire:
- $(MAKE) generated
- $(MAKE) sapphire_rom
-
-sapphire_rom: ROM := pokesapphire.gba
-sapphire_rom: ELF := pokesapphire.elf
-sapphire_rom: ASFLAGS += --defsym SAPPHIRE=1
-sapphire_rom: CPPFLAGS += -DSAPPHIRE
-sapphire_rom: pokesapphire.gba
+all: ruby
+ @:
+both: ruby sapphire
+ @:
+ruby: pokeruby.gba
+ @:
+sapphire: pokesapphire.gba
+ @:
# For contributors to make sure a change didn't affect the contents of the ROM.
-compare: ruby
+compare: both
@$(SHA1) rom.sha1
clean:
- rm -f pokeruby.gba pokesapphire.gba $(ELF) $(OBJS) $(C_SRCS:%.c=%.i)
+ rm -f $(ROM) $(ELF) $(OBJS) $(pokeruby_OBJS) $(pokesapphire_OBJS) $(C_SRCS:%.c=%.i)
find . \( -iname '*.1bpp' -o -iname '*.4bpp' -o -iname '*.8bpp' -o -iname '*.gbapal' -o -iname '*.lz' \) -exec rm {} +
include castform.mk
@@ -82,30 +79,45 @@ include menu.mk
%.gbapal: %.pal ; $(GFX) $< $@
%.lz: % ; $(GFX) $< $@
-src/siirtc.o: CFLAGS := -mthumb-interwork
+src/siirtc_ruby.o src/siirtc_sapphire.o: CFLAGS := -mthumb-interwork
-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
+src/agb_flash_ruby.o src/agb_flash_sapphire.o: CFLAGS := -O -mthumb-interwork
+src/agb_flash_1m_ruby.o src/agb_flash_1m_sapphire.o: CFLAGS := -O -mthumb-interwork
+src/agb_flash_mx_ruby.o src/agb_flash_mx_sapphire.o: CFLAGS := -O -mthumb-interwork
-src/m4a_2.o: CC1 := tools/agbcc/bin/old_agbcc
-src/m4a_4.o: CC1 := tools/agbcc/bin/old_agbcc
+src/m4a_2_ruby.o src/m4a_2_sapphire.o: CC1 := tools/agbcc/bin/old_agbcc
+src/m4a_4_ruby.o src/m4a_2_sapphire.o: CC1 := tools/agbcc/bin/old_agbcc
-$(C_OBJS): %.o : %.c
- @$(CPP) $(CPPFLAGS) $< -o $*.i
+src/%_ruby.o: VERSION := -D RUBY
+src/%_sapphire.o: VERSION := -D SAPPHIRE
+src/text_ruby.o src/text_sapphire.o: src/text.c $(GEN_FONT_HEADERS)
+src/link_ruby.o src/link_sapphire.o: src/link.c $(GEN_LINK_HEADERS)
+src/%_ruby.o src/%_sapphire.o src/%.o: src/%.c
+ @$(CPP) $(CPPFLAGS) $(VERSION) $< -o $*.i
@$(PREPROC) $*.i charmap.txt | $(CC1) $(CFLAGS) -o $*.s
- @bash -c 'echo -e ".text\n\t.align\t2, 0\n"' >> $*.s
+ @echo -e ".text\n\t.align\t2, 0\n" >> $*.s
$(AS) $(ASFLAGS) -o $@ $*.s
-%.o : dep = $(shell $(SCANINC) $*.s)
+asm/%_ruby.o data/%_ruby.o: VERSION := --defsym RUBY=1
+asm/%_sapphire.o data/%_sapphire.o: VERSION := --defsym SAPPHIRE=1
+
+asm/%.o: dep = $(shell $(SCANINC) asm/$*.s)
+asm/%_ruby.o asm/%_sapphire.o asm/%.o: asm/%.s $$(dep)
+ $(AS) $(ASFLAGS) $(VERSION) -o $@ $<
+
+data/%.o: dep = $(shell $(SCANINC) data/$*.s)
+data/%_ruby.o data/%_sapphire.o data/%.o: data/%.s $$(dep)
+ $(PREPROC) $< charmap.txt | $(AS) $(ASFLAGS) $(VERSION) -o $@
-$(ASM_OBJS): %.o: %.s $$(dep)
- $(AS) $(ASFLAGS) -o $@ $<
+ld_script_ruby.txt: ld_script.txt
+ @sed "s/\(\(src\|asm\|data\)\/.*\)\.o/\1_ruby.o/g" $< > $@
+ld_script_sapphire.txt: ld_script.txt
+ @sed "s/\(\(src\|asm\|data\)\/.*\)\.o/\1_sapphire.o/g" $< > $@
-$(DATA_ASM_OBJS): %.o: %.s $$(dep)
- $(PREPROC) $< charmap.txt | $(AS) $(ASFLAGS) -o $@
+pokeruby.elf: ld_script_ruby.txt $(pokeruby_OBJS)
+ $(LD) $(pokeruby_LDFLAGS) -o $@ $(pokeruby_OBJS) $(LIBGCC)
+pokesapphire.elf: ld_script_sapphire.txt $(pokesapphire_OBJS)
+ $(LD) $(pokesapphire_LDFLAGS) -o $@ $(pokesapphire_OBJS) $(LIBGCC)
-# Link objects to produce the ROM.
-pokeruby.gba pokesapphire.gba: $(OBJS)
- $(LD) $(LDFLAGS) -o $(ELF) $(OBJS) $(LIBGCC)
- $(OBJCOPY) -O binary --gap-fill 0xFF --pad-to 0x9000000 $(ELF) $(ROM)
+%.gba: %.elf
+ $(OBJCOPY) -O binary --gap-fill 0xFF --pad-to 0x9000000 $< $@
diff --git a/generated.mk b/generated.mk
index 70d50e8f8..e05b28a9c 100644
--- a/generated.mk
+++ b/generated.mk
@@ -10,9 +10,7 @@ include/fonts/down_arrow_tiles.h \
include/fonts/unknown_palette_81E6692.h \
include/fonts/default_palette.h
-LINK_HEADERS := include/link/digit_tiles.h include/link/digit_palette.h
-
-generated: $(GEN_FONT_HEADERS) $(LINK_HEADERS)
+GEN_LINK_HEADERS := include/link/digit_tiles.h include/link/digit_palette.h
include/fonts/font0_lat_glyphs.h: graphics/fonts/font0_lat.1bpp
$(BIN2C) $< sFont0LatinGlyphs >$@ -static -col 8 -pad 4
diff --git a/rom.sha1 b/rom.sha1
index 61b6a3325..137f7914a 100644
--- a/rom.sha1
+++ b/rom.sha1
@@ -1 +1,2 @@
f28b6ffc97847e94a6c21a63cacf633ee5c8df1e pokeruby.gba
+3ccbbd45f8553c36463f13b938e833f652b793e4 pokesapphire.gba