1
0
Fork 0
mirror of https://github.com/pnx/m16vm synced 2026-06-16 03:44:55 +02:00
m16vm/Makefile

45 lines
1 KiB
Makefile

# ---------------------------------------------------------------------------
# m16 Makefile.
# ---------------------------------------------------------------------------
#
# The following debug flags exists:
#
# * MEM_SIZE=<value>
# Defines the memory size of the virtual machine (in bytes)
#
# * M16_DEBUG_MEM
# Prints memory after program execution.
#
# * M16_DEBUG_REG
# Prints register values after program execution.
#
# * M16_DEBUG_INSTR
# Outputs the instructions executed in a human-readable format.
#
CC = gcc
CFLAGS = -g -Ilib/include -DMEM_SIZE=32 -DM16_DEBUG_MEM
LD = $(CC)
PROGRAMS = m16vm m16as
all: $(PROGRAMS)
m16vm : vm/vm.o vm/cpu.o vm/mm.o vm/instr_decode.o vm/syscall.o vm/program.o
$(LD) $(LDFLAGS) -o $@ $^
m16as : as/as.o as/parser.o as/lexer.o \
as/codegen.o as/error.o as/symtab.o \
as/ast.o lib/libm16.a
$(LD) $(LDFLAGS) -o $@ $^
lib/libm16.a : lib/vector.o
$(AR) rcs $@ $^
clean :
$(RM) as/*.o
$(RM) vm/*.o
$(RM) lib/*.o
$(RM) lib/*.a
distclean : clean
$(RM) $(PROGRAMS)