blob: 9a92dcbe71b1b841cb6019cc8d53443b7e3514cc [file] [log] [blame]
Girish Gowdraa707e7c2019-11-07 11:36:13 +05301#Copyright 2018-present Open Networking Foundation
Shad Ansari01b0e652018-04-05 21:02:53 +00002#
Girish Gowdraa707e7c2019-11-07 11:36:13 +05303#Licensed under the Apache License, Version 2.0 (the "License");
4#you may not use this file except in compliance with the License.
5#You may obtain a copy of the License at
Shad Ansari01b0e652018-04-05 21:02:53 +00006#
Girish Gowdraa707e7c2019-11-07 11:36:13 +05307#http://www.apache.org/licenses/LICENSE-2.0
Shad Ansari01b0e652018-04-05 21:02:53 +00008#
Girish Gowdraa707e7c2019-11-07 11:36:13 +05309#Unless required by applicable law or agreed to in writing, software
10#distributed under the License is distributed on an "AS IS" BASIS,
11#WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12#See the License for the specific language governing permissions and
13#limitations under the License.
Shad Ansari01b0e652018-04-05 21:02:53 +000014
15########################################################################
16##
17##
Luca Pretee75aaa52018-04-13 12:19:12 -070018## Config
Shad Ansari01b0e652018-04-05 21:02:53 +000019##
20##
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +000021TOP_DIR=`pwd`
Shad Ansari9acc9732018-10-30 18:01:44 +000022OPENOLTDEVICE ?= generic
Craig Lutgen88a22ad2018-10-04 12:30:46 -050023
Shad Ansari01b0e652018-04-05 21:02:53 +000024#
25# Three vendor proprietary source files are required to build BAL.
26# SW-BCM68620_<VER>.zip - Broadcom BAL source and Maple SDK.
27# sdk-all-<SDK_VER>.tar.gz - Broadcom Qumran SDK.
Craig Lutgenf040dba2018-09-27 11:21:43 -050028# ACCTON_BAL_<BAL_VER>-<DEV_VER>.patch - Accton/Edgecore's patch.
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +000029BAL_MAJOR_VER = 3
Jason Huangc6362792020-03-04 16:33:19 +080030BAL_MINOR_VER = 4
Girish Gowdrafc10f0d2020-11-30 13:06:35 -080031BAL_REV_A_VER = 9
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +053032ifeq ("$(strip $(OPENOLTDEVICE))",$(findstring "$(strip $(OPENOLTDEVICE))", "rlt-3200g-w" "rlt-1600g-w" "rlt-1600x-w"))
33BAL_REV_B_VER = 9
34DEV_VER = 20210727
35# Version of Open Network Linux (ONL).
36ONL_KERN_VER_MAJOR = 4.19
37else
38BAL_REV_B_VER = 9
39DEV_VER = 202107300101
40ONL_KERN_VER_MAJOR = 4.14
41endif
42BAL_API_VER = $(BAL_MAJOR_VER).$(BAL_MINOR_VER).$(BAL_REV_A_VER).$(BAL_REV_B_VER)
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +000043BAL_VER = $(BAL_MAJOR_VER).$(BAL_MINOR_VER).$(BAL_REV_A_VER).$(BAL_REV_B_VER)
44SDK_VER = 6.5.13
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +000045
46# OpenOLT Proto version.
47# This specifies the GIT tag in https://github.com/opencord/voltha-protos
48# repo that we need to refer to, to pick the right version of
49# openolt.proto and tech_profile.proto
Girish Gowdraeec0fc92021-05-12 15:37:55 -070050OPENOLT_PROTO_VER ?= v4.2.0
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +000051
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +053052# Variables used for Inband build
53INBAND = "n"
54VLAN_ID = 4093
55
Jason Huangdc83ba72020-11-16 22:08:43 +080056# NNI ports speed setting
57PORT_100G_SPEED ?= 100000
58PORT_25G_SPEED ?= 25000
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +053059ifeq ("$(strip $(OPENOLTDEVICE))",$(findstring "$(strip $(OPENOLTDEVICE))", "rlt-3200g-w" "rlt-1600g-w"))
60PORT_QSFP_SPEED ?= 40g
61PORT_SFP_SPEED ?= 10g
62else ifeq ("$(strip $(OPENOLTDEVICE))","rlt-1600x-w")
63PORT_QSFP_SPEED ?= 100g
64PORT_SFP_SPEED ?= 25g
65endif
Jason Huangdc83ba72020-11-16 22:08:43 +080066
Shad Ansari01b0e652018-04-05 21:02:53 +000067# Build directory
68BUILD_DIR = build
Girish Gowdraddf9a162020-01-27 12:56:27 +053069
Orhan Kupusogluec57af02021-05-12 12:38:17 +000070# Rx optical power test app
71RXTX_POWER_EXE = read_rxtx_power
72
Girish Gowdra252f4972020-09-07 21:24:01 -070073# initialiaze path of protoc binary
Girish Gowdra489425a2020-02-22 13:07:42 +053074protoc-bin = $(shell which protoc)
Girish Gowdraddf9a162020-01-27 12:56:27 +053075
Girish Gowdra252f4972020-09-07 21:24:01 -070076# initialiaze path of grpc_cpp_plugin binary
Girish Gowdra489425a2020-02-22 13:07:42 +053077grpc-cpp-plugin-bin = $(shell which grpc_cpp_plugin)
Shad Ansari2cddc552018-06-26 20:34:27 +000078
79USER := $(shell echo $(USER))
Luca Pretee75aaa52018-04-13 12:19:12 -070080#
Shad Ansari01b0e652018-04-05 21:02:53 +000081########################################################################
82##
83##
Girish Gowdra252f4972020-09-07 21:24:01 -070084## Initialize various build flags
Shad Ansari01b0e652018-04-05 21:02:53 +000085##
86##
87HOST_SYSTEM = $(shell uname | cut -f 1 -d_)
88SYSTEM ?= $(HOST_SYSTEM)
Luca Pretee75aaa52018-04-13 12:19:12 -070089
Humera Kouser5ac56612019-07-25 20:23:01 -040090VERSION ?= $(shell cat ../VERSION)
91
92#set ref and commit date only if committed
93LABEL_VCS_URL ?= $(shell git remote get-url $(shell git remote))
94LABEL_VCS_REF = $(shell git rev-parse HEAD)
95LABEL_BUILD_DATE ?= $(shell date -u "+%Y-%m-%dT%H:%M:%SZ")
96LABEL_COMMIT_DATE = $(shell git show -s --format=%cd --date=iso-strict HEAD)
97
Craig Lutgenf040dba2018-09-27 11:21:43 -050098LIBGRPC_PATH=$(shell pkg-config --libs-only-L grpc | sed s/-L// | sed s/\ //g)
Girish Gowdra252f4972020-09-07 21:24:01 -070099LIBZ_PATH=$(shell pkg-config --libs-only-L zlib | sed s/-L// | sed s/\ //g)
Craig Lutgenf040dba2018-09-27 11:21:43 -0500100LIBPROTOBUF_PATH=$(shell PKG_CONFIG_ALLOW_SYSTEM_LIBS=true pkg-config --libs-only-L protobuf | sed s/-L// | sed s/\ //g)
101
Girish Gowdra1935e6a2020-10-31 21:48:22 -0700102PCAPPLUSPLUS_INCLUDE_PATH=-I/usr/local/include/pcapplusplus/
103PCAPPLUSPLUS_LIB_PATH=-lPcap++ -lPacket++ -lCommon++
104
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530105ifeq ("$(strip $(OPENOLTDEVICE))",$(findstring "$(strip $(OPENOLTDEVICE))", "rlt-3200g-w" "rlt-1600g-w" "rlt-1600x-w"))
106CXX = @CXX@-6
107else
108CXX = @CXX@-4.9
109endif
Craig Lutgenf040dba2018-09-27 11:21:43 -0500110CXXFLAGS += @CXXFLAGS@
111CXXFLAGS += $(shell pkg-config --cflags-only-I grpc++)
Girish Gowdra1935e6a2020-10-31 21:48:22 -0700112CXXFLAGS += $(PCAPPLUSPLUS_INCLUDE_PATH)
Humera Kouser5ac56612019-07-25 20:23:01 -0400113CPPFLAGS += @CPPFLAGS@
Shad Ansari01b0e652018-04-05 21:02:53 +0000114CPPFLAGS += `pkg-config --cflags protobuf grpc`
Girish Gowdra252f4972020-09-07 21:24:01 -0700115
116# Enabling SCALE_AND_PERF for higher performance and scaling to 512 subscribers. Enabling the flag will
117# disable the handling in FLOW_CHECKER and also disable flow statistics
118# Setting SW_UTIL_SHELL=y will enable QAX debug shell when compiling for Broadcom chip based OLT
Humera Kouser5ac56612019-07-25 20:23:01 -0400119CPPFLAGS += -DVERSION=\"$(VERSION)\" -DBAL_VER=\"$(BAL_VER)\" -DLABEL_VCS_URL=\"$(LABEL_VCS_URL)\" \
120 -DLABEL_VCS_REF=\"$(LABEL_VCS_REF)\" -DLABEL_BUILD_DATE=\"$(LABEL_BUILD_DATE)\" \
Girish Gowdra252f4972020-09-07 21:24:01 -0700121 -DLABEL_COMMIT_DATE=\"$(LABEL_COMMIT_DATE)\" -DFLOW_CHECKER -USCALE_AND_PERF -DSW_UTIL_SHELL=n
Humera Kouser6143c9e2020-06-17 22:37:31 +0530122CPPFLAGS += -I./
Craig Lutgen7ebee132018-11-16 15:31:11 -0600123CXXFLAGS += -std=c++11 -fpermissive -Wno-literal-suffix
Craig Lutgenf040dba2018-09-27 11:21:43 -0500124LDFLAGS += @LDFLAGS@
125LDFLAGS += `pkg-config --libs protobuf grpc++ grpc` -ldl -lgpr
Shad Ansari9acc9732018-10-30 18:01:44 +0000126CXXFLAGSDEVICE = -I./device -I./device/$(OPENOLTDEVICE) -I./device/generic
Craig Lutgenf040dba2018-09-27 11:21:43 -0500127
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000128export CXX CXXFLAGS OPENOLT_PROTO_VER
Luca Pretee75aaa52018-04-13 12:19:12 -0700129
Shad Ansari01b0e652018-04-05 21:02:53 +0000130########################################################################
131##
132##
Luca Pretee75aaa52018-04-13 12:19:12 -0700133## ONL
Shad Ansari01b0e652018-04-05 21:02:53 +0000134##
135##
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000136ONL_REPO = onl
Shad Ansari01b0e652018-04-05 21:02:53 +0000137ONL_DIR = $(BUILD_DIR)/$(ONL_REPO)
Shad Ansari01b0e652018-04-05 21:02:53 +0000138onl:
139 if [ ! -d "$(ONL_DIR)/OpenNetworkLinux" ]; then \
140 mkdir -p $(ONL_DIR); \
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000141 git clone https://github.com/opencomputeproject/OpenNetworkLinux.git $(ONL_DIR)/OpenNetworkLinux; \
142 cp download/Makefile.onl $(ONL_DIR)/Makefile; \
143 install -m 755 download/build-onl.sh $(ONL_DIR)/OpenNetworkLinux; \
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530144 if [ "$(OPENOLTDEVICE)" = "rlt-3200g-w" ] || [ "$(OPENOLTDEVICE)" = "rlt-1600g-w" ] || [ "$(OPENOLTDEVICE)" = "rlt-1600x-w" ]; \
145 then \
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530146 cp $(TOP_DIR)/device/$(OPENOLTDEVICE)/update_kernel_options.sh $(ONL_DIR)/OpenNetworkLinux/.; \
147 chmod 0755 $(ONL_DIR)/OpenNetworkLinux/update_kernel_options.sh; \
148 fi; \
149 make -C $(ONL_DIR) onl-$(ONL_KERN_VER_MAJOR) INBAND=n BOARD=$(OPENOLTDEVICE); \
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +0530150 else \
151 if [ "$(INBAND)" = n -a "$$(grep "inband" $(ONL_DIR)/onl_build.mode | cut -d= -f 2)" = y ]; then \
152 make -C $(ONL_DIR) onl-$(ONL_KERN_VER_MAJOR) INBAND=n; \
153 fi; \
Shad Ansari01b0e652018-04-05 21:02:53 +0000154 fi;
155onl-force:
Shad Ansari9acc9732018-10-30 18:01:44 +0000156 make -C $(ONL_DIR) $(OPENOLTDEVICE)-$(ONL_KERN_VER_MAJOR)
Shad Ansari01b0e652018-04-05 21:02:53 +0000157distclean-onl:
158 sudo rm -rf $(ONL_DIR)
159
160########################################################################
161##
162##
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000163## Broadcom LIBRARY APIs
164##
165##
166BAL_API_DIR = $(BUILD_DIR)/bal-api-$(BAL_API_VER)
167
168bal-api-$(BAL_API_VER):
169 if [ ! -d "$(BAL_API_DIR)" ]; then \
170 mkdir -p $(BAL_API_DIR); \
171 git clone https://github.com/balapi/bal-api-$(BAL_API_VER).git $(BAL_API_DIR); \
172 fi;
173bal-api-clean:
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530174 rm -rf $(BAL_API_DIR)
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000175
176########################################################################
177##
178##
Luca Pretee75aaa52018-04-13 12:19:12 -0700179## BAL
Shad Ansari01b0e652018-04-05 21:02:53 +0000180##
181##
Jason Huang09b73ea2020-01-08 17:52:05 +0800182BAL_ZIP = SW-BCM686OLT_$(subst .,_,$(BAL_VER)).tgz
Shad Ansari01b0e652018-04-05 21:02:53 +0000183SDK_ZIP = sdk-all-$(SDK_VER).tar.gz
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530184ifeq ("$(strip $(OPENOLTDEVICE))",$(findstring "$(strip $(OPENOLTDEVICE))", "rlt-3200g-w" "rlt-1600g-w" "rlt-1600x-w"))
185PATCH_FILE = PHOENIX_BAL_$(BAL_VER)_V$(DEV_VER).patch
186else
187PATCH_FILE = ACCTON_BAL_$(BAL_VER)-V$(DEV_VER).patch
188BAL_IP_PATCH_FILE = ACCTON_BAL_$(BAL_VER)-V$(DEV_VER)-BROADCOM-IP.patch
189endif
Shad Ansari9acc9732018-10-30 18:01:44 +0000190BAL_DIR = $(BUILD_DIR)/$(OPENOLTDEVICE)-bal
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000191BCM_SDK = $(BAL_DIR)/switch_sdk/$(SDK_VER)
192BALLIBDIR = $(BAL_DIR)/build/host_reference/host_api
193BALLIBNAME = bal_host_api
194BAL_INC = -I$(BAL_DIR)/host_driver/bal/bal_include \
195 -I$(BAL_DIR)/host_driver/topology \
196 -I$(BAL_DIR)/host_driver/utils \
197 -I$(BAL_DIR)/host_driver/api \
Jason Huangc6362792020-03-04 16:33:19 +0800198 -I$(BAL_DIR)/host_driver/metadata \
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000199 -I$(BAL_DIR)/host_customized/os_abstraction \
200 -I$(BAL_DIR)/host_customized/os_abstraction/posix \
201 -I$(BAL_DIR)/host_customized/config \
202 -I$(BAL_DIR)/host_driver/api_conn_mgr \
203 -I$(BAL_DIR)/host_driver/conn_mgr \
204 -I$(BAL_DIR)/host_driver/api/host/topology \
205 -I$(BAL_DIR)/host_reference/cli \
206 -I$(BAL_DIR)/host_reference/api_cli \
207 -I$(BAL_API_DIR)/include \
208 -I$(BAL_API_DIR)/include/object_model
Shad Ansari01b0e652018-04-05 21:02:53 +0000209CXXFLAGS += $(BAL_INC) -I $(BAL_DIR)/lib/cmdline
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000210CXXFLAGS += -DBCMOS_MSG_QUEUE_DOMAIN_SOCKET -DBCMOS_MSG_QUEUE_UDP_SOCKET -DBCMOS_MEM_CHECK -DBCMOS_SYS_UNITTEST -DENABLE_LOG -DENABLE_CLI
Jason Huangdc83ba72020-11-16 22:08:43 +0800211PORT_SPEED_FILE = $(BAL_DIR)/switch_sdk/$(SDK_VER)/rc/$(OPENOLTDEVICE)/board_files/broadcom/port_speed.soc
Shad Ansaricb004c52018-05-30 18:07:23 +0000212
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000213sdk: onl bal-api-$(BAL_API_VER)
Shad Ansari01b0e652018-04-05 21:02:53 +0000214ifeq ("$(wildcard $(BAL_DIR))","")
215 mkdir $(BAL_DIR)
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000216 tar zxvf download/$(BAL_ZIP) --strip 1 -C $(BAL_DIR)
Shad Ansari01b0e652018-04-05 21:02:53 +0000217 cp download/$(SDK_ZIP) $(BCM_SDK)
218 chmod -R 744 $(BAL_DIR)
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530219 cat download/$(PATCH_FILE) | patch -p1 -d $(BAL_DIR)
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530220 cat download/$(BAL_IP_PATCH_FILE) | patch -p1 -d $(BAL_DIR)
Jason Huangdc83ba72020-11-16 22:08:43 +0800221ifeq ("$(strip $(OPENOLTDEVICE))","asfvolt16")
222 echo "setenv port_speed_for_100 $(PORT_100G_SPEED)" > $(PORT_SPEED_FILE)
223else ifeq ("$(strip $(OPENOLTDEVICE))","asgvolt64")
224 echo "setenv port_speed_for_100 $(PORT_100G_SPEED)" > $(PORT_SPEED_FILE)
225 echo "setenv port_speed_for_25 $(PORT_25G_SPEED)" >> $(PORT_SPEED_FILE)
226endif
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530227ifeq ("$(strip $(OPENOLTDEVICE))",$(findstring "$(strip $(OPENOLTDEVICE))", "rlt-3200g-w" "rlt-1600g-w" "rlt-1600x-w"))
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530228 chmod 0755 $(BAL_DIR)/onu_mgmt/libomcistack/me_codegen/omci_stack_codegen
Thiyagarajan Subramania2c2c5a2021-05-18 14:47:52 +0530229 make -C $(BAL_DIR) BOARD=phoenix ONL=$(TOP_DIR)/$(ONL_DIR)/OpenNetworkLinux ONL_DEBIAN_SUITE=$(shell lsb_release -c -s) OPEN_SOURCE=y
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530230 make -C $(BAL_DIR) BOARD=phoenix release_board
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530231else
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000232 make -C $(BAL_DIR) BOARD=$(OPENOLTDEVICE) ONL_DIR=$(TOP_DIR)/$(ONL_DIR)/OpenNetworkLinux OPEN_SOURCE=y
233 make -C $(BAL_DIR) BOARD=$(OPENOLTDEVICE) release_board
Shad Ansari01b0e652018-04-05 21:02:53 +0000234endif
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530235endif
Shad Ansaricb004c52018-05-30 18:07:23 +0000236
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000237bal-release: sdk
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530238ifeq ("$(strip $(OPENOLTDEVICE))",$(findstring "$(strip $(OPENOLTDEVICE))", "rlt-3200g-w" "rlt-1600g-w" "rlt-1600x-w"))
239 make -C $(BAL_DIR) BOARD=phoenix release_board
240else
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000241 make -C $(BAL_DIR) BOARD=$(OPENOLTDEVICE) release_board
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530242endif
Shad Ansaricb004c52018-05-30 18:07:23 +0000243
244bal-clean:
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000245 make -C $(BAL_DIR) BOARD=$(OPENOLTDEVICE) clean_all
Shad Ansari01b0e652018-04-05 21:02:53 +0000246
247########################################################################
248##
249##
Luca Pretee75aaa52018-04-13 12:19:12 -0700250## OpenOLT API
Shad Ansari01b0e652018-04-05 21:02:53 +0000251##
252##
Shad Ansari56c8ea42018-10-30 19:34:35 +0000253OPENOLT_PROTOS_DIR = ../protos
Shad Ansari19249582018-04-30 04:31:00 +0000254OPENOLT_API_LIB = $(OPENOLT_PROTOS_DIR)/libopenoltapi.a
Girish Gowdra252f4972020-09-07 21:24:01 -0700255CXXFLAGS += -I$(OPENOLT_PROTOS_DIR) -I./device -I./device/$(OPENOLTDEVICE) -I$(OPENOLT_PROTOS_DIR)/googleapis/gens
Shad Ansari19249582018-04-30 04:31:00 +0000256protos:
257 make -C $(OPENOLT_PROTOS_DIR) all
Shad Ansaricc01de12018-05-21 22:54:45 +0000258protos-clean:
Shad Ansari19249582018-04-30 04:31:00 +0000259 -make -C $(OPENOLT_PROTOS_DIR) clean
Shad Ansari01b0e652018-04-05 21:02:53 +0000260
261########################################################################
262##
263##
Shad Ansari627b5782018-08-13 22:49:32 +0000264## common
Shad Ansari7193ae22018-08-08 22:23:18 +0000265##
266##
Girish Gowdrafe649702019-10-30 12:49:58 +0530267
268# A hack to force a re-build of common/main.cc everytime.
269# This is needed to bake in the git VCS information in the openolt binary
270# at the time of building the openolt package.
271common/main.o: .FORCE
272.FORCE:
273 $(CXX) $(CXXFLAGS) $(CPPFLAGS) -I./common -c common/main.cc -o common/main.o
274
Shad Ansari627b5782018-08-13 22:49:32 +0000275common/%.o: common/%.cc
Humera Kouser5ac56612019-07-25 20:23:01 -0400276 $(CXX) $(CXXFLAGS) $(CPPFLAGS) -I./common -c $< -o $@
Shad Ansari7193ae22018-08-08 22:23:18 +0000277
278########################################################################
279##
280##
Craig Lutgen88a22ad2018-10-04 12:30:46 -0500281## device
282##
283##
Shad Ansari9acc9732018-10-30 18:01:44 +0000284device/$(OPENOLTDEVICE)/%.o: device/$(OPENOLTDEVICE)/%.cc
Craig Lutgen88a22ad2018-10-04 12:30:46 -0500285 $(CXX) $(CXXFLAGS) $(CXXFLAGSDEVICE) -c $< -o $@
286
287device/generic/%.o: device/generic/%.cc
288 $(CXX) $(CXXFLAGS) $(CXXFLAGSDEVICE) -c $< -o $@
289
290########################################################################
291##
292##
Shad Ansari627b5782018-08-13 22:49:32 +0000293## openolt
294##
295##
Humera Kouser9c2bd9f2020-09-25 02:41:29 -0400296OLT_SW_UPGRADE_DIR = ../olt-sw-upgrade
Shad Ansari9acc9732018-10-30 18:01:44 +0000297SRCS = $(wildcard src/*.cc) $(wildcard common/*.cc) $(wildcard device/$(OPENOLTDEVICE)/*.cc)
Humera Kouser9c2bd9f2020-09-25 02:41:29 -0400298ANSIBLE_DIR = /etc/ansible
Shad Ansari01b0e652018-04-05 21:02:53 +0000299OBJS = $(SRCS:.cc=.o)
300DEPS = $(SRCS:.cc=.d)
301.DEFAULT_GOAL := all
Shad Ansari2ae27672019-05-09 00:26:34 +0000302all: $(BUILD_DIR)/openolt
Shad Ansaricb004c52018-05-30 18:07:23 +0000303$(BUILD_DIR)/openolt: sdk protos $(OBJS)
Girish Gowdra1935e6a2020-10-31 21:48:22 -0700304 $(CXX) $(LDFLAGS) -L$(BALLIBDIR) $(OBJS) $(OPENOLT_API_LIB) $(LIBPROTOBUF_PATH)/libprotobuf.a -o $@ -l$(BALLIBNAME) $(shell pkg-config --libs protobuf grpc++ grpc) $(PCAPPLUSPLUS_LIB_PATH)
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530305ifeq ("$(strip $(OPENOLTDEVICE))",$(findstring "$(strip $(OPENOLTDEVICE))", "rlt-3200g-w" "rlt-1600g-w" "rlt-1600x-w"))
Thiyagarajan Subramania2c2c5a2021-05-18 14:47:52 +0530306 ln -sf $(TOP_DIR)/$(BAL_DIR)/build/fs/phoenix/release/release_phoenix_v$(BAL_VER).tar.gz $(BUILD_DIR)/release_$(OPENOLTDEVICE)_V$(BAL_VER).$(DEV_VER).tar.gz
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530307else
Jason Huang09b73ea2020-01-08 17:52:05 +0800308 ln -sf $(TOP_DIR)/$(BAL_DIR)/build/fs/$(OPENOLTDEVICE)/release/release_$(OPENOLTDEVICE)_V$(BAL_VER).$(DEV_VER).tar.gz $(BUILD_DIR)/.
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530309endif
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000310 ln -sf $(TOP_DIR)/$(BAL_DIR)/build/host_reference/host_api/strip/libbal_host_api.so $(BUILD_DIR)/.
311 ln -sf $(TOP_DIR)/$(BAL_DIR)/build/host_driver/dev_mgmt_daemon/dev_mgmt_daemon $(BUILD_DIR)/.
Girish Gowdra252f4972020-09-07 21:24:01 -0700312 ln -sf $(LIBGRPC_PATH)/libz.so.1 $(BUILD_DIR)/libz.so.1
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000313 ln -sf /usr/lib/x86_64-linux-gnu/libstdc++.so.6 $(BUILD_DIR)/libstdc++.so.6
314 strip $(BUILD_DIR)/openolt
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +0530315 echo "inband=n" > $(ONL_DIR)/onl_build.mode
316 if [ $(INBAND) = y ]; then \
317 echo "Building ONL+BAL+OpenoltAgent allinone image"; \
318 make deb; \
319 make inband-onl; \
320 fi;
321
Shad Ansari627b5782018-08-13 22:49:32 +0000322src/%.o: src/%.cc
Humera Kouser5ac56612019-07-25 20:23:01 -0400323 $(CXX) $(CXXFLAGS) $(CXXFLAGSDEVICE) $(CPPFLAGS) -I./common -c $< -o $@
Shad Ansari01b0e652018-04-05 21:02:53 +0000324
Orhan Kupusogluec57af02021-05-12 12:38:17 +0000325deb: rxtx-power
Jason Huang09b73ea2020-01-08 17:52:05 +0800326 cp $(BUILD_DIR)/release_$(OPENOLTDEVICE)_V$(BAL_VER).$(DEV_VER).tar.gz device/$(OPENOLTDEVICE)/mkdebian/debian
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000327 cp $(BUILD_DIR)/openolt device/$(OPENOLTDEVICE)/mkdebian/debian
Girish Gowdra252f4972020-09-07 21:24:01 -0700328 cp $(BUILD_DIR)/libz.so.1 device/$(OPENOLTDEVICE)/mkdebian/debian
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000329 cp $(BUILD_DIR)/libstdc++.so.6 device/$(OPENOLTDEVICE)/mkdebian/debian
330 cp $(BUILD_DIR)/libbal_host_api.so device/$(OPENOLTDEVICE)/mkdebian/debian
331 cp -a scripts/init.d device/$(OPENOLTDEVICE)/mkdebian/debian
Orhan Kupusogluec57af02021-05-12 12:38:17 +0000332 cp -a $(RXTX_POWER_EXE) device/$(OPENOLTDEVICE)/mkdebian/debian
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530333ifeq ("$(strip $(OPENOLTDEVICE))",$(findstring "$(strip $(OPENOLTDEVICE))", "rlt-3200g-w" "rlt-1600g-w" "rlt-1600x-w"))
334 sed -i '/\/opt\/bcm68650\/svk_init.sh/c\ \/opt\/bcm68650\/svk_init.sh -qsfp_speed=$(PORT_QSFP_SPEED) -sfp_speed=$(PORT_SFP_SPEED)' device/$(OPENOLTDEVICE)/mkdebian/debian/init.d/dev_mgmt_daemon
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530335endif
Girish Gowdra6e745522020-07-15 15:52:13 -0700336 cp -a scripts/watchdog device/$(OPENOLTDEVICE)/mkdebian/debian
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000337 cd device/$(OPENOLTDEVICE)/mkdebian && ./build_$(OPENOLTDEVICE)_deb.sh
Thiyagarajan Subramani3e8bfd92021-04-26 15:07:14 +0530338 mv device/$(OPENOLTDEVICE)/$(OPENOLTDEVICE)_*.deb $(BUILD_DIR)/openolt_$(OPENOLTDEVICE)-$(VERSION)-$(LABEL_VCS_REF).deb
Shad Ansaricb004c52018-05-30 18:07:23 +0000339 make deb-cleanup
Shad Ansari6cd46a62018-05-13 23:20:51 +0000340
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +0530341inband-onl:
342 # Clean previous ONL build and build freshly
343 sudo rm -rf $(ONL_DIR)
344 mkdir -p $(ONL_DIR)
345 git clone https://github.com/opencomputeproject/OpenNetworkLinux.git $(ONL_DIR)/OpenNetworkLinux
346 cp download/Makefile.onl $(ONL_DIR)/Makefile
347 install -m 755 download/build-onl.sh $(ONL_DIR)/OpenNetworkLinux
348
349 # Check ONL commit equals to Inband patch commit
350 ONL_COMMIT_ID=$(awk \'/COMMIT_ID = /{print $0}\' $(ONL_DIR)/Makefile | awk -F \"=\" \'{print $2}\')
351 INBAND_PATCH_COMMIT_ID=$(echo cp $(TOP_DIR)/inband/patch/*.patch | cut -d- -f 2 | cut -d. -f 1)
352 if [ "$(ONL_COMMIT_ID)" = "$(INBAND_PATCH_COMMIT_ID)" ]; then \
353 echo "ONL commit and inband patch commit matched."; \
354 cp $(TOP_DIR)/inband/patch/*.patch $(ONL_DIR)/OpenNetworkLinux; \
355 else \
356 echo "ONL commit and inband patch commit does not match. Exiting."; \
357 exit 1; \
358 fi;
359
Girish Gowdra6e745522020-07-15 15:52:13 -0700360 # Update inband.config file with VLAN ID argument passed
361 sed -i 's/asfvolt16_vlan_id_eth2=.*/asfvolt16_vlan_id_eth2=$(VLAN_ID)/' $(TOP_DIR)/inband/config/inband.config
362 sed -i 's/asgvolt64_vlan_id_eth1=.*/asgvolt64_vlan_id_eth1=$(VLAN_ID)/' $(TOP_DIR)/inband/config/inband.config
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +0530363
364 # Copy Inband config files and olt startup scripts to ONL source code and build
365 cd $(TOP_DIR) && mkdir -p $(ONL_DIR)/OpenNetworkLinux/bal_packages
366 cp $(TOP_DIR)/inband/scripts/* $(ONL_DIR)/OpenNetworkLinux/bal_packages
Girish Gowdra6e745522020-07-15 15:52:13 -0700367 cp $(TOP_DIR)/inband/config/inband.config $(ONL_DIR)/OpenNetworkLinux/bal_packages
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +0530368 cp $(BUILD_DIR)/openolt_$(OPENOLTDEVICE)-$(VERSION)-$(LABEL_VCS_REF).deb $(ONL_DIR)/OpenNetworkLinux/bal_packages/openolt_$(OPENOLTDEVICE).deb
Humera Kouser9c2bd9f2020-09-25 02:41:29 -0400369 cp $(OLT_SW_UPGRADE_DIR)/change_labels.sh $(ONL_DIR)/OpenNetworkLinux/bal_packages
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +0530370
371 # Rebuild ONL packed with already built BAL+Openolt debian package
372 make -C $(ONL_DIR) onl-$(ONL_KERN_VER_MAJOR) INBAND=y
373 echo "inband=y" > $(ONL_DIR)/onl_build.mode
374 make inband-onl-cleanup
Humera Kouser9c2bd9f2020-09-25 02:41:29 -0400375# requires 'sudo' privileges
376
377ansible:
378 (ONL_INSTALLED_INSTALLER="$(shell find "$$(cd ./build/onl/OpenNetworkLinux/RELEASE/jessie/amd64; pwd)" -name "ONL-onl-*_AMD64_INSTALLED_INSTALLER")"; \
379 rm -rf $(ANSIBLE_DIR)/roles/upgrade/files; \
380 mkdir -p $(ANSIBLE_DIR)/roles/upgrade/files; \
381 cp ../olt-sw-upgrade/install_onl.sh $(ANSIBLE_DIR)/roles/upgrade/files; \
382 chmod +x $(ANSIBLE_DIR)/roles/upgrade/files/*.sh; \
383 ln -s $$ONL_INSTALLED_INSTALLER $(ANSIBLE_DIR)/roles/upgrade/files/ONL_INSTALLED_INSTALLER)
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +0530384
Shad Ansari01b0e652018-04-05 21:02:53 +0000385src/%.o: %.cpp
386 $(CXX) -MMD -c $< -o $@
387
Orhan Kupusogluec57af02021-05-12 12:38:17 +0000388rxtx-power: clean-rxtx-power
389 $(CXX) -std=c++11 -DRXTX_POWER_EXE_MODE src/trx_eeprom_reader.cc -o $(RXTX_POWER_EXE) && ls -l $(RXTX_POWER_EXE)
390
391deb-cleanup: clean-rxtx-power
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000392 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/$(OPENOLTDEVICE).debhelper.log
393 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/$(OPENOLTDEVICE).postinst.debhelper
394 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/$(OPENOLTDEVICE).postrm.debhelper
395 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/$(OPENOLTDEVICE).substvars
396 @rm -rf device/$(OPENOLTDEVICE)/mkdebian/debian/$(OPENOLTDEVICE)/
397 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/debhelper-build-stamp
Girish Gowdra252f4972020-09-07 21:24:01 -0700398 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/libz.so.1
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000399 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/libstdc++.so.6
400 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/libbal_host_api.so
401 @rm -rf device/$(OPENOLTDEVICE)/mkdebian/debian/init.d/
402 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/openolt
Jason Huang09b73ea2020-01-08 17:52:05 +0800403 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/release_$(OPENOLTDEVICE)_V$(BAL_VER).$(DEV_VER).tar.gz
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000404 @rm -rf device/$(OPENOLTDEVICE)/mkdebian/debian/tmp/
405 @rm -f device/$(OPENOLTDEVICE)/$(OPENOLTDEVICE)_$(BAL_VER)+edgecore-V$(DEV_VER)_amd64.changes
Orhan Kupusogluec57af02021-05-12 12:38:17 +0000406 @rm -f device/$(OPENOLTDEVICE)/mkdebian/debian/$(RXTX_POWER_EXE)
Thiyagarajan Subramanie2a95972021-06-25 17:31:30 +0530407 @rm -rf device/$(OPENOLTDEVICE)/mkdebian/debian/watchdog/
Shad Ansaricc01de12018-05-21 22:54:45 +0000408
Thiyagarajan Subramanie84935d2020-04-23 17:45:44 +0530409inband-onl-cleanup:
410 @rm -f $(ONL_DIR)/OpenNetworkLinux/*.patch
411 @rm -rf $(ONL_DIR)/OpenNetworkLinux/bal_packages
412
Shad Ansaricb004c52018-05-30 18:07:23 +0000413clean: protos-clean deb-cleanup
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000414 @rm -f $(OBJS) $(DEPS)
415 @rm -rf $(OPENOLT_PROTOS_DIR)/googleapis
Girish Gowdra252f4972020-09-07 21:24:01 -0700416 @rm -f $(BUILD_DIR)/libz.so.1
Girish Gowdraab7ea552020-01-07 13:25:15 +0530417 @rm -f $(BUILD_DIR)/libbal_host_api.so
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000418 @rm -f $(BUILD_DIR)/openolt
Girish Gowdraab7ea552020-01-07 13:25:15 +0530419 @rm -f $(BUILD_DIR)/dev_mgmt_daemon
Jason Huang09b73ea2020-01-08 17:52:05 +0800420 @rm -f $(BUILD_DIR)/release_$(OPENOLTDEVICE)_V$(BAL_VER).$(DEV_VER).tar.gz
Girish Gowdrabc6e0852020-03-26 11:36:12 -0700421 @rm -f $(BUILD_DIR)/openolt_$(OPENOLTDEVICE)-$(VERSION)-$(LABEL_VCS_REF).deb
Shad Ansari19249582018-04-30 04:31:00 +0000422
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000423clean-src: protos-clean
424 @rm -f $(OBJS) $(DEPS)
425
Orhan Kupusogluec57af02021-05-12 12:38:17 +0000426clean-rxtx-power:
427 @rm -f src/$(RXTX_POWER_EXE)
428 @rm -f $(RXTX_POWER_EXE)
429
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000430distclean: clean-src clean
431 @rm -rf $(BUILD_DIR)
Shad Ansaricb004c52018-05-30 18:07:23 +0000432
Humera Kouser9c2bd9f2020-09-25 02:41:29 -0400433.PHONY: onl sdk bal protos inband-onl ansible .FORCE