2020-04-13 19:25:28 -04:00
|
|
|
TARGETS = forth/forth
|
2020-03-17 21:44:32 -04:00
|
|
|
# Those Forth source files are in a particular order
|
2020-04-10 14:16:45 -04:00
|
|
|
BOOTSRCS = ./forth/conf.fs \
|
|
|
|
../forth/xcomp.fs \
|
|
|
|
./forth/xcomp.fs \
|
|
|
|
../forth/boot.fs \
|
|
|
|
../forth/z80c.fs \
|
|
|
|
../forth/icore.fs \
|
|
|
|
./forth/xstop.fs
|
|
|
|
|
2020-04-11 13:31:17 -04:00
|
|
|
FORTHSRCS = core.fs cmp.fs print.fs str.fs parse.fs readln.fs fmt.fs z80a.fs \
|
2020-04-14 09:05:43 -04:00
|
|
|
link.fs blk.fs
|
2020-04-03 08:31:30 -04:00
|
|
|
FORTHSRC_PATHS = ${FORTHSRCS:%=../forth/%} forth/run.fs
|
2019-12-09 09:36:38 -05:00
|
|
|
OBJS = emul.o libz80/libz80.o
|
2020-04-02 23:15:43 -04:00
|
|
|
SLATEST = ../tools/slatest
|
2020-04-04 10:27:21 -04:00
|
|
|
STRIPFC = ../tools/stripfc
|
2020-04-14 09:05:43 -04:00
|
|
|
BIN2C = ../tools/bin2c
|
|
|
|
BLKPACK = ../tools/blkpack
|
2020-04-16 20:59:20 -04:00
|
|
|
BLKUNPACK = ../tools/blkunpack
|
2019-05-09 14:09:40 -04:00
|
|
|
|
2019-05-09 12:58:41 -04:00
|
|
|
.PHONY: all
|
2020-04-02 23:15:43 -04:00
|
|
|
all: $(TARGETS)
|
2019-05-09 12:58:41 -04:00
|
|
|
|
2020-04-14 09:05:43 -04:00
|
|
|
$(BLKPACK):
|
2020-04-02 23:15:43 -04:00
|
|
|
$(MAKE) -C ../tools
|
2020-04-15 09:01:09 -04:00
|
|
|
|
|
|
|
.PHONY: $(STRIPFC) $(SLATEST) $(BIN2C)
|
2020-04-14 14:25:14 -04:00
|
|
|
$(STRIPFC): $(BLKPACK)
|
|
|
|
$(SLATEST): $(BLKPACK)
|
|
|
|
$(BIN2C): $(BLKPACK)
|
2020-04-16 20:59:20 -04:00
|
|
|
$(BLKUNPACK): $(BLKPACK)
|
2019-11-15 15:37:49 -05:00
|
|
|
|
2020-04-10 09:55:58 -04:00
|
|
|
# z80c.bin is not in the prerequisites because it's a bootstrap
|
|
|
|
# binary that should be updated manually through make updatebootstrap.
|
2020-04-02 23:15:43 -04:00
|
|
|
forth/forth0.bin: $(SLATEST)
|
2020-04-10 09:55:58 -04:00
|
|
|
cp forth/z80c.bin $@
|
2020-04-02 23:15:43 -04:00
|
|
|
$(SLATEST) $@
|
2020-04-13 11:35:47 -04:00
|
|
|
cat forth/pre.fs forth/emul.fs >> $@
|
2020-03-09 22:26:02 -04:00
|
|
|
|
2020-04-07 19:32:30 -04:00
|
|
|
forth/forth0-bin.h: forth/forth0.bin $(BIN2C)
|
2020-04-05 14:04:05 -04:00
|
|
|
$(BIN2C) KERNEL < forth/forth0.bin | tee $@ > /dev/null
|
2020-03-09 22:26:02 -04:00
|
|
|
|
2020-03-22 21:46:43 -04:00
|
|
|
forth/stage1: forth/stage.c $(OBJS) forth/forth0-bin.h
|
|
|
|
$(CC) forth/stage.c $(OBJS) -o $@
|
2020-03-12 00:14:44 -04:00
|
|
|
|
2020-03-22 21:46:43 -04:00
|
|
|
forth/stage1dbg: forth/stage.c $(OBJS) forth/forth0-bin.h
|
2020-04-03 08:31:30 -04:00
|
|
|
$(CC) -DDEBUG forth/stage.c $(OBJS) -o $@
|
2020-03-13 16:01:09 -04:00
|
|
|
|
2020-04-04 10:27:21 -04: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-03-24 21:13:02 -04:00
|
|
|
forth/core.bin: $(FORTHSRC_PATHS) forth/stage1
|
2020-04-13 11:35:47 -04:00
|
|
|
cat $(FORTHSRC_PATHS) ./forth/stop.fs | $(STRIPFC) | ./forth/stage1 > $@
|
2020-03-24 21:13:02 -04:00
|
|
|
|
2020-04-03 08:31:30 -04:00
|
|
|
forth/forth1.bin: forth/core.bin $(SLATEST)
|
2020-04-10 09:55:58 -04:00
|
|
|
cat forth/z80c.bin forth/core.bin > $@
|
2020-04-02 23:15:43 -04:00
|
|
|
$(SLATEST) $@
|
2020-03-12 00:14:44 -04:00
|
|
|
|
2020-04-07 19:32:30 -04:00
|
|
|
forth/forth1-bin.h: forth/forth1.bin $(BIN2C)
|
2020-04-13 11:35:47 -04:00
|
|
|
$(BIN2C) KERNEL < forth/forth1.bin > $@
|
2020-03-12 00:14:44 -04:00
|
|
|
|
2020-03-24 13:46:05 -04:00
|
|
|
forth/stage2: forth/stage.c $(OBJS) forth/forth1-bin.h
|
|
|
|
$(CC) -DSTAGE2 forth/stage.c $(OBJS) -o $@
|
|
|
|
|
2020-04-14 09:05:43 -04:00
|
|
|
blkfs: $(BLKPACK)
|
|
|
|
$(BLKPACK) ../blk > $@
|
|
|
|
|
|
|
|
forth/forth: forth/forth.c $(OBJS) forth/forth1-bin.h blkfs
|
2020-03-09 22:26:02 -04:00
|
|
|
$(CC) forth/forth.c $(OBJS) -o $@
|
|
|
|
|
2019-05-09 12:58:41 -04:00
|
|
|
libz80/libz80.o: libz80/z80.c
|
2019-07-11 21:21:54 -04:00
|
|
|
$(MAKE) -C libz80/codegen opcodes
|
2019-05-20 08:20:00 -04:00
|
|
|
$(CC) -Wall -ansi -g -c -o libz80/libz80.o libz80/z80.c
|
2019-05-09 12:58:41 -04:00
|
|
|
|
2019-12-02 16:35:49 -05:00
|
|
|
emul.o: emul.c
|
|
|
|
$(CC) -c -o emul.o emul.c
|
|
|
|
|
2019-06-03 09:25:47 -04:00
|
|
|
|
2019-05-19 15:03:34 -04:00
|
|
|
.PHONY: updatebootstrap
|
2020-04-10 14:16:45 -04:00
|
|
|
updatebootstrap: forth/stage2
|
|
|
|
cat $(BOOTSRCS) | ./forth/stage2 > ./forth/z80c.bin
|
2020-03-24 13:46:05 -04:00
|
|
|
|
2020-04-16 20:59:20 -04:00
|
|
|
.PHONY: pack
|
|
|
|
pack:
|
|
|
|
rm blkfs && $(MAKE) blkfs
|
|
|
|
|
|
|
|
.PHONY: unpack
|
|
|
|
unpack:
|
|
|
|
$(BLKUNPACK) ../blk < blkfs
|
|
|
|
|
2019-05-09 12:58:41 -04:00
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
2020-04-14 14:25:14 -04:00
|
|
|
rm -f $(TARGETS) emul.o forth/*-bin.h forth/forth?.bin blkfs
|
2020-04-07 17:56:55 -04:00
|
|
|
$(MAKE) -C ../tools clean
|