forked from hpca-uji/ConvLIB
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
112 lines (86 loc) · 3.53 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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
include Makefile.inc
#------------------------------------------
#| COMPILERS |
#------------------------------------------
OPTFLAGS=
ifneq ($(MAKECMDGOALS),clean)
ifeq ($(arch), riscv)
CC = riscv64-unknown-linux-gnu-gcc
CLINKER = riscv64-unknown-linux-gnu-gcc
#OPTFLAGS += -O3 -fopenmp -march=rv64imafdcv0p7_zfh_xtheadc -mabi=lp64d -mtune=c910
OPTFLAGS = -O0 -g3 -march=rv64gcv0p7_zfh_xtheadc -mabi=lp64d -DFP32 -mtune=c906 -static -DRISCV
else ifeq ($(arch), armv8)
CC = gcc
CLINKER = gcc
OPTFLAGS = -march=armv8-a -O3 -DCHECK -DARMV8 -DFP32
else
$(error Architecture unsuported. Please use arch=[riscv|armv8])
endif
endif
#------------------------------------------
OPTFLAGS += -fopenmp -DOMP_ENABLE
OBJDIR = build
BIN = convolution_driver.x
#------------------------------------------
LIBS = -lm
LIBS_LINKER = $(LIBS)
INCLUDE =
WINOGRAD = ENABLE_WINOGRAD
#------------------------------------------
ifeq ($(BLIS_ENABLE), T)
INCLUDE += -I$(BLIS_HOME)/include/blis/
LIBS_LINKER += $(BLIS_HOME)/lib/libblis.a
OPTFLAGS += -DENABLE_BLIS
else
WINOGRAD = DISABLE_WINOGRAD
endif
ifeq ($(OPENBLAS_ENABLE), T)
INCLUDE += -I$(OPENBLAS_HOME)/include/
LIBS_LINKER += $(OPENBLAS_HOME)/lib/libopenblas.a
OPTFLAGS += -DENABLE_OPENBLAS
else
WINOGRAD = DISABLE_WINOGRAD
endif
#------------------------------------------
SRC_ASM_FILES = $(wildcard ./src/asm_generator/ukernels/*.S)
OBJ_ASM_FILES = $(patsubst ./src/asm_generator/ukernels/%.S, $(OBJDIR)/%.o, $(SRC_ASM_FILES))
OBJ_FILES += $(OBJ_ASM_FILES)
SRC_CONV_FILES = $(wildcard ./src/*.c)
OBJ_CONV_FILES = $(patsubst ./src/%.c, $(OBJDIR)/%.o, $(SRC_CONV_FILES))
SRC_GEMM_FILES = $(wildcard ./src/gemm/*.c)
OBJ_GEMM_FILES = $(patsubst ./src/gemm/%.c, $(OBJDIR)/%.o, $(SRC_GEMM_FILES))
SRC_CONVGEMM_FILES = $(wildcard ./src/convGemm/*.c)
OBJ_CONVGEMM_FILES = $(patsubst ./src/convGemm/%.c, $(OBJDIR)/%.o, $(SRC_CONVGEMM_FILES))
ifeq ($(arch), armv8)
ifeq ($(WINOGRAD), ENABLE_WINOGRAD)
SRC_WINOGRAD_FILES = $(wildcard ./src/convWinograd/*.c)
OBJ_WINOGRAD_FILES = $(patsubst ./src/convWinograd/%.c, $(OBJDIR)/%.o, $(SRC_WINOGRAD_FILES))
endif
else
WINOGRAD = DISABLE_WINOGRAD
endif
OBJ_FILES = $(OBJDIR)/model_level.o $(OBJDIR)/selector_ukernel.o $(OBJDIR)/gemm_ukernel.o $(OBJ_CONV_FILES) $(OBJ_ASM_FILES) $(OBJ_GEMM_FILES) $(OBJ_CONVGEMM_FILES) $(OBJ_WINOGRAD_FILES)
OPTFLAGS += -D$(WINOGRAD)
all: $(OBJDIR)/$(BIN)
$(OBJDIR)/$(BIN): $(OBJ_FILES)
$(CLINKER) $(OPTFLAGS) -o $@ $^ $(LIBS_LINKER)
$(OBJDIR)/%.o: ./src/%.c
$(CC) $(CFLAGS) $(OPTFLAGS) -c -o $@ $< $(INCLUDE) $(LIBS)
$(OBJDIR)/%.o: ./src/gemm/%.c
$(CC) $(CFLAGS) $(OPTFLAGS) -c -o $@ $< $(INCLUDE) $(LIBS)
$(OBJDIR)/%.o: ./src/convGemm/%.c
$(CC) $(CFLAGS) $(OPTFLAGS) -c -o $@ $< $(INCLUDE) $(LIBS)
$(OBJDIR)/%.o: ./src/convWinograd/%.c
$(CC) $(CFLAGS) $(OPTFLAGS) -c -o $@ $< $(INCLUDE) $(LIBS)
$(OBJDIR)/%.o: ./src/asm_generator/ukernels/%.S
$(CC) $(CFLAGS) $(OPTFLAGS) -c -o $@ $< $(INCLUDE) $(LIBS)
$(OBJDIR)/model_level.o: ./src/modelLevel/model_level.c
mkdir -p $(OBJDIR)
mkdir -p output
$(CC) $(CFLAGS) $(OPTFLAGS) -c -o $@ $< $(INCLUDE) $(LIBS)
$(OBJDIR)/gemm_ukernel.o: ./src/asm_generator/ukernels/gemm_ukernel.c
$(CC) $(CFLAGS) $(OPTFLAGS) -c -o $@ $< $(INCLUDE) $(LIBS)
$(OBJDIR)/selector_ukernel.o: ./src/asm_generator/ukernels/selector_ukernel.c
$(CC) $(CFLAGS) $(OPTFLAGS) -c -o $@ $< $(INCLUDE) $(LIBS)
clean:
rm $(OBJDIR)/*