testpico: 32x vint tests
[megadrive.git] / testpico / Makefile
... / ...
CommitLineData
1CROSS = m68k-elf-
2HOSTCC = gcc
3CC = $(CROSS)gcc
4AS = $(CROSS)as
5LD = $(CROSS)ld
6OBJCOPY = $(CROSS)objcopy
7
8CROSS_SH = sh-elf-
9CC_SH = $(CROSS_SH)gcc
10LD_SH = $(CROSS_SH)ld
11OBJCOPY_SH = $(CROSS_SH)objcopy
12
13ASFLAGS += -m68000 --register-prefix-optional --bitwise-or -pic
14ASFLAGS_CC += -Wa,-m68000 -Wa,--register-prefix-optional -Wa,--bitwise-or -Wa,-pic
15CFLAGS += -Wall -g -O2 -m68000 -fomit-frame-pointer
16LDLIBS_LIBGCC := $(shell $(CC) -print-file-name=libgcc.a)
17LDLIBS += $(LDLIBS_LIBGCC)
18
19ifeq ($(shell m68k-elf-gcc -dD -E -c - --param=min-pagesize=0 < /dev/null > /dev/null 2>&1 && echo ok),ok)
20CFLAGS += --param=min-pagesize=0
21endif
22
23SUFFIX := $(shell git describe --always --dirty)
24ifdef PICO
25CFLAGS += -DPICO
26SUFFIX := $(SUFFIX)-for-pd
27endif
28CFLAGS += -DVERSION=\"$(SUFFIX)\"
29
30TARGET_BASE = testpico
31TARGET = $(TARGET_BASE)-$(SUFFIX)
32OBJS = sega_gcc.o main.o asmtools.o
33
34all: $(TARGET).bin
35
36$(TARGET).elf: $(OBJS)
37 $(LD) -o $@ -Tsega.ld -Map $(TARGET_BASE).map $^ $(LDLIBS)
38
39clean:
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
47fill: 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
57TARGET_SH = sh2_test
58OBJS_SH = sh2_test.osh sh2_main.osh
59
60CFLAGS_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
75sega_gcc.o: z80_test.bin80
76sega_gcc.o: sh2_test.binsh
77
78up: $(TARGET).bin
79 scp $< root@router:/tmp/
80
81.PHONY: all clean