-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathMakefile
More file actions
70 lines (52 loc) · 1.45 KB
/
Copy pathMakefile
File metadata and controls
70 lines (52 loc) · 1.45 KB
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
63
64
65
66
67
68
69
70
CC := gcc
AS := as
LD := ld
OBJECTS_COMMON := main.o spectre_lab_helper.o
OBJECTS_PART1 := $(OBJECTS_COMMON) attacker-part1.o
TARGET_PART1 := part1
OBJECTS_PART2 := $(OBJECTS_COMMON) attacker-part2.o
TARGET_PART2 := part2
OBJECTS_PART3 := $(OBJECTS_COMMON) attacker-part3.o
TARGET_PART3 := part3
BUILD_OBJECTS_PART1 := $(patsubst %,build/%,$(OBJECTS_PART1))
BUILD_OBJECTS_PART2 := $(patsubst %,build/%,$(OBJECTS_PART2))
BUILD_OBJECTS_PART3 := $(patsubst %,build/%,$(OBJECTS_PART3))
TARGETS := $(TARGET_PART1) $(TARGET_PART2) $(TARGET_PART3)
ASFLAGS :=
CFLAGS := -Iinc -g -O0
.PHONY: all clean
all: $(TARGETS)
clean:
rm -rf build $(TARGETS)
build/%.o: src-common/%.s
@echo " AS $<"
@mkdir -p build
@$(AS) -c $(ASFLAGS) $< -o $@
build/%.o: src-common/%.c
@echo " CC $<"
@mkdir -p build
@$(CC) -c $(CFLAGS) $< -o $@
build/%.o: part1-src/%.c
@echo " CC $<"
@mkdir -p build
@$(CC) -c $(CFLAGS) $< -o $@
build/%.o: part2-src/%.c
@echo " CC $<"
@mkdir -p build
@$(CC) -c $(CFLAGS) $< -o $@
build/%.o: part3-src/%.c
@echo " CC $<"
@mkdir -p build
@$(CC) -c $(CFLAGS) $< -o $@
$(TARGET_PART1): $(BUILD_OBJECTS_PART1) Makefile
@echo " LD $@"
@mkdir -p build
@$(CC) -o $@ $(BUILD_OBJECTS_PART1)
$(TARGET_PART2): $(BUILD_OBJECTS_PART2) Makefile
@echo " LD $@"
@mkdir -p build
@$(CC) -o $@ $(BUILD_OBJECTS_PART2)
$(TARGET_PART3): $(BUILD_OBJECTS_PART3) Makefile
@echo " LD $@"
@mkdir -p build
@$(CC) -o $@ $(BUILD_OBJECTS_PART3)