-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
executable file
·50 lines (38 loc) · 1021 Bytes
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
include mips_sc/src/Makefile.testcase
.PHONY: run clean
ifndef INCLUDE_DIR
INCLUDE_DIR := ./temu/include
endif
ifndef SRC_DIR
SRC_DIR := ./temu/src
endif
ifndef BUILD_DIR
BUILD_DIR := build/
endif
DEBUG := false
# Compilation flags
CC := gcc
CFLAGS := -I$(INCLUDE_DIR) -I$(INCLUDE_DIR)/cpu -I$(INCLUDE_DIR)/memory -I$(INCLUDE_DIR)/monitor -Wall -Werror
LDFLAGS := -lreadline
# Files to be compiled
SRCS := $(wildcard $(SRC_DIR)/*.c) $(wildcard $(SRC_DIR)/memory/*.c) $(wildcard $(SRC_DIR)/cpu/*.c) $(wildcard $(SRC_DIR)/monitor/*.c)
TEMU_TARGET := temu
ifeq ($(DEBUG), true)
CFLAGS += -g
endif
export INCLUDE_DIR
export SRC_DIR
export BUILD_DIR
# ********************
# Rules of Compilation
# ********************
$(BUILD_DIR)$(TEMU_TARGET):
@mkdir -p $(BUILD_DIR)
$(CC) $(CFLAGS) $(LDFLAGS) -o $@ $(SRCS)
@git commit --allow-empty -q -m "compile"
run: $(BUILD_DIR)$(TEMU_TARGET)
@./$(BUILD_DIR)$(TEMU_TARGET) $(USER_PROGRAM)
@git commit --allow-empty -q -m "run"
clean:
rm -r $(BUILD_DIR)
rm log.txt