From 9c1fa3e4118f892509065217eac0833c08b6f40c Mon Sep 17 00:00:00 2001 From: William Lallemand Date: Thu, 23 May 2024 16:54:30 +0200 Subject: [PATCH] CI: scripts/buil-ssl: cleanup the boringssl and quictls build Put the quictls and boringssl build in their own function instead of keeping it in the main part of the script. --- scripts/build-ssl.sh | 62 +++++++++++++++++++++++--------------------- 1 file changed, 32 insertions(+), 30 deletions(-) diff --git a/scripts/build-ssl.sh b/scripts/build-ssl.sh index 156864fefe8ff..f1a6f8a86ed08 100755 --- a/scripts/build-ssl.sh +++ b/scripts/build-ssl.sh @@ -88,6 +88,10 @@ build_libressl () { } download_boringssl () { + + # travis-ci comes with go-1.11, while boringssl requires go-1.13 + eval "$(curl -sL https://raw.githubusercontent.com/travis-ci/gimme/master/gimme | GIMME_GO_VERSION=1.13 bash)" + if [ ! -d "${BUILDSSL_TMPDIR}/boringssl" ]; then git clone --depth=1 https://boringssl.googlesource.com/boringssl ${BUILDSSL_TMPDIR}/boringssl else @@ -98,6 +102,24 @@ download_boringssl () { fi } +build_boringssl () { + cd ${BUILDSSL_TMPDIR}/boringssl + if [ -d build ]; then rm -rf build; fi + mkdir build + cd build + cmake -GNinja -DCMAKE_BUILD_TYPE=release -DBUILD_SHARED_LIBS=1 .. + ninja + + rm -rf ${BUILDSSL_DESTDIR}/lib || exit 0 + rm -rf ${BUILDSSL_DESTDIR}/include || exit 0 + + mkdir -p ${BUILDSSL_DESTDIR}/lib + cp crypto/libcrypto.so ssl/libssl.so ${BUILDSSL_DESTDIR}/lib + + mkdir -p ${BUILDSSL_DESTDIR}/include + cp -r ../include/* ${BUILDSSL_DESTDIR}/include +} + download_aws_lc () { if [ ! -f "${BUILDSSL_TMPDIR}/aws-lc-${AWS_LC_VERSION}.tar.gz" ]; then mkdir -p "${BUILDSSL_TMPDIR}" @@ -135,6 +157,13 @@ download_quictls () { fi } +build_quictls () { + cd ${BUILDSSL_TMPDIR}/quictls + ./config shared no-tests ${QUICTLS_EXTRA_ARGS:-} --prefix="${BUILDSSL_DESTDIR}" --openssldir="${BUILDSSL_DESTDIR}" --libdir=lib -DPURIFY + make -j$(nproc) build_sw + make install_sw +} + download_wolfssl () { if [ ! -f "${BUILDSSL_TMPDIR}/wolfssl-${WOLFSSL_VERSION}.tar.gz" ]; then mkdir -p ${BUILDSSL_TMPDIR} @@ -177,28 +206,8 @@ if [ ! -z ${OPENSSL_VERSION+x} ]; then fi if [ ! -z ${BORINGSSL+x} ]; then - ( - - # travis-ci comes with go-1.11, while boringssl requires go-1.13 - eval "$(curl -sL https://raw.githubusercontent.com/travis-ci/gimme/master/gimme | GIMME_GO_VERSION=1.13 bash)" - - download_boringssl - cd ${BUILDSSL_TMPDIR}/boringssl - if [ -d build ]; then rm -rf build; fi - mkdir build - cd build - cmake -GNinja -DCMAKE_BUILD_TYPE=release -DBUILD_SHARED_LIBS=1 .. - ninja - - rm -rf ${BUILDSSL_DESTDIR}/lib || exit 0 - rm -rf ${BUILDSSL_DESTDIR}/include || exit 0 - - mkdir -p ${BUILDSSL_DESTDIR}/lib - cp crypto/libcrypto.so ssl/libssl.so ${BUILDSSL_DESTDIR}/lib - - mkdir -p ${BUILDSSL_DESTDIR}/include - cp -r ../include/* ${BUILDSSL_DESTDIR}/include - ) + download_boringssl + build_boringssl fi if [ ! -z ${AWS_LC_VERSION+x} ]; then @@ -207,15 +216,8 @@ if [ ! -z ${AWS_LC_VERSION+x} ]; then fi if [ ! -z ${QUICTLS+x} ]; then - ( download_quictls - cd ${BUILDSSL_TMPDIR}/quictls - - ./config shared no-tests ${QUICTLS_EXTRA_ARGS:-} --prefix="${BUILDSSL_DESTDIR}" --openssldir="${BUILDSSL_DESTDIR}" --libdir=lib -DPURIFY - make -j$(nproc) build_sw - make install_sw - - ) + build_quictls fi if [ ! -z ${WOLFSSL_VERSION+x} ]; then