X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=scripts%2Fbuild_oran.sh;h=12dce7bc9dc521ec455d1ff3bd2f4933c69fc01c;hb=f87e7ddc6c57b1f2f38727a24408d52c2872cc18;hp=05192ecc7e6280f17248aa2ae4984ddb93019e75;hpb=477f99a2439564e6870b6498c3ace8b7d5e4ea98;p=pti%2Frtp.git diff --git a/scripts/build_oran.sh b/scripts/build_oran.sh index 05192ec..12dce7b 100755 --- a/scripts/build_oran.sh +++ b/scripts/build_oran.sh @@ -1,11 +1,32 @@ -#!/bin/sh +#!/bin/bash +# +# Copyright (C) 2019 Wind River Systems, Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Ensure we fail the job if any steps fail. +set -e -o pipefail help_info () { cat << ENDHELP Usage: -$(basename $0) WORKSPACE_DIR +$(basename $0) <-w WORKSPACE_DIR> [-n] [-h] where: - WORKSPACE_DIR is the path for the project + -w WORKSPACE_DIR is the path for the project + -n dry-run only for bitbake + -h this help info + -e EXTRA_CONF is the pat for extra config file + -r whether to inherit rm_work (default is Yes) ENDHELP } @@ -19,19 +40,65 @@ echo_error () { echo_cmd () { echo - echo "$1" + echo_info "$1" echo "CMD: ${RUN_CMD}" } if [ $# -eq 0 ]; then + echo "Missing options!" help_info exit fi +check_yn_rm_work () { + yn="$1" + case ${yn} in + [Yy]|[Yy]es) + RM_WORK="Yes" + ;; + [Nn]|[Nn]o) + RM_WORK="No" + ;; + *) + echo "Invalid arg for -r option." + help_info + exit 1 + ;; + esac +} + +DRYRUN="" +EXTRA_CONF="" +RM_WORK="Yes" + SCRIPTS_DIR=`dirname $0` SCRIPTS_DIR=`readlink -f $SCRIPTS_DIR` -WORKSPACE=`readlink -f $1` +while getopts "w:e:r:nh" OPTION; do + case ${OPTION} in + w) + WORKSPACE=`readlink -f ${OPTARG}` + ;; + e) + EXTRA_CONF=`readlink -f ${OPTARG}` + ;; + n) + DRYRUN="-n" + ;; + r) + check_yn_rm_work ${OPTARG} + ;; + h) + help_info + exit + ;; + esac +done + +if [ -z ${WORKSPACE} ]; then + echo_info "No workspace specified, a directory 'workspace' will be created in current directory as the workspace" + WORKSPACE=`readlink -f workspace` +fi SRC_WRL_DIR=${WORKSPACE}/src_wrl1018 SRC_ORAN_DIR=${WORKSPACE}/src_oran @@ -54,13 +121,22 @@ RUN_CMD="./wrlinux-x/setup.sh --machines intel-x86-64 --layers meta-cloud-servic echo_cmd "Setup wrlinux build project:" ${RUN_CMD} -# Clone extra layers -echo_info "Cloning oran layer:" - -cd ${SRC_ORAN_DIR} -RUN_CMD="git clone https://gerrit.o-ran-sc.org/r/pti/rtp" -echo_cmd "Cloing with:" -${RUN_CMD} +# Clone the oran layer if it's not already cloned +# Check if the script is inside the repo +if cd ${SCRIPTS_DIR} && git rev-parse --is-inside-work-tree > /dev/null 2>&1; then + CLONED_ORAN_REPO=`dirname ${SCRIPTS_DIR}` + echo_info "Use the cloned oran repo: ${CLONED_ORAN_REPO}" + mkdir ${SRC_ORAN_DIR}/rtp + cd ${SRC_ORAN_DIR}/rtp + ln -sf ${CLONED_ORAN_REPO}/meta-oran meta-oran + ln -sf ${CLONED_ORAN_REPO}/scripts scripts +else + echo_info "Cloning oran layer:" + cd ${SRC_ORAN_DIR} + RUN_CMD="git clone https://gerrit.o-ran-sc.org/r/pti/rtp" + echo_cmd "Cloing with:" + ${RUN_CMD} +fi # Source the build env cd ${SRC_WRL_DIR} @@ -68,9 +144,11 @@ cd ${SRC_WRL_DIR} set ${PRJ_BUILD_DIR} . ./oe-init-build-env ${PRJ_BUILD_DIR} -# Add the meta-oran layer and required layers +# Add the meta-oran layer cd ${PRJ_BUILD_DIR} -bitbake-layers add-layer ${SRC_ORAN_DIR}/rtp/meta-oran +RUN_CMD="bitbake-layers add-layer ${SRC_ORAN_DIR}/rtp/meta-oran" +echo_cmd "Add the meta-oran layer into the build project" +${RUN_CMD} # Add extra configs into local.conf cat << EOF >> conf/local.conf @@ -79,9 +157,25 @@ cat << EOF >> conf/local.conf ######################## DISTRO = "oran-inf" BB_NO_NETWORK = '0' +WRTEMPLATE += "feature/oran-host-rt-tune" + +# Work around for CI build +IMAGE_INSTALL_remove = "ceph" EOF +if [ "${RM_WORK}" == "Yes" ]; then + echo "INHERIT += 'rm_work'" >> conf/local.conf +fi + +if [ "${EXTRA_CONF}" != "" ] && [ -f "${EXTRA_CONF}" ]; then + cat ${EXTRA_CONF} >> conf/local.conf +fi + # Build the oran-inf-host image mkdir -p logs TIMESTAMP=`date +"%Y%m%d_%H%M%S"` -bitbake oran-image-inf-host 2>&1|tee logs/bitbake_oran-image-inf-host_${TIMESTAMP}.log +RUN_CMD="bitbake ${DRYRUN} oran-image-inf-host" +echo_cmd "Build the oran-image-inf-host image" +bitbake ${DRYRUN} oran-image-inf-host 2>&1|tee logs/bitbake_oran-image-inf-host_${TIMESTAMP}.log + +echo_info "Build succeeded, you can get the image in ${PRJ_BUILD_DIR}/tmp-glibc/deploy/images/intel-x86-64/oran-image-inf-host-intel-x86-64.iso"