-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathMakefile
167 lines (136 loc) · 4.1 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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
#
# Top level Makefile for openperf
#
all: openperf libopenperf-shim
.PHONY: deps
deps:
@git submodule init && git submodule update
.PHONY: openperf
openperf: deps
@cd targets/openperf && $(MAKE)
.PHONY: libopenperf-shim
libopenperf-shim: deps
@cd targets/libopenperf-shim && $(MAKE)
.PHONY: package-deb
package-deb: openperf libopenperf-shim deps
@cd pkg && $(MAKE) package-deb
.PHONY: test
test: test_unit test_aat
.PHONY: test_aat
test_aat: openperf libopenperf-shim
@cd tests/aat && $(MAKE)
.PHONY: test_aat_%
test_aat_%: openperf libopenperf-shim
@cd tests/aat && $(MAKE) progress_$*
.PHONY: test_unit
test_unit: deps
@cd tests/unit && $(MAKE)
.PHONY: clean
clean: image_clean codegen_clean api_clean
@cd targets/openperf && $(MAKE) clean
@cd targets/libopenperf-shim && $(MAKE) clean
@cd pkg && $(MAKE) clean
@cd tests/aat && $(MAKE) clean
@cd tests/unit && $(MAKE) clean
@rm -f compile_commands.json
#
# Targets for Docker image
#
DOCKER_IMAGE=openperf-contrib
include mk/versions.mk
.PHONY: image
image: deps
@DOCKER_IMAGE=${DOCKER_IMAGE} GIT_COMMIT=${GIT_COMMIT} GIT_VERSION=${GIT_VERSION} BUILD_NUMBER=${BUILD_NUMBER} \
bash contrib/docker/build.sh
.PHONY: image_test_aat
image_test_aat: image
@cd tests/aat && $(MAKE) progress_docker
.PHONY: image_pack
image_pack: image
@docker save -o openperf-${GIT_VERSION}.tar ${DOCKER_IMAGE}
.PHONY: image_clean
image_clean:
ifneq ($(shell which docker), )
@docker image rm -f ${DOCKER_IMAGE}
@docker image prune -f
endif
# Generate code from schema definitions
# Since generated code is stored in the repo, manual generation is only required
# when the schema files are updated. Commit any schema changes and resulting
# generated code updates back to the source repository.
.PHONY: codegen
codegen: schema_codegen
.PHONY: schema_codegen
schema_codegen: packet_protocol_codegen
@cd api/schema && $(MAKE)
.PHONY: packet_protocol_codegen
packet_protocol_codegen: libpacket_codegen
@cd src/modules/packet/protocol && $(MAKE)
.PHONY: libpacket_codegen
libpacket_codegen:
@cd src/lib/packet && $(MAKE)
.PHONY: codegen_clean
codegen_clean:
@cd src/modules/packet/protocol && $(MAKE) clean
@cd src/lib/packet && $(MAKE) clean
###
# Targets for combined schema api
###
.PHONY: api
api:
@mkdir -p build/api
$(strip deps/swagger-codegen/swagger-codegen generate \
-DoutputFile=openperf.yaml \
-l swagger-yaml \
-i api/schema/v1/openperf.yaml \
-o build/api)
.PHONY: api_clean
api_clean:
@rm -rf build/api
###
# Targets for code formatting and analysis
###
.PHONY: pretty
pretty: pretty-cpp pretty-c
# We skip a lot of the C-code....
# We want to leave white-space as-is for any LwIP derived code so that we can
# easily compare deltas when upgrading.
# We also skip over anything with the C11 _Generic keyword; clang-format
# doesn't handle it correctly.
pretty-c:
@find src targets tests \
-path src/swagger -prune -o \
-type f \( \
-iname \*.c -o \
-iname \*.h \) \
! -name bsd_tree.h \
$(shell printf "! -name %s " $(shell basename -a $(shell grep -rl "This file is part of the lwIP" src))) \
$(shell printf "! -name %s " $(shell basename -a $(shell grep -rl _Generic src))) \
-print0 | xargs -0 clang-format -i -style=file
pretty-cpp:
@find src targets tests \
-path src/swagger -prune -o \
-path src/lib/packet/protocol -prune -o \
-path src/modules/packet/protocol/transmogrify -prune -o \
-type f \( \
-iname \*.cpp -o \
-iname \*.hpp -o \
-iname \*.tcc \) \
-print0 | xargs -0 clang-format -i -style=file
# clang-tidy requires a compile_commands.json file which is oustide the scope
# of this Makefile. Hence, we make the file a requirement but don't provide
# a rule to build it.
.PHONY: tidy
TIDY_ARGS:= -quiet
ifneq (,$(TIDY_JOBS))
TIDY_ARGS+= -j $(TIDY_JOBS)
endif
tidy: compile_commands.json
@find src \
-path src/swagger -prune -o \
-path src/lib/packet/protocol -prune -o \
-path src/modules/packet/protocol/transmogrify -prune -o \
-iname \*.cpp -print0 \
| xargs -0 run-clang-tidy $(strip $(TIDY_ARGS)) \
-header-filter='^$(shell pwd)/src/.*hpp,-^$(shell pwd)/src/modules/socket/dpdk/.*hpp' \
-extra-arg=-Wno-shadow