source: buchla-68k/Makefile@ f394e7b

Last change on this file since f394e7b was f394e7b, checked in by Thomas Lopatic <thomas@…>, 7 years ago

Linked ROM without errors.

  • Property mode set to 100644
File size: 8.0 KB
RevLine 
[109c83b]1CROSS_DIR := /opt/cross-m68k/bin
2CROSS_TRI := m68k-none-elf
3CROSS_PRE := $(CROSS_DIR)/$(CROSS_TRI)
4
5CROSS_GCC := $(CROSS_PRE)-gcc
6CROSS_AS := $(CROSS_PRE)-as
[9bf0f86]7CROSS_AR := $(CROSS_PRE)-ar
[6dc5ea7]8CROSS_OBJC := $(CROSS_PRE)-objcopy
[109c83b]9
10# -mshort sets the size of an int to 16 bits; important for interop with
11# the hand-written assembly language code
12
[bef53a9]13FLAGS := -Os -m68000 -Wall -Wextra
14
[6dc5ea7]15FLAGS_COM := $(FLAGS) -mshort -std=c99 -fleading-underscore -ffreestanding \
16 -nostdinc -fno-strict-aliasing -fno-inline -fno-omit-frame-pointer \
[109c83b]17 -Wpedantic -Wcast-align -Wcast-qual -Wconversion -Wsign-conversion \
18 -Wshadow -Wmissing-declarations -Wredundant-decls \
19 -I include
20
[bef53a9]21FLAGS_ASM := $(FLAGS) -Wa,--register-prefix-optional
[9bf0f86]22FLAGS_LNK := $(FLAGS) -mshort -std=c99 -ffreestanding -nostdlib
[109c83b]23
24HEADERS := $(wildcard include/*.h)
25
[9bf0f86]26all: rom.abs midas.abs
27
[109c83b]28PROLOG_C := croot.c
29PROLOG_S := fsmain.s
30
31PROLOG_CO := $(PROLOG_C:.c=.o)
32PROLOG_SO := $(PROLOG_S:.s=.o)
33PROLOG_OBJ := $(PROLOG_CO:%=build/%) $(PROLOG_SO:%=build/%)
34
35build/%.o: prolog/%.c $(HEADERS) | build
36 $(CROSS_GCC) $(FLAGS_COM) -c -o $@ $<
[6dc5ea7]37 $(CROSS_OBJC) --redefine-syms misc/rewrite.txt $@
[109c83b]38
39build/%.o: prolog/%.s $(HEADERS) | build
40 $(CROSS_GCC) $(FLAGS_ASM) -c -o $@ $<
41
[9bf0f86]42prolog.a: $(PROLOG_OBJ)
43 rm -f prolog.a
44 $(CROSS_AR) rcs prolog.a $(PROLOG_OBJ)
45
[109c83b]46IOLIB_C := dofmt.c mdump.c pause.c printf.c rawio.c sprintf.c waitcr.c
47IOLIB_S := hwdefs.s rtraps.s setipl.s setsr.s traps.s
48
49IOLIB_CO := $(IOLIB_C:.c=.o)
50IOLIB_SO := $(IOLIB_S:.s=.o)
51IOLIB_OBJ := $(IOLIB_CO:%=build/%) $(IOLIB_SO:%=build/%)
52
53build/%.o: iolib/%.c $(HEADERS) | build
54 $(CROSS_GCC) $(FLAGS_COM) -c -o $@ $<
[6dc5ea7]55 $(CROSS_OBJC) --redefine-syms misc/rewrite.txt $@
[109c83b]56
57build/%.o: iolib/%.s $(HEADERS) | build
58 $(CROSS_GCC) $(FLAGS_ASM) -c -o $@ $<
59
[9bf0f86]60iolib.a: $(IOLIB_OBJ)
61 rm -f iolib.a
62 $(CROSS_AR) rcs iolib.a $(IOLIB_OBJ)
63
[109c83b]64LIBCIO_C := atoi.c atol.c blkrd.c blkwr.c close.c clusmap.c conin.c conwr.c \
65 dirfns.c fgets.c filesys.c filname.c flread.c fopen.c fprintf.c \
66 fputs.c fread.c fscanf.c fseek.c fsinit.c fsize.c fstubs.c ftell.c \
67 fwrite.c getbuff.c getc.c getl.c getw.c lseek.c open.c posit.c putc.c \
68 putl.c putw.c read.c readrn.c rename.c scan.c setbuf.c ungetc.c \
69 unlink.c write.c writern.c
70
71LIBCIO_S := ptcl12.s
72
73LIBCIO_CO := $(LIBCIO_C:.c=.o)
74LIBCIO_SO := $(LIBCIO_S:.s=.o)
75LIBCIO_OBJ := $(LIBCIO_CO:%=build/%) $(LIBCIO_SO:%=build/%)
76
77build/%.o: libcio/%.c $(HEADERS) | build
78 $(CROSS_GCC) $(FLAGS_COM) -c -o $@ $<
[6dc5ea7]79 $(CROSS_OBJC) --redefine-syms misc/rewrite.txt $@
[109c83b]80
81build/%.o: libcio/%.s $(HEADERS) | build
82 $(CROSS_GCC) $(FLAGS_ASM) -c -o $@ $<
83
[9bf0f86]84libcio.a: $(LIBCIO_OBJ)
85 rm -f libcio.a
86 $(CROSS_AR) rcs libcio.a $(LIBCIO_OBJ)
87
[109c83b]88LIBSM_C := index.c memccpy.c memchr.c memcmp.c memcmpu.c memcpy.c memcpyw.c \
89 memset.c memsetw.c rindex.c str2lc.c str2uc.c strcat.c strccpy.c \
90 strchr.c strcmp.c strcpy.c strcspn.c strfill.c strlcmp.c strlen.c \
91 strltrm.c strncat.c strncmp.c strncpy.c strpbrk.c strrchr.c strrev.c \
92 strrevi.c strrtrm.c strspn.c strtok.c strtol.c
93
94LIBSM_CO := $(LIBSM_C:.c=.o)
95LIBSM_OBJ := $(LIBSM_CO:%=build/%)
96
97build/%.o: libsm/%.c $(HEADERS) | build
98 $(CROSS_GCC) $(FLAGS_COM) -c -o $@ $<
[6dc5ea7]99 $(CROSS_OBJC) --redefine-syms misc/rewrite.txt $@
[109c83b]100
[9bf0f86]101libsm.a: $(LIBSM_OBJ)
102 rm -f libsm.a
103 $(CROSS_AR) rcs libsm.a $(LIBSM_OBJ)
104
[109c83b]105LIB700_C := bitrev.c ctype.c ispow2.c mangle.c micons.c tolower.c toupper.c
106
107LIB700_S := aldiv.s almul.s alrem.s blkfill.s blkmove.s finalone.s jumpto.s \
108 ldiv.s lmul.s lrem.s rand24.s setjmp.s uldiv.s
109
110LIB700_CO := $(LIB700_C:.c=.o)
111LIB700_SO := $(LIB700_S:.s=.o)
112LIB700_OBJ := $(LIB700_CO:%=build/%) $(LIB700_SO:%=build/%)
113
114build/%.o: lib700/%.c $(HEADERS) | build
115 $(CROSS_GCC) $(FLAGS_COM) -c -o $@ $<
[6dc5ea7]116 $(CROSS_OBJC) --redefine-syms misc/rewrite.txt $@
[109c83b]117
118build/%.o: lib700/%.s $(HEADERS) | build
119 $(CROSS_GCC) $(FLAGS_ASM) -c -o $@ $<
120
[9bf0f86]121lib700.a: $(LIB700_OBJ)
122 rm -f lib700.a
123 $(CROSS_AR) rcs lib700.a $(LIB700_OBJ)
124
[109c83b]125VLIB_C := cg2.c cg3.c glcinit.c lseg.c vbfill4.c vclrs.c vhinit.c vmput.c \
126 vobjfns.c vputs.c vputsv.c vsetpal.c vsinit.c vspray4.c vtext.c \
127 vwputm.c
128
129VLIB_S := acctrl.s glcplot.s tsplot4.s vbank.s vclrav.s vcputs.s vcputsv.s \
130 viint.s vputa.s vputc.s vputcv.s vputp.s vsetav.s vsetcv.s vsplot4.s \
131 vvputsv.s vwputp.s vwputs.s
132
133VLIB_CO := $(VLIB_C:.c=.o)
134VLIB_SO := $(VLIB_S:.s=.o)
135VLIB_OBJ := $(VLIB_CO:%=build/%) $(VLIB_SO:%=build/%)
136
137build/%.o: vlib/%.c $(HEADERS) | build
138 $(CROSS_GCC) $(FLAGS_COM) -c -o $@ $<
[6dc5ea7]139 $(CROSS_OBJC) --redefine-syms misc/rewrite.txt $@
[109c83b]140
141build/%.o: vlib/%.s $(HEADERS) | build
142 $(CROSS_GCC) $(FLAGS_ASM) -c -o $@ $<
143
[9bf0f86]144vlib.a: $(VLIB_OBJ)
145 rm -f vlib.a
146 $(CROSS_AR) rcs vlib.a $(VLIB_OBJ)
[109c83b]147
148ROM_C := booter.c romp.c
[6dc5ea7]149ROM_S := bios.s timeint.s
[109c83b]150
151ROM_CO := $(ROM_C:.c=.o)
152ROM_SO := $(ROM_S:.s=.o)
[f394e7b]153# ROM_SO goes before ROM_CO, so that bios.o is first.
154ROM_OBJ := $(ROM_SO:%=build/%) $(ROM_CO:%=build/%)
[109c83b]155
[6dc5ea7]156LOWRAM_S := lowram.s
157
158LOWRAM_SO := $(LOWRAM_S:.s=.o)
159LOWRAM_OBJ := $(LOWRAM_SO:%=build/%)
160
[109c83b]161build/%.o: rom/%.c $(HEADERS) | build
162 $(CROSS_GCC) $(FLAGS_COM) -c -o $@ $<
[6dc5ea7]163 $(CROSS_OBJC) --redefine-syms misc/rewrite.txt $@
[109c83b]164
165build/%.o: rom/%.s $(HEADERS) | build
166 $(CROSS_GCC) $(FLAGS_ASM) -c -o $@ $<
167
[6dc5ea7]168rom.abs: $(ROM_OBJ) \
169 prolog.a iolib.a libcio.a libsm.a lib700.a vlib.a
[f394e7b]170 $(CROSS_GCC) $(FLAGS_LNK) -Wl,--script,misc/rom.ld,--entry,0x100000 \
171 -o rom.abs $(ROM_OBJ) \
[6dc5ea7]172 prolog.a libcio.a vlib.a iolib.a libsm.a lib700.a -lgcc
[9bf0f86]173
[c65a0e2]174RAM_C := addfpu.c adfield.c adselbx.c asgdsp.c asgvce.c barbadj.c chgsef.c \
175 chksec.c cminit.c ctcpos.c curset.c dbentr.c dcopy.c dec2fr.c delnote.c \
176 delpnts.c dformat.c dopatch.c enterit.c etaccn.c etadep.c etadyn.c \
177 etagch.c etagpt.c etains.c etaint.c etaopt.c etaprg.c etarat.c etatab.c \
178 etatun.c etavgr.c etdyn.c etiact.c eticnf.c etidin.c etimlt.c etinst.c \
179 etioas.c etiosc.c etipnt.c etires.c etitim.c etival.c etivce.c etiwsn.c \
180 etloc.c etmcfn.c etrel.c etres1.c etscor.c etsnbt.c etstrn.c ettpch.c \
181 ettrns.c etttab.c ettval.c etvel.c etwavs.c etwhar.c etwhrv.c etwoff.c \
182 etwpnt.c etwslt.c etwvce.c fcnote.c frfind.c gcurpos.c idfield.c idselbx.c \
183 im700.c infield.c initi.c instdsp.c itcpos.c kbobj.c lcdlbls.c ldfield.c \
184 ldselbx.c libdsp.c librw.c localkb.c m7menu.c midas.c msl.c msm.c nedacc.c \
185 pix2mid.c ptdisp.c ptdkey.c ptfield.c ptread.c ptselbx.c ptwrite.c puteq.c \
186 rscript.c scadv.c scfield.c scgoto.c scinit.c scope.c scordsp.c scread.c \
187 scselbx.c sctrak.c scwrite.c seccpy.c sedump.c select.c sendval.c setgc.c \
188 setv2gi.c setwq.c showcfg.c smscrl.c sqdisp.c sqdkey.c sqexec.c sqfield.c \
189 sqread.c sqscan.c sqselbx.c sqwrite.c stcpos.c stmproc.c swinit.c tdfield.c \
190 tdselbx.c ttcpos.c tundsp.c ucslice.c uslice.c vtyper.c wdfield.c wdselbx.c \
191 wheel.c wscalc.c wsdsp.c
192
193RAM_S := execins.s execkey.s fpuint.s procpfl.s sedisp.s seexec.s serintr.s \
[283e7a6]194 sreset.s timeint.s tofpu.s verdate.s
[c65a0e2]195
196RAM_CO := $(RAM_C:.c=.o)
197RAM_SO := $(RAM_S:.s=.o)
198RAM_OBJ := $(RAM_CO:%=build/%) $(RAM_SO:%=build/%)
199
200build/%.o: ram/%.c $(HEADERS) | build
201 $(CROSS_GCC) $(FLAGS_COM) -c -o $@ $<
[6dc5ea7]202 $(CROSS_OBJC) --redefine-syms misc/rewrite.txt $@
[c65a0e2]203
204build/%.o: ram/%.s $(HEADERS) | build
205 $(CROSS_GCC) $(FLAGS_ASM) -c -o $@ $<
206
[6dc5ea7]207midas.abs: $(LOWRAM_OBJ) prolog.a $(RAM_OBJ) \
208 iolib.a libcio.a libsm.a lib700.a vlib.a
[f394e7b]209 $(CROSS_GCC) $(FLAGS_LNK) -Wl,--script,misc/ram.ld,--entry,0x10000 \
210 -o midas.abs $(LOWRAM_OBJ) prolog.a $(RAM_OBJ) \
[6dc5ea7]211 libcio.a vlib.a iolib.a libsm.a lib700.a -lgcc
[109c83b]212
213build:
214 mkdir build
215
[f8c95c4]216hatari/c.img: $(wildcard hatari/c/bin/*) $(wildcard hatari/c/work/*)
[109c83b]217 rm -f hatari/c.img
[bef53a9]218 atari-hd-image 16 hatari/c.img BUCHLA hatari/c
[109c83b]219
220emu: hatari/c.img
221 hatari \
222 --control-socket /tmp/buchla.sock \
[bef53a9]223 --memsize 14 \
[109c83b]224 --vdi-width 1280 --vdi-height 960 \
225 --drive-a false --drive-b false \
226 --acsi 0=hatari/c.img \
227 --harddrive hatari/d --gemdos-drive d
228
229rem:
230 hatari/rem.py
231
232clean:
233 rm -rf build
[9bf0f86]234 rm -f prolog.a iolib.a libcio.a libsm.a lib700.a vlib.a
235 rm -f rom.abs midas.abs
[109c83b]236 rm -f hatari/c.img
237 rm -f hatari/d/out/*
Note: See TracBrowser for help on using the repository browser.