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