forked from p4lang/p4c-behavioral
-
Notifications
You must be signed in to change notification settings - Fork 2
/
p4c-bm.mk
147 lines (113 loc) · 6.1 KB
/
p4c-bm.mk
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
THIS_DIR := $(dir $(lastword $(MAKEFILE_LIST)))
ifndef P4FACTORY
$(error P4FACTORY not defined)
endif
MAKEFILES_DIR := $(P4FACTORY)/makefiles
ifndef SUBMODULE_P4C_BEHAVIORAL
$(error SUBMODULE_P4C_BEHAVIORAL not defined)
endif
ifndef P4_NAME
$(error P4_NAME not defined)
endif
ifndef P4_PREFIX
P4_PREFIX := ${P4_NAME}
endif
# Behavioral compiler; default is to use the one in local submodule
BM_SHELL := ${SUBMODULE_P4C_BEHAVIORAL}/p4c_bm/shell.py
BM_BUILD_DIR := ${BUILD_DIR}/bm
BM_OBJ_DIR := ${BM_BUILD_DIR}/obj
BM_BUILD_SRC_DIR := ${BM_BUILD_DIR}/src
BM_BUILD_THRIFT_DIR := ${BM_BUILD_DIR}/thrift
MAKE_DIR := ${BM_BUILD_DIR}
include $(MAKEFILES_DIR)/makedir.mk
MAKE_DIR := ${BM_OBJ_DIR}
include $(MAKEFILES_DIR)/makedir.mk
MAKE_DIR := $(BM_BUILD_SRC_DIR)
include $(MAKEFILES_DIR)/makedir.mk
MAKE_DIR := $(PUBLIC_INC_PATH)/p4_sim
include $(MAKEFILES_DIR)/makedir.mk
BM_PARAMS := --gen-dir=${BM_BUILD_DIR}/ --thrift --public-inc-path=$(PUBLIC_INC_PATH)/p4_sim
BM_PARAMS += --p4-prefix=${P4_PREFIX}
ifdef BM_P4_META_CONFIG
BM_PARAMS += --meta-config=${BM_P4_META_CONFIG}
endif
BM_TEMPLATES_C := $(wildcard ${THIS_DIR}/p4c_bm/templates/src/*.c)
BM_TEMPLATES_H := $(wildcard ${THIS_DIR}/p4c_bm/templates/src/*.h)
BM_TEMPLATES_H += $(wildcard ${THIS_DIR}/p4c_bm/templates/src/*.ipp)
BM_TEMPLATES_CPP := $(wildcard ${THIS_DIR}/p4c_bm/templates/src/*.cpp)
BM_TEMPLATES_PUBLIC_HEADERS := $(wildcard ${THIS_DIR}/p4c_bm/templates/inc/*.h)
BM_TEMPLATES_THRIFT := $(wildcard ${THIS_DIR}/p4c_bm/templates/thrift/*.thrift)
BM_TEMPLATES := ${BM_TEMPLATES_C} ${BM_TEMPLATES_H} ${BM_TEMPLATES_CPP} ${BM_TEMPLATES_PUBLIC_HEADERS} ${BM_TEMPLATES_THRIFT}
# compile the plugins
include $(THIS_DIR)/p4c_bm/plugin/p4c-plugin.mk
BM_TENJIN_OUTPUT_C := $(addprefix ${BM_BUILD_SRC_DIR}/, $(notdir ${BM_TEMPLATES_C}))
BM_TENJIN_OUTPUT_H := $(addprefix ${BM_BUILD_DIR}/src/, $(notdir ${BM_TEMPLATES_H}))
BM_TENJIN_OUTPUT_CPP += $(addprefix ${BM_BUILD_DIR}/src/, $(notdir ${BM_TEMPLATES_CPP}))
PD_PUBLIC_HEADERS_DIR := ${PUBLIC_INC_PATH}/p4_sim
BM_TENJIN_OUTPUT_PUBLIC_HEADERS := $(addprefix ${PD_PUBLIC_HEADERS_DIR}/, $(notdir ${BM_TEMPLATES_PUBLIC_HEADERS}))
THRIFT_FILES_WITH_SERVICES = p4_pd_rpc conn_mgr_pd_rpc mc_pd_rpc devport_mgr_pd_rpc
THRIFT_FILES = ${THRIFT_FILES_WITH_SERVICES} res
THRIFT_SERVICES = ${P4_PREFIX} conn_mgr mc devport_mgr
THRIFT_PD_BASENAMES = $(addsuffix _constants, ${THRIFT_FILES})
THRIFT_PD_BASENAMES += $(addsuffix _types, ${THRIFT_FILES})
THRIFT_PD_BASENAMES += ${THRIFT_SERVICES}
BM_TENJIN_OUTPUT_THRIFT = $(addprefix ${BM_BUILD_THRIFT_DIR}/, $(addsuffix .thrift, ${THRIFT_FILES}))
BM_TENJIN_OUTPUT_THRIFT_SERVICES = $(addprefix ${BM_BUILD_THRIFT_DIR}/, $(addsuffix .thrift, ${THRIFT_FILES_WITH_SERVICES}))
# Output of Tenjin are the following files:
# p4c_bm/templates/src/*.c
# p4c_bm/templates/src/*.h
# p4c_bm/templates/inc/*.h
# p4c_bm_templates/src/*.cpp
# p4c_bm_templates/thrift/*.thrift
# All files are output to ${BM_BUILD_DIR}/src/
BM_TENJIN_OUTPUT := ${BM_TENJIN_OUTPUT_C} ${BM_TENJIN_OUTPUT_H} ${BM_TENJIN_OUTPUT_CPP} ${BM_TENJIN_OUTPUT_THRIFT} ${BM_TENJIN_OUTPUT_PUBLIC_HEADERS}
BM_TENJIN_OUTPUT_NEWEST := $(shell ls -t ${BM_TENJIN_OUTPUT} 2> /dev/null | head -1)
BM_TENJIN_OUTPUT_OLDEST := $(shell ls -tr ${BM_TENJIN_OUTPUT} 2> /dev/null | head -1)
# For a first-time build, above 2 variables will be empty.
ifeq (${BM_TENJIN_OUTPUT_NEWEST},)
BM_TENJIN_OUTPUT_NEWEST := ${BM_BUILD_SRC_DIR}/pd.c
endif
ifeq (${BM_TENJIN_OUTPUT_OLDEST},)
BM_TENJIN_OUTPUT_OLDEST := bm_tenjin_output_oldest
endif
# Make the oldest Tenjin output depend on P4 program and input templates.
${BM_TENJIN_OUTPUT_OLDEST}: %: $(BM_TEMPLATES) ${P4_INPUT} $(wildcard ${P4_INCLUDES_DIR}/*.p4) $(wildcard ${P4_INCLUDES_DIR}/*.h)
${BM_SHELL} ${P4_INPUT} ${BM_PARAMS} ${TARGET_PARAMS}
# Make all Tenjin output files depend on the oldest Tenjin output file.
BM_TENJIN_DUMMY_TARGETS := $(filter-out ${BM_TENJIN_OUTPUT_OLDEST}, ${BM_TENJIN_OUTPUT})
${BM_TENJIN_DUMMY_TARGETS} : ${BM_TENJIN_OUTPUT_OLDEST}
# Every target that depends on the Tenjin output should just add BM_TENJIN_TARGET to its pre-requisite list.
BM_TENJIN_TARGET := ${BM_TENJIN_OUTPUT_NEWEST}
THRIFT_PD_BASENAMES = $(addsuffix _constants, ${THRIFT_FILES})
THRIFT_PD_BASENAMES += $(addsuffix _types, ${THRIFT_FILES})
THRIFT_PD_BASENAMES += ${THRIFT_SERVICES}
BM_THRIFT_OUTPUT_PREREQ := $(addprefix ${BM_BUILD_SRC_DIR}/, $(addsuffix _types.h, ${THRIFT_FILES_WITH_SERVICES}))
BM_THRIFT_OUTPUT_CPP := $(addprefix ${BM_BUILD_SRC_DIR}/, $(addsuffix .cpp, ${THRIFT_PD_BASENAMES}))
BM_THRIFT_OUTPUT_H := $(addprefix ${BM_BUILD_SRC_DIR}/, $(addsuffix .h, ${THRIFT_PD_BASENAMES}))
${BM_THRIFT_OUTPUT_PREREQ}: ${BM_TENJIN_OUTPUT_THRIFT} ${BM_TENJIN_TARGET}
$(foreach t,${BM_TENJIN_OUTPUT_THRIFT_SERVICES},thrift -r --gen cpp --out ${BM_BUILD_SRC_DIR} ${t} && ) true
${BM_THRIFT_OUTPUT_CPP} : ${BM_THRIFT_OUTPUT_PREREQ}
ifdef COVERAGE
COVERAGE_FLAGS := --coverage
endif
BM_OBJS_C := $(addsuffix .o, $(basename $(addprefix ${BM_OBJ_DIR}/, $(notdir ${BM_TENJIN_OUTPUT_C}))))
${BM_OBJS_C} : ${BM_OBJ_DIR}/%.o : ${BM_BUILD_DIR}/src/%.c ${BM_TENJIN_TARGET}
@echo " Compiling : bm::$(notdir $<)"
$(VERBOSE)gcc -o $@ $(COVERAGE_FLAGS) $(DEBUG_FLAGS) $(GLOBAL_INCLUDES) $(GLOBAL_CFLAGS) -I $(PUBLIC_INC_PATH) -MD -c $<
BM_OBJS_CPP := $(addsuffix .o, $(basename $(addprefix ${BM_OBJ_DIR}/, $(notdir ${BM_TENJIN_OUTPUT_CPP}))))
BM_OBJS_CPP += $(addsuffix .o, $(basename $(addprefix ${BM_OBJ_DIR}/, $(notdir ${BM_THRIFT_OUTPUT_CPP}))))
${BM_OBJS_CPP} : ${BM_OBJ_DIR}/%.o : ${BM_BUILD_SRC_DIR}/%.cpp ${BM_TENJIN_TARGET} ${BM_BUILD_SRC_DIR}/${P4_PREFIX}.cpp
@echo " Compiling : bm::$(notdir $<)"
$(VERBOSE)g++ -o $@ $(COVERAGE_FLAGS) $(DEBUG_FLAGS) $(GLOBAL_INCLUDES) -I ${PUBLIC_INC_PATH} -MD -c $<
# Include the auto-generated .d dependency files. gcc/g++ generate the .d file
# when -MD option is used.
-include $(BM_OBJS_C:.o=.d)
-include $(BM_OBJS_CPP:.o=.d)
THRIFT_INPUT_FILES := ${BM_TENJIN_OUTPUT_THRIFT_SERVICES}
THRIFT_DEP_FILES := ${BM_TENJIN_OUTPUT_THRIFT}
THRIFT_SERVICE_NAMES := ${THRIFT_SERVICES}
include ${MAKEFILES_DIR}/thrift-py.mk
${BM_LIB}: ${BM_OBJS_C} ${BM_OBJS_CPP}
@echo " Creating : $(notdir $@)"
$(VERBOSE)ar -rc $@ $^
.PHONY: bm.a