VPP-303 - Documentation changes for vnet/vnet/sr
[vpp.git] / Makefile
1 # Copyright (c) 2016 Cisco and/or its affiliates.
2 # Licensed under the Apache License, Version 2.0 (the "License");
3 # you may not use this file except in compliance with the License.
4 # You may obtain a copy of the License at:
5 #
6 #     http://www.apache.org/licenses/LICENSE-2.0
7 #
8 # Unless required by applicable law or agreed to in writing, software
9 # distributed under the License is distributed on an "AS IS" BASIS,
10 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11 # See the License for the specific language governing permissions and
12 # limitations under the License.
13
14 WS_ROOT=$(CURDIR)
15 BR=$(WS_ROOT)/build-root
16 CCACHE_DIR?=$(BR)/.ccache
17 GDB?=gdb
18 PLATFORM?=vpp
19
20 MINIMAL_STARTUP_CONF="unix { interactive }"
21
22 GDB_ARGS= -ex "handle SIGUSR1 noprint nostop"
23
24 #
25 # OS Detection
26 #
27 OS_ID        = $(shell grep '^ID=' /etc/os-release | cut -f2- -d= | sed -e 's/\"//g')
28 OS_VERSION_ID= $(shell grep '^VERSION_ID=' /etc/os-release | cut -f2- -d= | sed -e 's/\"//g')
29
30 DEB_DEPENDS  = curl build-essential autoconf automake bison libssl-dev ccache
31 DEB_DEPENDS += debhelper dkms git libtool libganglia1-dev libapr1-dev dh-systemd
32 DEB_DEPENDS += libconfuse-dev git-review exuberant-ctags cscope
33 DEB_DEPENDS += python-dev
34 ifeq ($(OS_VERSION_ID),14.04)
35         DEB_DEPENDS += openjdk-8-jdk-headless
36 else
37         DEB_DEPENDS += default-jdk-headless
38 endif
39
40 RPM_DEPENDS_GROUPS = 'Development Tools'
41 RPM_DEPENDS  = redhat-lsb glibc-static java-1.8.0-openjdk-devel yum-utils
42 RPM_DEPENDS += openssl-devel https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm apr-devel
43 RPM_DEPENDS += python-devel
44 EPEL_DEPENDS = libconfuse-devel ganglia-devel
45
46 ifneq ($(wildcard $(STARTUP_DIR)/startup.conf),)
47         STARTUP_CONF ?= $(STARTUP_DIR)/startup.conf
48 endif
49
50 ifeq ($(findstring y,$(UNATTENDED)),y)
51 CONFIRM=-y
52 FORCE=--force-yes
53 endif
54
55 .PHONY: help bootstrap wipe wipe-release build build-release rebuild rebuild-release
56 .PHONY: run run-release debug debug-release build-vat run-vat pkg-deb pkg-rpm
57 .PHONY: ctags cscope plugins plugins-release build-vpp-api
58
59 help:
60         @echo "Make Targets:"
61         @echo " bootstrap           - prepare tree for build"
62         @echo " install-dep         - install software dependencies"
63         @echo " wipe                - wipe all products of debug build "
64         @echo " wipe-release        - wipe all products of release build "
65         @echo " build               - build debug binaries"
66         @echo " build-release       - build release binaries"
67         @echo " plugins             - build debug plugin binaries"
68         @echo " plugins-release     - build release plugin binaries"
69         @echo " rebuild             - wipe and build debug binares"
70         @echo " rebuild-release     - wipe and build release binares"
71         @echo " run                 - run debug binary"
72         @echo " run-release         - run release binary"
73         @echo " debug               - run debug binary with debugger"
74         @echo " debug-release       - run release binary with debugger"
75         @echo " build-vat           - build vpp-api-test tool"
76         @echo " build-vpp-api       - build vpp-api"
77         @echo " run-vat             - run vpp-api-test tool"
78         @echo " pkg-deb             - build DEB packages"
79         @echo " pkg-rpm             - build RPM packages"
80         @echo " ctags               - (re)generate ctags database"
81         @echo " gtags               - (re)generate gtags database"
82         @echo " cscope              - (re)generate cscope database"
83         @echo " doxygen             - (re)generate documentation"
84         @echo " bootstrap-doxygen   - setup Doxygen dependencies"
85         @echo " wipe-doxygen        - wipe all generated documentation"
86         @echo ""
87         @echo "Make Arguments:"
88         @echo " V=[0|1]             - set build verbosity level"
89         @echo " STARTUP_CONF=<path> - startup configuration file"
90         @echo "                       (e.g. /etc/vpp/startup.conf)"
91         @echo " STARTUP_DIR=<path>  - startup drectory (e.g. /etc/vpp)"
92         @echo "                       It also sets STARTUP_CONF if"
93         @echo "                       startup.conf file is present"
94         @echo " GDB=<path>          - gdb binary to use for debugging"
95         @echo " PLATFORM=<name>     - target platform. default is vpp"
96         @echo ""
97         @echo "Current Argumernt Values:"
98         @echo " V            = $(V)"
99         @echo " STARTUP_CONF = $(STARTUP_CONF)"
100         @echo " STARTUP_DIR  = $(STARTUP_DIR)"
101         @echo " GDB          = $(GDB)"
102         @echo " PLATFORM     = $(PLATFORM)"
103         @echo " DPDK_VERSION = $(DPDK_VERSION)"
104
105 $(BR)/.bootstrap.ok:
106 ifeq ($(OS_ID),ubuntu)
107         @MISSING=$$(apt-get install -y -qq -s $(DEB_DEPENDS) | grep "^Inst ") ; \
108         if [ -n "$$MISSING" ] ; then \
109           echo "\nPlease install missing packages: \n$$MISSING\n" ; \
110           echo "by executing \"make install-dep\"\n" ; \
111           exit 1 ; \
112         fi ; \
113         exit 0
114 endif
115         @echo "SOURCE_PATH = $(WS_ROOT)"                   > $(BR)/build-config.mk
116         @echo "#!/bin/bash\n"                              > $(BR)/path_setup
117         @echo 'export PATH=$(BR)/tools/ccache-bin:$$PATH' >> $(BR)/path_setup
118         @echo 'export PATH=$(BR)/tools/bin:$$PATH'        >> $(BR)/path_setup
119         @echo 'export CCACHE_DIR=$(CCACHE_DIR)'           >> $(BR)/path_setup
120
121 ifeq ("$(wildcard /usr/bin/ccache )","")
122         @echo "WARNING: Please install ccache AYEC and re-run this script"
123 else
124         @rm -rf $(BR)/tools/ccache-bin
125         @mkdir -p $(BR)/tools/ccache-bin
126         @ln -s /usr/bin/ccache $(BR)/tools/ccache-bin/gcc
127         @ln -s /usr/bin/ccache $(BR)/tools/ccache-bin/g++
128 endif
129         @make -C $(BR) V=$(V) is_build_tool=yes vppapigen-install
130         @touch $@
131
132 bootstrap: $(BR)/.bootstrap.ok
133
134 install-dep:
135 ifeq ($(OS_ID),ubuntu)
136 ifeq ($(OS_VERSION_ID),14.04)
137         @sudo -E apt-get $(CONFIRM) $(FORCE) install software-properties-common
138         @sudo -E add-apt-repository ppa:openjdk-r/ppa $(CONFIRM)
139         @sudo -E apt-get update
140 endif
141         @sudo -E apt-get $(CONFIRM) $(FORCE) install $(DEB_DEPENDS)
142 else ifneq ("$(wildcard /etc/redhat-release)","")
143         @sudo yum groupinstall $(CONFIRM) $(RPM_DEPENDS_GROUPS)
144         @sudo yum install $(CONFIRM) $(RPM_DEPENDS)
145         @sudo yum install $(CONFIRM) --enablerepo=epel $(EPEL_DEPENDS)
146         @sudo debuginfo-install $(CONFIRM) glibc-2.17-106.el7_2.4.x86_64 openssl-libs-1.0.1e-51.el7_2.4.x86_64 zlib-1.2.7-15.el7.x86_64
147 else
148         $(error "This option currently works only on Ubuntu or Centos systems")
149 endif
150
151 define make
152         @make -C $(BR) PLATFORM=$(PLATFORM) TAG=$(1) $(2)
153 endef
154
155 build: $(BR)/.bootstrap.ok
156         $(call make,$(PLATFORM)_debug,vpp-install)
157
158 wipe: $(BR)/.bootstrap.ok
159         $(call make,$(PLATFORM)_debug,vpp-wipe)
160
161 rebuild: wipe build
162
163 build-release: $(BR)/.bootstrap.ok
164         $(call make,$(PLATFORM),vpp-install)
165
166 wipe-release: $(BR)/.bootstrap.ok
167         $(call make,$(PLATFORM),vpp-wipe)
168
169 rebuild-release: wipe-release build-release
170
171 plugins: $(BR)/.bootstrap.ok
172         $(call make,$(PLATFORM)_debug,plugins-install)
173
174 plugins-release: $(BR)/.bootstrap.ok
175         $(call make,$(PLATFORM),plugins-install)
176
177 build-vpp-api: $(BR)/.bootstrap.ok
178         $(call make,$(PLATFORM)_debug,vpp-api-install)
179
180 STARTUP_DIR ?= $(PWD)
181 ifeq ("$(wildcard $(STARTUP_CONF))","")
182 define run
183         @echo "WARNING: STARTUP_CONF not defined or file doesn't exist."
184         @echo "         Running with minimal startup config: $(MINIMAL_STARTUP_CONF)\n"
185         @cd $(STARTUP_DIR) && \
186           sudo $(2) $(1)/vpp/bin/vpp $(MINIMAL_STARTUP_CONF) plugin_path $(1)/plugins/lib64/vpp_plugins
187 endef
188 else
189 define run
190         @cd $(STARTUP_DIR) && \
191           sudo $(2) $(1)/vpp/bin/vpp $(shell cat $(STARTUP_CONF) | sed -e 's/#.*//') plugin_path $(1)/plugins/lib64/vpp_plugins
192 endef
193 endif
194
195 %.files: .FORCE
196         @find . \( -name '*\.[chyS]' -o -name '*\.java' -o -name '*\.lex' \) -and \
197                 \( -not -path './build-root*' -o -path \
198                 './build-root/build-vpp_debug-native/dpdk*' \) > $@
199
200 .FORCE:
201
202 run:
203         $(call run, $(BR)/install-$(PLATFORM)_debug-native)
204
205 run-release:
206         $(call run, $(BR)/install-$(PLATFORM)-native)
207
208 debug:
209         $(call run, $(BR)/install-$(PLATFORM)_debug-native,$(GDB) $(GDB_ARGS) --args)
210
211 debug-release:
212         $(call run, $(BR)/install-$(PLATFORM)-native,$(GDB) $(GDB_ARGS) --args)
213
214 build-vat:
215         $(call make,$(PLATFORM)_debug,vpp-api-test-install)
216
217 run-vat:
218         @sudo $(BR)/install-$(PLATFORM)_debug-native/vpp-api-test/bin/vpp_api_test
219
220 pkg-deb:
221         $(call make,$(PLATFORM),install-deb)
222
223 pkg-rpm:
224         $(call make,$(PLATFORM),install-rpm)
225
226 ctags: ctags.files
227         @ctags --totals --tag-relative -L $<
228         @rm $<
229
230 gtags: ctags
231         @gtags --gtagslabel=ctags
232
233 cscope: cscope.files
234         @cscope -b -q -v
235
236
237 #
238 # Build the documentation
239 #
240
241 # Doxygen configuration and our utility scripts
242 export DOXY_DIR ?= $(WS_ROOT)/doxygen
243
244 define make-doxy
245         @OS_ID="$(OS_ID)" WS_ROOT="$(WS_ROOT)" BR="$(BR)" make -C $(DOXY_DIR) $@
246 endef
247
248 .PHONY: bootstrap-doxygen doxygen wipe-doxygen
249
250 bootstrap-doxygen:
251         $(call make-doxy)
252
253 doxygen:
254         $(call make-doxy)
255
256 wipe-doxygen:
257         $(call make-doxy)
258