-
Notifications
You must be signed in to change notification settings - Fork 16
/
Makefile
62 lines (50 loc) · 1.59 KB
/
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
50
51
52
53
54
55
56
57
58
59
60
61
62
###############################################################################
# Makefile for boom-attacks
###########################
# Makes baremetal executables to run on BOOM
###############################################################################
# Folders
SRC:=src
INC:=inc
LNK:=link
OBJ:=obj
BIN:=bin
DMP:=dump
DEP:=dep
# Commands and flags
CC:=riscv64-unknown-elf-gcc
OBJDUMP:=riscv64-unknown-elf-objdump -S
CFLAGS=-mcmodel=medany -l -std=gnu99 -O0 -g -fno-common -fno-builtin-printf -Wall -I$(INC) -Wno-unused-function -Wno-unused-variable
LDFLAGS:=-static -nostdlib -nostartfiles -lgcc
DEPFLAGS=-MT $@ -MMD -MP -MF $(DEP)/$*.d
RM=rm -rf
# Programs to compile
PROGRAMS=condBranchMispred returnStackBuffer indirBranchMispred
BINS=$(addprefix $(BIN)/,$(addsuffix .riscv,$(PROGRAMS)))
DUMPS=$(addprefix $(DMP)/,$(addsuffix .dump,$(PROGRAMS)))
.PHONY: all
all: $(BINS) $(DUMPS)
dumps: $(DUMPS)
# Build object files
$(OBJ)/%.o: $(SRC)/%.S
@mkdir -p $(OBJ)
$(CC) $(CFLAGS) -D__ASSEMBLY__=1 -c $< -o $@
$(OBJ)/%.o: $(SRC)/%.c
@mkdir -p $(OBJ)
@mkdir -p $(DEP)
$(CC) $(CFLAGS) $(DEPFLAGS) -c $< -o $@
# Build executable
$(BIN)/%.riscv: $(OBJ)/%.o $(OBJ)/crt.o $(OBJ)/syscalls.o $(OBJ)/stack.o $(LNK)/link.ld
@mkdir -p $(BIN)
$(CC) -T $(LNK)/link.ld $(LDFLAGS) $< $(OBJ)/crt.o $(OBJ)/stack.o $(OBJ)/syscalls.o -o $@
# Build dump
$(DMP)/%.dump: $(BIN)/%.riscv
@mkdir -p $(DMP)
$(OBJDUMP) -D $< > $@
# Keep the temporary .o files
.PRECIOUS: $(OBJ)/%.o
# Remove all generated files
clean:
rm -rf $(BIN) $(OBJ) $(DMP) $(DEP)
# Include dependencies
-include $(addprefix $(DEP)/,$(addsuffix .d,$(PROGRAMS)))