2020-04-25 07:53:58 +10:00
|
|
|
TARGETS = forth stage2
|
2020-03-18 12:44:32 +11:00
|
|
|
# Those Forth source files are in a particular order
|
2020-04-22 10:38:42 +10:00
|
|
|
FORTHSRCS = core.fs cmp.fs print.fs parse.fs readln.fs fmt.fs blk.fs
|
2020-04-25 07:53:58 +10:00
|
|
|
FORTHSRC_PATHS = ${FORTHSRCS:%=../forth/%} run.fs
|
2019-12-10 01:36:38 +11:00
|
|
|
OBJS = emul.o libz80/libz80.o
|
2020-04-03 14:15:43 +11:00
|
|
|
SLATEST = ../tools/slatest
|
2020-04-05 01:27:21 +11:00
|
|
|
STRIPFC = ../tools/stripfc
|
2020-04-14 23:05:43 +10:00
|
|
|
BIN2C = ../tools/bin2c
|
|
|
|
BLKPACK = ../tools/blkpack
|
2020-04-17 10:59:20 +10:00
|
|
|
BLKUNPACK = ../tools/blkunpack
|
2019-05-10 04:09:40 +10:00
|
|
|
|
2019-05-10 02:58:41 +10:00
|
|
|
.PHONY: all
|
2020-04-03 14:15:43 +11:00
|
|
|
all: $(TARGETS)
|
2019-05-10 02:58:41 +10:00
|
|
|
|
2020-04-14 23:05:43 +10:00
|
|
|
$(BLKPACK):
|
2020-04-03 14:15:43 +11:00
|
|
|
$(MAKE) -C ../tools
|
2020-04-15 23:01:09 +10:00
|
|
|
|
|
|
|
.PHONY: $(STRIPFC) $(SLATEST) $(BIN2C)
|
2020-04-15 04:25:14 +10:00
|
|
|
$(STRIPFC): $(BLKPACK)
|
|
|
|
$(SLATEST): $(BLKPACK)
|
|
|
|
$(BIN2C): $(BLKPACK)
|
2020-04-17 10:59:20 +10:00
|
|
|
$(BLKUNPACK): $(BLKPACK)
|
2019-11-16 07:37:49 +11:00
|
|
|
|
2020-04-10 23:55:58 +10:00
|
|
|
# z80c.bin is not in the prerequisites because it's a bootstrap
|
|
|
|
# binary that should be updated manually through make updatebootstrap.
|
2020-04-25 07:53:58 +10:00
|
|
|
forth0.bin: $(SLATEST)
|
|
|
|
cp z80c.bin $@
|
2020-04-03 14:15:43 +11:00
|
|
|
$(SLATEST) $@
|
2020-04-25 07:53:58 +10:00
|
|
|
cat pre.fs emul.fs >> $@
|
2020-03-10 13:26:02 +11:00
|
|
|
|
2020-04-25 07:53:58 +10:00
|
|
|
forth0-bin.h: forth0.bin $(BIN2C)
|
|
|
|
$(BIN2C) KERNEL < forth0.bin | tee $@ > /dev/null
|
2020-03-10 13:26:02 +11:00
|
|
|
|
2020-04-25 07:53:58 +10:00
|
|
|
stage1: stage.c $(OBJS) forth0-bin.h
|
|
|
|
$(CC) stage.c $(OBJS) -o $@
|
2020-03-12 15:14:44 +11:00
|
|
|
|
2020-04-25 07:53:58 +10:00
|
|
|
stage1dbg: stage.c $(OBJS) forth0-bin.h
|
|
|
|
$(CC) -DDEBUG stage.c $(OBJS) -o $@
|
2020-03-14 07:01:09 +11:00
|
|
|
|
2020-04-05 01:27:21 +11:00
|
|
|
# We don't really need to use stripfc, but we do it anyway to test that we
|
|
|
|
# don't mistakenly break our code with that tool. It's easier to debug here.
|
2020-04-25 07:53:58 +10:00
|
|
|
core.bin: $(FORTHSRC_PATHS) stage1
|
|
|
|
cat $(FORTHSRC_PATHS) stop.fs | $(STRIPFC) | ./stage1 > $@
|
2020-03-25 12:13:02 +11:00
|
|
|
|
2020-04-25 07:53:58 +10:00
|
|
|
forth1.bin: core.bin $(SLATEST)
|
|
|
|
cat z80c.bin core.bin > $@
|
2020-04-03 14:15:43 +11:00
|
|
|
$(SLATEST) $@
|
2020-03-12 15:14:44 +11:00
|
|
|
|
2020-04-25 07:53:58 +10:00
|
|
|
forth1-bin.h: forth1.bin $(BIN2C)
|
|
|
|
$(BIN2C) KERNEL < forth1.bin > $@
|
2020-03-12 15:14:44 +11:00
|
|
|
|
2020-04-25 07:53:58 +10:00
|
|
|
stage2: stage.c $(OBJS) forth1-bin.h blkfs-bin.h
|
|
|
|
$(CC) -DSTAGE2 stage.c $(OBJS) -o $@
|
2020-03-25 04:46:05 +11:00
|
|
|
|
2020-04-14 23:05:43 +10:00
|
|
|
blkfs: $(BLKPACK)
|
|
|
|
$(BLKPACK) ../blk > $@
|
|
|
|
|
2020-04-25 07:53:58 +10:00
|
|
|
blkfs-bin.h: blkfs $(BIN2C)
|
2020-04-20 11:31:41 +10:00
|
|
|
$(BIN2C) BLKFS < blkfs > $@
|
|
|
|
|
2020-04-25 08:01:55 +10:00
|
|
|
forth: forth.c $(OBJS) forth1-bin.h blkfs-bin.h
|
2020-04-25 07:53:58 +10:00
|
|
|
$(CC) forth.c $(OBJS) -o $@
|
2020-03-10 13:26:02 +11:00
|
|
|
|
2019-05-10 02:58:41 +10:00
|
|
|
libz80/libz80.o: libz80/z80.c
|
2019-07-12 11:21:54 +10:00
|
|
|
$(MAKE) -C libz80/codegen opcodes
|
2019-05-20 22:20:00 +10:00
|
|
|
$(CC) -Wall -ansi -g -c -o libz80/libz80.o libz80/z80.c
|
2019-05-10 02:58:41 +10:00
|
|
|
|
2019-12-03 08:35:49 +11:00
|
|
|
emul.o: emul.c
|
|
|
|
$(CC) -c -o emul.o emul.c
|
|
|
|
|
2019-06-03 23:25:47 +10:00
|
|
|
|
2019-05-20 05:03:34 +10:00
|
|
|
.PHONY: updatebootstrap
|
2020-04-25 07:53:58 +10:00
|
|
|
updatebootstrap: stage2
|
|
|
|
cat xcomp.fs | ./stage2 > z80c.bin
|
2020-03-25 04:46:05 +11:00
|
|
|
|
2020-04-17 10:59:20 +10:00
|
|
|
.PHONY: pack
|
|
|
|
pack:
|
|
|
|
rm blkfs && $(MAKE) blkfs
|
|
|
|
|
|
|
|
.PHONY: unpack
|
|
|
|
unpack:
|
|
|
|
$(BLKUNPACK) ../blk < blkfs
|
|
|
|
|
2019-05-10 02:58:41 +10:00
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
2020-04-25 07:53:58 +10:00
|
|
|
rm -f $(TARGETS) emul.o *-bin.h forth?.bin blkfs
|
2020-04-08 07:56:55 +10:00
|
|
|
$(MAKE) -C ../tools clean
|