diff options
author | Nao Pross <naopross@thearcway.org> | 2017-05-02 00:06:10 +0200 |
---|---|---|
committer | Nao Pross <naopross@thearcway.org> | 2017-05-02 00:06:10 +0200 |
commit | 752e0fd9ec166ea8a513294fd44b7203af03d684 (patch) | |
tree | 94f6000ed20ef39bfdd3f85caad801a6e53ba072 /sw/z80/makefile | |
parent | Merge branch 'master' of https://github.com/NaoPross/z80uPC (diff) | |
download | z80uPC-752e0fd9ec166ea8a513294fd44b7203af03d684.tar.gz z80uPC-752e0fd9ec166ea8a513294fd44b7203af03d684.zip |
switch to sdcc
- update of the makefile to use sdcc, since it is more popular and
it's easier to insall on other computers
- fix of crt0.s (old loader.asm) for the new compiler
- change of the structure in the source code folder to separate
betweeen libc and kernel code
Diffstat (limited to 'sw/z80/makefile')
-rw-r--r-- | sw/z80/makefile | 34 |
1 files changed, 22 insertions, 12 deletions
diff --git a/sw/z80/makefile b/sw/z80/makefile index 94646a9..ecdd9a4 100644 --- a/sw/z80/makefile +++ b/sw/z80/makefile @@ -2,26 +2,36 @@ # source code settings # OSNAME := helvetiOS - -CSOURCES := $(wildcard *.c) -BINARY := $(OSNAME).bin + +CSOURCES := $(wildcard kernel/*.c) $(wildcard libc/*.c) +HEXFILE := build/$(OSNAME).hex +BINARY := build/$(OSNAME).bin ### # compiler settings -# -CC := zcc -CARGS := -Wall -I . -DDEBUG -crt0 loader -asm z80asm -nostdlib + +CC := sdcc + +CFLAGS := -mz80 --no-std-crt0 crt0.rel \ + -I kernel/include -I libc/include -DDEBUG + +LDFLAGS := --code-loc 0x0800 --data-loc 0x8000 all: $(BINARY) # build binary -$(BINARY): $(CSOURCES) - cp loader.asm loader.opt - $(CC) $(CARGS) $(CSOURCES) -o $@ +$(BINARY): $(CSOURCES) crt0.rel + mkdir -p build + $(CC) $(CFLAGS) $(LDFLSGS) $(CSOURCES) -o $(HEXFILE) + xxd -r -p $(HEXFILE) $(BINARY) + +crt0.rel: crt0.s + sdasz80 -o $< dis: $(BINARY) - z80dasm -a -g 0h $< + z80dasm -a -g 0h $< -o $(OSNAME).s clean: - - rm $(BINARY) - - rm loader.opt + - rm build/* + - rm $(OSNAME).s + - rm crt0.rel |