blob: 3b54d144c15e4a7d94928c4951c97459fe0f5e08 [file] [log] [blame]
Alanny Lopez56fc36a2017-07-27 13:55:44 -05001#!/bin/bash
Alanny Lopezb0a12dd2017-04-24 16:21:47 -05002###############################################################################
Chris Smart02651712015-11-11 11:09:00 +11003#
Michael Shepos3939e952019-01-16 16:00:35 -06004# This build script is for running the OpenBMC builds as Docker containers.
Alanny Lopez3fbaa512017-04-24 15:46:52 -05005#
Alanny Lopezb0a12dd2017-04-24 16:21:47 -05006###############################################################################
7#
Alanny Lopeze08e8702018-02-24 18:07:13 -06008# Script Variables:
9# build_scripts_dir The path of the openbmc-build-scripts directory.
10# Default: The directory containing this script
11# http_proxy The HTTP address of the proxy server to connect to.
12# Default: "", proxy is not setup if this is not set
13# WORKSPACE Path of the workspace directory where some intermediate
14# files and the images will be saved to.
15# Default: "~/{RandomNumber}"
Andrew Geisslerdc1e7022018-03-26 07:54:48 -070016# num_cpu Number of cpu's to give bitbake, default is total amount
17# in system
Alanny Lopezb0a12dd2017-04-24 16:21:47 -050018#
Alanny Lopeze08e8702018-02-24 18:07:13 -060019# Docker Image Build Variables:
Alanny Lopez1246b032018-02-24 23:34:55 -060020# BITBAKE_OPTS Set to "-c populate_sdk" or whatever other BitBake options
Alanny Lopeze08e8702018-02-24 18:07:13 -060021# you'd like to pass into the build.
22# Default: "", no options set
Alanny Lopez1246b032018-02-24 23:34:55 -060023# build_dir Path where the actual BitBake build occurs inside the
Alanny Lopeze08e8702018-02-24 18:07:13 -060024# container, path cannot be located on network storage.
25# Default: "/tmp/openbmc"
26# distro The distro used as the base image for the build image:
27# fedora|ubuntu
28# Default: "ubuntu"
Alanny Lopez1246b032018-02-24 23:34:55 -060029# img_name The name given to the target build's docker image.
Alanny Lopeze08e8702018-02-24 18:07:13 -060030# Default: "openbmc/${distro}:${imgtag}-${target}-${ARCH}"
Alanny Lopez1246b032018-02-24 23:34:55 -060031# img_tag The base docker image distro tag:
Alanny Lopeze08e8702018-02-24 18:07:13 -060032# ubuntu: latest|16.04|14.04|trusty|xenial
33# fedora: 23|24|25
34# Default: "latest"
35# target The target we aim to build:
Andrew Geisslerdd820722018-02-20 13:42:58 -060036# evb-ast2500|palmetto|qemu|qemux86-64
Vijay Khemka4c5b12e2019-01-23 14:50:09 -080037# romulus|s2600wf|witherspoon|zaius|tiogapass
Alanny Lopeze08e8702018-02-24 18:07:13 -060038# Default: "qemu"
Andrew Geissler215e43c2019-04-23 10:57:48 -050039# no_tar Set to true if you do not want the debug tar built
40# Default: "false"
Alanny Lopez723fea62017-09-12 11:22:17 -050041#
Alanny Lopeze08e8702018-02-24 18:07:13 -060042# Deployment Variables:
Alanny Lopez1246b032018-02-24 23:34:55 -060043# obmc_dir Path of the OpenBMC repo directory used as a reference
Alanny Lopeze08e8702018-02-24 18:07:13 -060044# for the build inside the container.
45# Default: "${WORKSPACE}/openbmc"
Michael Shepos10afbb22019-02-06 13:33:07 -060046# xtrct_small_copy_dir
47# Directory within build_dir that should be copied to
48# xtrct_path. The directory and all parents up to, but not
49# including, build_dir will be copied. For example, if
50# build_dir is set to "/tmp/openbmc" and this is set to
51# "build/tmp", the directory at xtrct_path will have the
52# following directory structure:
53# xtrct_path
54# | - build
55# | - tmp
56# ...
57# Can also be set to the empty string to copy the entire
58# contents of build_dir to xtrct_path.
59# Default: "deploy/images".
Alanny Lopezb0a12dd2017-04-24 16:21:47 -050060#
61###############################################################################
Joel Stanley4b8b2392016-02-12 15:44:57 +103062# Trace bash processing. Set -e so when a step fails, we fail the build
Joel Stanley38c9d142016-02-16 12:31:55 +103063set -xeo pipefail
Chris Smart02651712015-11-11 11:09:00 +110064
Alanny Lopez46967702018-02-25 00:29:14 -060065# Script Variables:
66build_scripts_dir=${build_scripts_dir:-"$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"}
67http_proxy=${http_proxy:-}
68WORKSPACE=${WORKSPACE:-${HOME}/${RANDOM}${RANDOM}}
Andrew Geisslerdc1e7022018-03-26 07:54:48 -070069num_cpu=${num_cpu:-$(nproc)}
Alanny Lopez46967702018-02-25 00:29:14 -060070
71# Docker Image Build Variables:
72build_dir=${build_dir:-/tmp/openbmc}
Chris Smart02651712015-11-11 11:09:00 +110073distro=${distro:-ubuntu}
Alanny Lopez1246b032018-02-24 23:34:55 -060074img_tag=${img_tag:-latest}
Alanny Lopez46967702018-02-25 00:29:14 -060075target=${target:-qemu}
Andrew Geissler215e43c2019-04-23 10:57:48 -050076no_tar=${no_tar:-false}
Alanny Lopez46967702018-02-25 00:29:14 -060077
78# Deployment variables
Alanny Lopez46967702018-02-25 00:29:14 -060079obmc_dir=${obmc_dir:-${WORKSPACE}/openbmc}
Michael Shepos3939e952019-01-16 16:00:35 -060080ssc_dir=${HOME}
Michael Shepos10afbb22019-02-06 13:33:07 -060081xtrct_small_copy_dir=${xtrct_small_copy_dir:-deploy/images}
Michael Shepos3939e952019-01-16 16:00:35 -060082xtrct_path="${obmc_dir}/build/tmp"
83xtrct_copy_timeout="300"
Alanny Lopez46967702018-02-25 00:29:14 -060084
Chris Smartc3522542016-02-16 11:59:36 +110085PROXY=""
Chris Smart02651712015-11-11 11:09:00 +110086
Alanny Lopezccc650e2017-04-24 15:14:20 -050087# Determine the architecture
88ARCH=$(uname -m)
89
90# Determine the prefix of the Dockerfile's base image
91case ${ARCH} in
92 "ppc64le")
93 DOCKER_BASE="ppc64le/"
94 ;;
95 "x86_64")
96 DOCKER_BASE=""
97 ;;
98 *)
99 echo "Unsupported system architecture(${ARCH}) found for docker image"
100 exit 1
101esac
Andrew Geissler11abbbe2016-08-14 19:39:47 -0500102
Chris Smart02651712015-11-11 11:09:00 +1100103# Timestamp for job
104echo "Build started, $(date)"
105
Alanny Lopez1246b032018-02-24 23:34:55 -0600106# If the obmc_dir directory doesn't exist clone it in
107if [ ! -d ${obmc_dir} ]; then
108 echo "Clone in openbmc master to ${obmc_dir}"
109 git clone https://github.com/openbmc/openbmc ${obmc_dir}
Andrew Geisslerc3c35202016-08-16 08:47:50 -0500110fi
111
Alanny Lopez1246b032018-02-24 23:34:55 -0600112# Make and chown the xtrct_path directory to avoid permission errors
113if [ ! -d ${xtrct_path} ]; then
114 mkdir -p ${xtrct_path}
Alanny Lopez723fea62017-09-12 11:22:17 -0500115fi
Alanny Lopez1246b032018-02-24 23:34:55 -0600116chown ${UID}:${GROUPS} ${xtrct_path}
Alanny Lopez723fea62017-09-12 11:22:17 -0500117
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500118# Work out what build target we should be running and set BitBake command
Michael Shepos2de03e92018-11-07 15:54:56 -0600119MACHINE=""
Chris Smart02651712015-11-11 11:09:00 +1100120case ${target} in
Chris Smart02651712015-11-11 11:09:00 +1100121 palmetto)
Brad Bishop7161a172018-10-05 16:48:06 -0400122 LAYER_DIR="meta-ibm/meta-palmetto"
Chris Smart02651712015-11-11 11:09:00 +1100123 ;;
Joel Stanley0e077202016-06-28 16:42:45 +0930124 witherspoon)
Brad Bishop7161a172018-10-05 16:48:06 -0400125 LAYER_DIR="meta-ibm/meta-witherspoon"
Joel Stanley0e077202016-06-28 16:42:45 +0930126 ;;
Joel Stanley0e077202016-06-28 16:42:45 +0930127 evb-ast2500)
Brad Bishop7161a172018-10-05 16:48:06 -0400128 LAYER_DIR="meta-evb/meta-evb-aspeed/meta-evb-ast2500"
Joel Stanley0e077202016-06-28 16:42:45 +0930129 ;;
Ed Tanous6dc40d92018-07-30 11:13:36 -0700130 s2600wf)
Brad Bishop7161a172018-10-05 16:48:06 -0400131 LAYER_DIR="meta-intel/meta-s2600wf"
Ed Tanous6dc40d92018-07-30 11:13:36 -0700132 ;;
Joel Stanley915381f2016-11-01 16:58:59 +1030133 zaius)
Brad Bishop7161a172018-10-05 16:48:06 -0400134 LAYER_DIR="meta-ingrasys/meta-zaius"
Joel Stanley915381f2016-11-01 16:58:59 +1030135 ;;
136 romulus)
Brad Bishop7161a172018-10-05 16:48:06 -0400137 LAYER_DIR="meta-ibm/meta-romulus"
Joel Stanley915381f2016-11-01 16:58:59 +1030138 ;;
Chris Smart02651712015-11-11 11:09:00 +1100139 qemu)
Brad Bishop7161a172018-10-05 16:48:06 -0400140 LAYER_DIR="meta-phosphor"
Michael Shepos2de03e92018-11-07 15:54:56 -0600141 # MACHINE defaults to `qemuarm` in this layer, no change necessary
Chris Smart02651712015-11-11 11:09:00 +1100142 ;;
Andrew Geisslerdd820722018-02-20 13:42:58 -0600143 qemux86-64)
Michael Shepos2de03e92018-11-07 15:54:56 -0600144 LAYER_DIR="meta-phosphor"
145 # MACHINE defaults to `qemuarm` in this layer, change to `qemux86-64`
146 MACHINE="qemux86-64"
Andrew Geisslerdd820722018-02-20 13:42:58 -0600147 ;;
Vijay Khemka4c5b12e2019-01-23 14:50:09 -0800148 tiogapass)
149 LAYER_DIR="meta-facebook/meta-tiogapass"
150 ;;
Chris Smart02651712015-11-11 11:09:00 +1100151 *)
152 exit 1
153 ;;
154esac
155
Brad Bishop7161a172018-10-05 16:48:06 -0400156BITBAKE_CMD="TEMPLATECONF=${LAYER_DIR}/conf source oe-init-build-env"
157
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500158# Configure Docker build
Chris Smart02651712015-11-11 11:09:00 +1100159if [[ "${distro}" == fedora ]];then
160
161 if [[ -n "${http_proxy}" ]]; then
162 PROXY="RUN echo \"proxy=${http_proxy}\" >> /etc/dnf/dnf.conf"
163 fi
164
165 Dockerfile=$(cat << EOF
Alanny Lopez1246b032018-02-24 23:34:55 -0600166 FROM ${DOCKER_BASE}${distro}:${img_tag}
Chris Smart02651712015-11-11 11:09:00 +1100167
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500168 ${PROXY}
Chris Smart02651712015-11-11 11:09:00 +1100169
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500170 # Set the locale
171 RUN locale-gen en_US.UTF-8
172 ENV LANG en_US.UTF-8
173 ENV LANGUAGE en_US:en
174 ENV LC_ALL en_US.UTF-8
Saqib Khan75635122017-03-23 10:57:34 -0500175
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500176 RUN dnf --refresh install -y \
177 bzip2 \
178 chrpath \
179 cpio \
180 diffstat \
181 findutils \
182 gcc \
183 gcc-c++ \
184 git \
185 make \
186 patch \
187 perl-bignum \
188 perl-Data-Dumper \
189 perl-Thread-Queue \
190 python-devel \
191 python3-devel \
192 SDL-devel \
193 socat \
194 subversion \
195 tar \
196 texinfo \
197 wget \
Saqib Khan5158a322017-10-23 11:31:24 -0500198 which \
199 iputils-ping
Chris Smart02651712015-11-11 11:09:00 +1100200
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500201 RUN grep -q ${GROUPS} /etc/group || groupadd -g ${GROUPS} ${USER}
202 RUN grep -q ${UID} /etc/passwd || useradd -d ${HOME} -m -u ${UID} -g ${GROUPS} ${USER}
Chris Smart02651712015-11-11 11:09:00 +1100203
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500204 USER ${USER}
205 ENV HOME ${HOME}
206 RUN /bin/bash
Chris Smart02651712015-11-11 11:09:00 +1100207EOF
208)
209
Alanny Lopezccc650e2017-04-24 15:14:20 -0500210elif [[ "${distro}" == ubuntu ]]; then
211
Chris Smart02651712015-11-11 11:09:00 +1100212 if [[ -n "${http_proxy}" ]]; then
213 PROXY="RUN echo \"Acquire::http::Proxy \\"\"${http_proxy}/\\"\";\" > /etc/apt/apt.conf.d/000apt-cacher-ng-proxy"
214 fi
215
216 Dockerfile=$(cat << EOF
Alanny Lopez1246b032018-02-24 23:34:55 -0600217 FROM ${DOCKER_BASE}${distro}:${img_tag}
Chris Smart02651712015-11-11 11:09:00 +1100218
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500219 ${PROXY}
Chris Smart02651712015-11-11 11:09:00 +1100220
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500221 ENV DEBIAN_FRONTEND noninteractive
Saqib Khan75635122017-03-23 10:57:34 -0500222
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500223 RUN apt-get update && apt-get install -yy \
224 build-essential \
225 chrpath \
226 debianutils \
227 diffstat \
228 gawk \
229 git \
230 libdata-dumper-simple-perl \
231 libsdl1.2-dev \
232 libthread-queue-any-perl \
Alanny Lopez27af3a02017-05-26 10:49:06 -0500233 locales \
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500234 python \
235 python3 \
236 socat \
237 subversion \
238 texinfo \
239 cpio \
Saqib Khan5158a322017-10-23 11:31:24 -0500240 wget \
241 iputils-ping
Chris Smart02651712015-11-11 11:09:00 +1100242
Alanny Lopez27af3a02017-05-26 10:49:06 -0500243 # Set the locale
244 RUN locale-gen en_US.UTF-8
245 ENV LANG en_US.UTF-8
246 ENV LANGUAGE en_US:en
247 ENV LC_ALL en_US.UTF-8
248
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500249 RUN grep -q ${GROUPS} /etc/group || groupadd -g ${GROUPS} ${USER}
250 RUN grep -q ${UID} /etc/passwd || useradd -d ${HOME} -m -u ${UID} -g ${GROUPS} ${USER}
Chris Smartd30c5902016-03-01 15:00:54 +1100251
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500252 USER ${USER}
253 ENV HOME ${HOME}
254 RUN /bin/bash
Chris Smart02651712015-11-11 11:09:00 +1100255EOF
256)
257fi
258
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500259# Create the Docker run script
Chris Smart02651712015-11-11 11:09:00 +1100260export PROXY_HOST=${http_proxy/#http*:\/\/}
261export PROXY_HOST=${PROXY_HOST/%:[0-9]*}
262export PROXY_PORT=${http_proxy/#http*:\/\/*:}
263
Chris Smart01d2b962015-11-11 18:05:30 +1100264mkdir -p ${WORKSPACE}
Chris Smart02651712015-11-11 11:09:00 +1100265
Andrew Geissler215e43c2019-04-23 10:57:48 -0500266# Determine command for bitbake image build
267bitbake_image="obmc-phosphor-image"
268if [ $no_tar = "false" ]; then
269 bitbake_image="${bitbake_image} obmc-phosphor-debug-tarball"
270fi
271
Chris Smart01d2b962015-11-11 18:05:30 +1100272cat > "${WORKSPACE}"/build.sh << EOF_SCRIPT
Chris Smart02651712015-11-11 11:09:00 +1100273#!/bin/bash
274
Joel Stanley38c9d142016-02-16 12:31:55 +1030275set -xeo pipefail
Chris Smart02651712015-11-11 11:09:00 +1100276
Alanny Lopez723fea62017-09-12 11:22:17 -0500277# Go into the OpenBMC directory, the build will handle changing directories
Alanny Lopez1246b032018-02-24 23:34:55 -0600278cd ${obmc_dir}
Chris Smart02651712015-11-11 11:09:00 +1100279
280# Set up proxies
281export ftp_proxy=${http_proxy}
282export http_proxy=${http_proxy}
283export https_proxy=${http_proxy}
284
Chris Smart01d2b962015-11-11 18:05:30 +1100285mkdir -p ${WORKSPACE}/bin
Chris Smart02651712015-11-11 11:09:00 +1100286
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500287# Configure proxies for BitBake
Chris Smart02651712015-11-11 11:09:00 +1100288if [[ -n "${http_proxy}" ]]; then
289
Chris Smartd30c5902016-03-01 15:00:54 +1100290 cat > ${WORKSPACE}/bin/git-proxy << \EOF_GIT
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500291 #!/bin/bash
292 # \$1 = hostname, \$2 = port
293 PROXY=${PROXY_HOST}
294 PROXY_PORT=${PROXY_PORT}
295 exec socat STDIO PROXY:\${PROXY}:\${1}:\${2},proxyport=\${PROXY_PORT}
Chris Smart02651712015-11-11 11:09:00 +1100296EOF_GIT
297
Chris Smart01d2b962015-11-11 18:05:30 +1100298 chmod a+x ${WORKSPACE}/bin/git-proxy
299 export PATH=${WORKSPACE}/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:${PATH}
Chris Smart02651712015-11-11 11:09:00 +1100300 git config core.gitProxy git-proxy
301
302 mkdir -p ~/.subversion
303
304 cat > ~/.subversion/servers << EOF_SVN
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500305 [global]
306 http-proxy-host = ${PROXY_HOST}
307 http-proxy-port = ${PROXY_PORT}
Chris Smart02651712015-11-11 11:09:00 +1100308EOF_SVN
309fi
310
311# Source our build env
312${BITBAKE_CMD}
313
Michael Shepos2de03e92018-11-07 15:54:56 -0600314# Change MACHINE name when given for build target
315if [[ -n "${MACHINE}" ]]; then
316 sed "s/^MACHINE\ ??=.*/MACHINE\ ??=\ \"${MACHINE}\"/" -i conf/local.conf
317fi
318
Alanny Lopezeaa2eae2017-04-24 14:55:07 -0500319# Custom BitBake config settings
Chris Smart02651712015-11-11 11:09:00 +1100320cat >> conf/local.conf << EOF_CONF
Chris Smartc650c202015-11-25 15:58:53 +1100321BB_NUMBER_THREADS = "$(nproc)"
322PARALLEL_MAKE = "-j$(nproc)"
Chris Smart02651712015-11-11 11:09:00 +1100323INHERIT += "rm_work"
324BB_GENERATE_MIRROR_TARBALLS = "1"
Alanny Lopez1246b032018-02-24 23:34:55 -0600325DL_DIR="${ssc_dir}/bitbake_downloads"
326SSTATE_DIR="${ssc_dir}/bitbake_sharedstatecache"
Chris Smart02651712015-11-11 11:09:00 +1100327USER_CLASSES += "buildstats"
Andrew Geissler931ec672016-08-11 13:10:05 -0500328INHERIT_remove = "uninative"
Alanny Lopez1246b032018-02-24 23:34:55 -0600329TMPDIR="${build_dir}"
Chris Smart02651712015-11-11 11:09:00 +1100330EOF_CONF
331
332# Kick off a build
Andrew Geissler215e43c2019-04-23 10:57:48 -0500333bitbake ${BITBAKE_OPTS} ${bitbake_image}
Chris Smart02651712015-11-11 11:09:00 +1100334
Alanny Lopez1246b032018-02-24 23:34:55 -0600335# Copy internal build directory into xtrct_path directory
Charles Paul Hoferb249c2c2018-09-12 12:15:13 -0500336if [[ ${xtrct_small_copy_dir} ]]; then
337 mkdir -p ${xtrct_path}/${xtrct_small_copy_dir}
338 timeout ${xtrct_copy_timeout} cp -r ${build_dir}/${xtrct_small_copy_dir}/* ${xtrct_path}/${xtrct_small_copy_dir}
339else
340 timeout ${xtrct_copy_timeout} cp -r ${build_dir}/* ${xtrct_path}
341fi
Charles Paul Hoferbe8700e2018-09-05 09:28:08 -0500342
343if [[ 0 -ne $? ]]; then
344 echo "Received a non-zero exit code from timeout"
345 exit 1
346fi
347
Chris Smart02651712015-11-11 11:09:00 +1100348EOF_SCRIPT
349
350chmod a+x ${WORKSPACE}/build.sh
351
Alanny Lopez51186882017-08-01 16:14:41 -0500352# Give the Docker image a name based on the distro,tag,arch,and target
Alanny Lopez1246b032018-02-24 23:34:55 -0600353img_name=${img_name:-openbmc/${distro}:${img_tag}-${target}-${ARCH}}
Alanny Lopez51186882017-08-01 16:14:41 -0500354
355# Build the Docker image
Alanny Lopez1246b032018-02-24 23:34:55 -0600356docker build -t ${img_name} - <<< "${Dockerfile}"
Alanny Lopez51186882017-08-01 16:14:41 -0500357
Michael Shepos3939e952019-01-16 16:00:35 -0600358# If obmc_dir or ssc_dir are ${HOME} or a subdirectory they will not be mounted
359mount_obmc_dir="-v ""${obmc_dir}"":""${obmc_dir}"" "
360mount_ssc_dir="-v ""${ssc_dir}"":""${ssc_dir}"" "
361if [[ "${obmc_dir}" = "${HOME}/"* || "${obmc_dir}" = "${HOME}" ]];then
362mount_obmc_dir=""
Alanny Lopez3fbaa512017-04-24 15:46:52 -0500363fi
Michael Shepos3939e952019-01-16 16:00:35 -0600364if [[ "${ssc_dir}" = "${HOME}/"* || "${ssc_dir}" = "${HOME}" ]];then
365mount_ssc_dir=""
366fi
367
368# Run the Docker container, execute the build.sh script
369docker run \
370--cap-add=sys_admin \
371--net=host \
372--rm=true \
373-e WORKSPACE=${WORKSPACE} \
374-w "${HOME}" \
375-v "${HOME}":"${HOME}" \
376${mount_obmc_dir} \
377${mount_ssc_dir} \
378--cpus="$num_cpu" \
379-t ${img_name} \
380${WORKSPACE}/build.sh
Chris Smart02651712015-11-11 11:09:00 +1100381
Alanny Lopezd32d3322017-07-18 15:21:39 -0500382# To maintain function of resources that used an older path, add a link
Alanny Lopez1246b032018-02-24 23:34:55 -0600383ln -sf ${xtrct_path}/deploy ${WORKSPACE}/deploy
Alanny Lopezd32d3322017-07-18 15:21:39 -0500384
Chris Smart02651712015-11-11 11:09:00 +1100385# Timestamp for build
Alanny Lopez0e8ad992017-06-19 15:45:23 -0500386echo "Build completed, $(date)"