-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
52 lines (37 loc) · 1.21 KB
/
Makefile
File metadata and controls
52 lines (37 loc) · 1.21 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
# SPDX-License-Identifier: GPL-2.0-or-later
VERBOSE ?= @
SRCDIR := src
OBJDIR := build
ARGS :=
CC := clang
CFLAGS := -std=c2x -Wconversion -Wall -Werror -D_GNU_SOURCE -g $(shell pkg-config --cflags numa) -I $(OBJDIR)
LDFLAGS := $(shell pkg-config --libs numa)
.PHONY: all build build_all generate_params run run_all clean
TARGET := $(OBJDIR)/benchmark
# parameters for each workload can be generated using 'generate_params'-target
PARAMS := $(OBJDIR)/parameters.h
all: $(TARGET)
dummy_params:
@mkdir -p $(dir $(PARAMS))
cp $(SRCDIR)/example-parameters.h $(PARAMS)
generate_params:
@mkdir -p $(OBJDIR)
./scripts/generate_params.py "$(OBJDIR)"
build_all:
./scripts/for_all.py build "$(OBJDIR)"
build: $(TARGET)
run_all:
./scripts/for_all.py run "$(OBJDIR)"
run: $(OBJDIR)/results.csv
$(OBJDIR)/results.csv: $(OBJDIR)/benchmark
scripts/measure.sh "$(OBJDIR)" "$@"
$(OBJDIR)/benchmark: $(OBJDIR)/benchmark.o $(OBJDIR)/configuration.o $(OBJDIR)/allocator.o $(PARAMS)
@echo "LD $@"
$(VERBOSE) $(CC) $(CFLAGS) $(filter %.o,$^) $(LDFLAGS) -o $@
$(OBJDIR)/%.o: $(SRCDIR)/%.c $(PARAMS)
@echo "C $@"
@mkdir -p $(dir $@)
$(VERBOSE) $(CC) $(CFLAGS) -c $< -o $@
clean:
@echo "RM $(OBJDIR)"
$(VERBOSE) rm -rf $(OBJDIR)