collapseos/emul/Makefile

69 lines
2.1 KiB
Makefile
Raw Normal View History

TARGETS = runbin/runbin forth/forth
# Those Forth source files are in a particular order
FORTHSRCS = core.fs print.fs str.fs parse.fs readln.fs fmt.fs z80a.fs
FORTHSRC_PATHS = ${FORTHSRCS:%=../forth/%} forth/run.fs
OBJS = emul.o libz80/libz80.o
SLATEST = ../tools/slatest
2020-04-04 10:27:21 -04:00
STRIPFC = ../tools/stripfc
2019-05-09 14:09:40 -04:00
2019-05-09 12:58:41 -04:00
.PHONY: all
all: $(TARGETS)
2019-05-09 12:58:41 -04:00
2020-04-04 10:27:21 -04:00
$(STRIPFC):
$(SLATEST):
$(MAKE) -C ../tools
# z80c.bin and boot.bin are not in the prerequisites because they're bootstrap
# binaries that should be updated manually through make updatebootstrap.
forth/forth0.bin: $(SLATEST)
cat forth/boot.bin forth/z80c.bin > $@
$(SLATEST) $@
cat forth/emul.fs >> $@
2020-03-09 22:26:02 -04:00
forth/forth0-bin.h: forth/forth0.bin
./bin2c.sh KERNEL < forth/forth0.bin | tee $@ > /dev/null
2020-03-09 22:26:02 -04:00
forth/stage1: forth/stage.c $(OBJS) forth/forth0-bin.h
$(CC) forth/stage.c $(OBJS) -o $@
forth/stage1dbg: forth/stage.c $(OBJS) forth/forth0-bin.h
$(CC) -DDEBUG forth/stage.c $(OBJS) -o $@
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-04 10:27:21 -04:00
cat $(FORTHSRC_PATHS) ./forth/stop.fs | $(STRIPFC) | ./forth/stage1 | tee $@ > /dev/null
2020-03-24 21:13:02 -04:00
forth/forth1.bin: forth/core.bin $(SLATEST)
cat forth/boot.bin forth/z80c.bin forth/core.bin > $@
$(SLATEST) $@
forth/forth1-bin.h: forth/forth1.bin
./bin2c.sh KERNEL < forth/forth1.bin | tee $@ > /dev/null
forth/stage2: forth/stage.c $(OBJS) forth/forth1-bin.h
$(CC) -DSTAGE2 forth/stage.c $(OBJS) -o $@
2020-03-24 21:13:02 -04:00
forth/forth: forth/forth.c $(OBJS) forth/forth1-bin.h
2020-03-09 22:26:02 -04:00
$(CC) forth/forth.c $(OBJS) -o $@
runbin/runbin: runbin/runbin.c $(OBJS)
$(CC) runbin/runbin.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
emul.o: emul.c
$(CC) -c -o emul.o emul.c
.PHONY: updatebootstrap
updatebootstrap: forth/stage2
cat ./forth/conf.fs ../forth/boot.fs | ./forth/stage2 | tee forth/boot.bin > /dev/null
cat ./forth/conf.fs ../forth/z80c.fs ../forth/icore.fs | ./forth/stage2 | tee forth/z80c.bin > /dev/null
2019-05-09 12:58:41 -04:00
.PHONY: clean
clean:
rm -f $(TARGETS) emul.o forth/*-bin.h forth/forth?.bin