testpico: 32x reset + other tests
[megadrive.git] / testpico / Makefile
CommitLineData
ffd4b35c 1CROSS = m68k-elf-
2HOSTCC = gcc
3CC = $(CROSS)gcc
4AS = $(CROSS)as
5LD = $(CROSS)ld
6OBJCOPY = $(CROSS)objcopy
7
9d39a80e 8CROSS_SH = sh-elf-
9CC_SH = $(CROSS_SH)gcc
10LD_SH = $(CROSS_SH)ld
11OBJCOPY_SH = $(CROSS_SH)objcopy
12
ffd4b35c 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
234c4556 16LDLIBS_LIBGCC := $(shell $(CC) -print-file-name=libgcc.a)
17LDLIBS += $(LDLIBS_LIBGCC)
18
19SUFFIX := $(shell git describe --always --dirty)
20ifdef PICO
21CFLAGS += -DPICO
22SUFFIX := $(SUFFIX)-for-pd
23endif
24TARGET_BASE = testpico
25TARGET = $(TARGET_BASE)-$(SUFFIX)
71b41fdd 26OBJS = sega_gcc.o main.o asmtools.o
ffd4b35c 27
28all: $(TARGET).bin
29
30$(TARGET).elf: $(OBJS)
234c4556 31 $(LD) -o $@ -Tsega.ld -Map $(TARGET_BASE).map $^ $(LDLIBS)
ffd4b35c 32
33clean:
234c4556 34 $(RM) $(TARGET_BASE)*.bin $(OBJS) *.elf *.map fill
9d39a80e 35 $(RM) *.lst *.bin80 *.osh *.binsh
ffd4b35c 36
37$(TARGET).bin: $(TARGET).elf fill
38 $(OBJCOPY) -I elf32-m68k -O binary $< $@
39 ./fill $@
40
41fill: fill.c
42 $(HOSTCC) -o $@ $^ -Wall -O2
43
44%.o: %.S
cc7e5122 45 $(CC) -c -o $@ $^ $(CFLAGS) $(ASFLAGS_CC)
ffd4b35c 46
47%.bin80: %.s80
48 sjasm $< $@
49
9d39a80e 50# sh2
51TARGET_SH = sh2_test
52OBJS_SH = sh2_test.osh sh2_main.osh
53
54CFLAGS_SH = -m2 -mb -O2 -Wall
55
56%.binsh: %.elf
57 $(OBJCOPY_SH) -O binary $< $@
58
59$(TARGET_SH).elf: $(OBJS_SH)
60 $(LD_SH) -o $@ $^ -Tmars.ld -Map $(TARGET_SH).map -nostdlib
61
62%.osh: %.sh2
63 $(CC_SH) -o $@ -c -x assembler $< $(CFLAGS_SH)
64
65%.osh: %.c
66 $(CC_SH) -o $@ -c $< $(CFLAGS_SH)
67
ffd4b35c 68# manual deps
71b41fdd 69sega_gcc.o: z80_test.bin80
9d39a80e 70sega_gcc.o: sh2_test.binsh
71
72up: $(TARGET).bin
73 scp $< root@router:/tmp/
ffd4b35c 74
75.PHONY: all clean