[667] | 1 | # where is soclib? |
---|
| 2 | # |
---|
| 3 | SOCLIB_DIR=$(shell soclib-cc --getpath) |
---|
| 4 | |
---|
| 5 | # name definitions |
---|
| 6 | # |
---|
| 7 | SOCLIB_DESC=desc.py |
---|
| 8 | SOCLIB_TOP=top.cpp |
---|
| 9 | SIMULATOR_BINARY=system.x |
---|
| 10 | SIMULATOR_CMD=./$(SIMULATOR_BINARY) --nobanner |
---|
| 11 | |
---|
| 12 | # extra arguments for compilation |
---|
| 13 | # |
---|
| 14 | #SOCLIB_CC_ARGS=-v |
---|
| 15 | SOCLIB_CC_ARGS+=-b common:mips32 |
---|
| 16 | |
---|
| 17 | # extra arguments for execution |
---|
| 18 | # |
---|
| 19 | # gdb |
---|
| 20 | # - F: start the simulation in a frozen state so it can be attached with a gdb |
---|
| 21 | # client |
---|
| 22 | # - X: disable automatic break whenever an exception is caught, the exception |
---|
| 23 | # handler will be called transparently |
---|
| 24 | # - S: make the simulation stop and wait for a gdb attachment whenever an |
---|
| 25 | # exception is caught |
---|
| 26 | # - C: dump a trace of every inter-functions branch |
---|
| 27 | # - T: exit the simulator on trap exception |
---|
| 28 | # - Z: same as C but display only function's entrypoint |
---|
| 29 | # - W: disable automatic break whenever a watchpoint is hit, just report it on |
---|
| 30 | # stderr (watchpoints can be defined using SOCLIB_GDB_WATCH) |
---|
| 31 | SIMULATOR_GDB= |
---|
| 32 | ifeq ("$(origin GDB)", "command line") |
---|
| 33 | ifeq ($(GDB), 1) |
---|
| 34 | SIMULATOR_GDB=SOCLIB_GDB=FCX |
---|
| 35 | else |
---|
| 36 | SIMULATOR_GDB=SOCLIB_GDB=$(GDB) |
---|
| 37 | endif |
---|
| 38 | endif |
---|
| 39 | # ncpus |
---|
| 40 | SIMULATOR_NCPUS=4 |
---|
| 41 | ifeq ("$(origin NCPUS)", "command line") |
---|
| 42 | SIMULATOR_NCPUS=$(NCPUS) |
---|
| 43 | endif |
---|
| 44 | # vmlinux |
---|
| 45 | SIMULATOR_VMLINUX=./vmlinux |
---|
| 46 | ifeq ("$(origin VMLINUX)", "command line") |
---|
| 47 | SIMULATOR_VMLINUX=$(VMLINUX) |
---|
| 48 | endif |
---|
| 49 | # dsk |
---|
| 50 | SIMULATOR_DSK= |
---|
| 51 | ifeq ("$(origin DSK)", "command line") |
---|
| 52 | SIMULATOR_DSK=--dsk $(DSK) |
---|
| 53 | endif |
---|
| 54 | # trace |
---|
| 55 | SIMULATOR_TRACE= |
---|
| 56 | ifeq ("$(origin TRACE)", "command line") |
---|
| 57 | SIMULATOR_TRACE=--trace $(TRACE) |
---|
| 58 | endif |
---|
| 59 | # ncycles |
---|
| 60 | SIMULATOR_NCYCLES= |
---|
| 61 | ifeq ("$(origin NCYCLES)", "command line") |
---|
| 62 | SIMULATOR_NCYCLES=--ncycles $(NCYCLES) |
---|
| 63 | endif |
---|
| 64 | |
---|
| 65 | # recipes |
---|
| 66 | all: $(SIMULATOR_BINARY) |
---|
| 67 | |
---|
| 68 | $(SIMULATOR_BINARY): $(SOCLIB_DESC) $(SOCLIB_TOP) |
---|
| 69 | soclib-cc $(SOCLIB_CC_ARGS) -P -p $(SOCLIB_DESC) -o $(SIMULATOR_BINARY) |
---|
| 70 | |
---|
| 71 | run_tsar_boot: all tsar_boot.bin |
---|
| 72 | $(SIMULATOR_GDB) $(SIMULATOR_CMD) --ncpus $(SIMULATOR_NCPUS) --rom tsar_boot.bin $(SIMULATOR_DSK) $(SIMULATOR_TRACE) $(SIMULATOR_NCYCLES) |
---|
| 73 | |
---|
| 74 | run_dummy_boot: all |
---|
| 75 | $(SIMULATOR_GDB) $(SIMULATOR_CMD) --ncpus $(SIMULATOR_NCPUS) --rom $(SIMULATOR_VMLINUX) $(SIMULATOR_DSK) --dummy-boot $(SIMULATOR_TRACE) $(SIMULATOR_NCYCLES) |
---|
| 76 | |
---|
| 77 | cscope.out: |
---|
| 78 | soclib-cc -p $(SOCLIB_DESC) --tags |
---|
| 79 | |
---|
| 80 | clean: |
---|
| 81 | soclib-cc -P -p $(SOCLIB_DESC) -x -o $(SIMULATOR_BINARY) |
---|
| 82 | rm -f $(SIMULATOR_BINARY) *.o vci* |
---|
| 83 | |
---|
| 84 | .PHONY: $(SIMULATOR_BINARY) |
---|