dca29b20fe86b3383cadaad9ee9ce462a3c4673c
[megadrive.git] / testpico / Makefile
1 CROSS = m68k-elf-
2 HOSTCC = gcc
3 CC = $(CROSS)gcc
4 AS = $(CROSS)as
5 LD = $(CROSS)ld
6 OBJCOPY = $(CROSS)objcopy
7
8 CROSS_SH = sh-elf-
9 CC_SH = $(CROSS_SH)gcc
10 LD_SH = $(CROSS_SH)ld
11 OBJCOPY_SH = $(CROSS_SH)objcopy
12
13 ASFLAGS += -m68000 --register-prefix-optional --bitwise-or -pic
14 ASFLAGS_CC += -Wa,-m68000 -Wa,--register-prefix-optional -Wa,--bitwise-or -Wa,-pic
15 CFLAGS += -Wall -g -O2 -m68000 -fomit-frame-pointer
16 LDLIBS_LIBGCC := $(shell $(CC) -print-file-name=libgcc.a)
17 LDLIBS += $(LDLIBS_LIBGCC)
18
19 ifeq ($(shell m68k-elf-gcc -dD -E -c - --param=min-pagesize=0 < /dev/null > /dev/null 2>&1 && echo ok),ok)
20 CFLAGS += --param=min-pagesize=0
21 endif
22
23 SUFFIX := $(shell git describe --always --dirty)
24 ifdef PICO
25 CFLAGS += -DPICO
26 SUFFIX := $(SUFFIX)-for-pd
27 endif
28 CFLAGS += -DVERSION=\"$(SUFFIX)\"
29
30 TARGET_BASE = testpico
31 TARGET = $(TARGET_BASE)-$(SUFFIX)
32 OBJS = sega_gcc.o main.o asmtools.o
33
34 all: $(TARGET).bin
35
36 $(TARGET).elf: $(OBJS)
37         $(LD) -o $@ -Tsega.ld -Map $(TARGET_BASE).map $^ $(LDLIBS)
38
39 clean:
40         $(RM) $(TARGET_BASE)*.bin $(OBJS) *.elf *.map fill
41         $(RM) *.lst *.bin80 *.osh *.binsh
42
43 $(TARGET).bin: $(TARGET).elf fill
44         $(OBJCOPY) -I elf32-m68k -O binary $< $@
45         ./fill $@
46
47 fill: fill.c
48         $(HOSTCC) -o $@ $^ -Wall -O2
49
50 %.o: %.S
51         $(CC) -c -o $@ $^ $(CFLAGS) $(ASFLAGS_CC)
52
53 %.bin80: %.s80
54         sjasm $< $@
55
56 # sh2
57 TARGET_SH = sh2_test
58 OBJS_SH = sh2_test.osh sh2_main.osh
59
60 CFLAGS_SH = -m2 -mb -O2 -Wall
61
62 %.binsh: %.elf
63         $(OBJCOPY_SH) -O binary $< $@
64
65 $(TARGET_SH).elf: $(OBJS_SH)
66         $(LD_SH) -o $@ $^ -Tmars.ld -Map $(TARGET_SH).map -nostdlib
67
68 %.osh: %.sh2
69         $(CC_SH) -o $@ -c -x assembler $< $(CFLAGS_SH)
70
71 %.osh: %.c
72         $(CC_SH) -o $@ -c $< $(CFLAGS_SH)
73
74 # manual deps
75 sega_gcc.o: z80_test.bin80
76 sega_gcc.o: sh2_test.binsh
77
78 up: $(TARGET).bin
79         scp $< root@router:/tmp/
80
81 .PHONY: all clean