2019-10-03 08:33:31 +00:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
|
|
set -e
|
2020-08-07 12:11:02 +00:00
|
|
|
set -o pipefail
|
2019-10-03 08:33:31 +00:00
|
|
|
|
|
|
|
SCRIPT_DIR="$(dirname "$BASH_SOURCE")"
|
|
|
|
SCRIPT_DIR="$(realpath "$SCRIPT_DIR")"
|
|
|
|
|
2020-03-27 02:14:52 +00:00
|
|
|
num_vcpus=$(nproc)
|
2019-10-03 08:33:31 +00:00
|
|
|
|
|
|
|
CEPH_DIR="${CEPH_DIR:-$SCRIPT_DIR}"
|
|
|
|
BUILD_DIR="${BUILD_DIR:-${CEPH_DIR}/build}"
|
|
|
|
DEPS_DIR="${DEPS_DIR:-$CEPH_DIR/build.deps}"
|
2020-08-07 12:11:02 +00:00
|
|
|
ZIP_DEST="${ZIP_DEST:-$BUILD_DIR/ceph.zip}"
|
2019-10-03 08:33:31 +00:00
|
|
|
|
|
|
|
CLEAN_BUILD=${CLEAN_BUILD:-}
|
|
|
|
SKIP_BUILD=${SKIP_BUILD:-}
|
2020-08-07 12:11:02 +00:00
|
|
|
# Usefull when packaging existing binaries.
|
|
|
|
SKIP_CMAKE=${SKIP_CMAKE:-}
|
|
|
|
SKIP_DLL_COPY=${SKIP_DLL_COPY:-}
|
|
|
|
SKIP_TESTS=${SKIP_TESTS:-}
|
2020-03-28 00:17:42 +00:00
|
|
|
SKIP_BINDIR_CLEAN=${SKIP_BINDIR_CLEAN:-}
|
2019-10-03 08:33:31 +00:00
|
|
|
NUM_WORKERS=${NUM_WORKERS:-$num_vcpus}
|
|
|
|
DEV_BUILD=${DEV_BUILD:-}
|
2020-08-07 12:11:02 +00:00
|
|
|
BUILD_ZIP=${BUILD_ZIP:-}
|
|
|
|
# By default, we'll build release binaries with debug symbols attached.
|
|
|
|
# If BUILD_ZIP and STRIP_ZIPPED are enabled, we'll strip the binaries
|
|
|
|
# that we're going to archive.
|
|
|
|
# Unfortunately we cannot use pdb symbols when cross compiling. cv2pdb
|
|
|
|
# well as llvm rely on mspdb*.dll in order to support this proprietary format.
|
|
|
|
STRIP_ZIPPED=${STRIP_ZIPPED:-}
|
2020-03-27 02:43:22 +00:00
|
|
|
# Allow for OS specific customizations through the OS flag.
|
|
|
|
# Valid options are currently "ubuntu" and "suse".
|
|
|
|
|
|
|
|
OS=${OS}
|
|
|
|
if [[ -z $OS ]]; then
|
|
|
|
if [[ -f /etc/os-release ]] && \
|
|
|
|
$(grep -q "^NAME=\".*SUSE.*\"" /etc/os-release); then
|
|
|
|
OS="suse"
|
|
|
|
elif [[ -f /etc/lsb-release ]] && \
|
|
|
|
$(grep -q "^DISTRIB_ID=Ubuntu" /etc/lsb-release); then
|
|
|
|
OS="ubuntu"
|
|
|
|
else
|
|
|
|
echo "Unsupported Linux distro, only SUSE and Ubuntu are currently \
|
|
|
|
supported. Set the OS variable to override"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
export OS="$OS"
|
2019-10-03 08:33:31 +00:00
|
|
|
|
|
|
|
# We'll have to be explicit here since auto-detecting doesn't work
|
|
|
|
# properly when cross compiling.
|
|
|
|
ALLOCATOR=${ALLOCATOR:-libc}
|
|
|
|
# Debug builds don't work with MINGW for the time being, failing with
|
|
|
|
# can't close <file>: File too big
|
|
|
|
# -Wa,-mbig-obj does not help.
|
|
|
|
CMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE:-RelWithDebInfo}
|
2021-01-07 13:14:00 +00:00
|
|
|
# Some tests can't use shared libraries yet due to unspecified dependencies.
|
|
|
|
# We'll do a static build by default for now.
|
|
|
|
ENABLE_SHARED=${ENABLE_SHARED:-OFF}
|
2019-10-03 08:33:31 +00:00
|
|
|
|
2020-08-07 12:11:02 +00:00
|
|
|
binDir="$BUILD_DIR/bin"
|
|
|
|
strippedBinDir="$BUILD_DIR/bin_stripped"
|
2019-10-03 08:33:31 +00:00
|
|
|
depsSrcDir="$DEPS_DIR/src"
|
|
|
|
depsToolsetDir="$DEPS_DIR/mingw"
|
|
|
|
|
2020-03-23 13:34:37 +00:00
|
|
|
generatorUsed="Unix Makefiles"
|
2019-10-03 08:33:31 +00:00
|
|
|
lz4Dir="${depsToolsetDir}/lz4"
|
|
|
|
sslDir="${depsToolsetDir}/openssl"
|
|
|
|
curlDir="${depsToolsetDir}/curl"
|
|
|
|
boostDir="${depsToolsetDir}/boost"
|
|
|
|
zlibDir="${depsToolsetDir}/zlib"
|
2020-03-24 02:16:28 +00:00
|
|
|
backtraceDir="${depsToolsetDir}/libbacktrace"
|
2019-10-03 08:33:31 +00:00
|
|
|
snappyDir="${depsToolsetDir}/snappy"
|
|
|
|
winLibDir="${depsToolsetDir}/windows/lib"
|
rbd: allow mounting images on Windows
This change will allow mapping rbd images on Windows, leveraging the
WNBD[1] Virtual Storport Miniport driver [2].
The behavior and CLI is similar to the Linux rbd-nbd, with a few
notable differences:
* device paths cannot be requested. The disk number and path will
be picked by Windows. If a device path is provided by the user
when mapping an image, it will be used as an identifier, which
can also be used when unmapping the image.
* the "show" command was added, which describes a specific mapping.
This can be used for retrieving the disk path.
* the "service" command was added, allowing rbd-wnbd to run as a
Windows service. All mappings are currently perisistent, being
recreated when the service stops, unless explicitly unmapped.
The service disconnects the mappings when being stopped.
* the "list" command also includes a "status" column.
The purpose of the "service" mode is to ensure that mappings survive
reboots and that the Windows service start order can be adjusted so
that rbd images can be mapped before starting services that may depend
on it, such as VMMS.
The mapped images can either be consumed by the host directly or exposed
to Hyper-V VMs.
While at it, we'll skip building rbd-mirror as it's quite unlikely that
this daemon is going to be used on Windows for now.
[1] https://github.com/cloudbase/wnbd
[2] https://docs.microsoft.com/en-us/windows-hardware/drivers/storage/overview-of-storage-virtual-miniport-drivers
Signed-off-by: Lucian Petrut <lpetrut@cloudbasesolutions.com>
Signed-off-by: Alin Gabriel Serdean <aserdean@cloudbasesolutions.com>
2020-07-30 11:40:31 +00:00
|
|
|
wnbdSrcDir="${depsSrcDir}/wnbd"
|
|
|
|
wnbdLibDir="${depsToolsetDir}/wnbd/lib"
|
2019-10-03 08:33:31 +00:00
|
|
|
|
|
|
|
depsDirs="$lz4Dir;$curlDir;$sslDir;$boostDir;$zlibDir;$backtraceDir;$snappyDir"
|
|
|
|
depsDirs+=";$winLibDir"
|
|
|
|
|
2020-03-23 13:34:37 +00:00
|
|
|
lz4Lib="${lz4Dir}/lib/dll/liblz4-1.dll"
|
2019-10-03 08:33:31 +00:00
|
|
|
lz4Include="${lz4Dir}/lib"
|
|
|
|
curlLib="${curlDir}/lib/libcurl.dll.a"
|
|
|
|
curlInclude="${curlDir}/include"
|
|
|
|
|
|
|
|
if [[ -n $CLEAN_BUILD ]]; then
|
|
|
|
echo "Cleaning up build dir: $BUILD_DIR"
|
|
|
|
rm -rf $BUILD_DIR
|
2020-03-24 03:13:36 +00:00
|
|
|
rm -rf $DEPS_DIR
|
2019-10-03 08:33:31 +00:00
|
|
|
fi
|
2020-03-28 00:17:42 +00:00
|
|
|
if [[ -z $SKIP_BINDIR_CLEAN ]]; then
|
|
|
|
echo "Cleaning up bin dir: $binDir"
|
|
|
|
rm -rf $binDir
|
|
|
|
fi
|
2019-10-03 08:33:31 +00:00
|
|
|
|
2020-03-24 03:13:36 +00:00
|
|
|
if [[ ! -f ${depsToolsetDir}/completed ]]; then
|
2019-10-03 08:33:31 +00:00
|
|
|
echo "Preparing dependencies: $DEPS_DIR"
|
2020-03-27 02:43:22 +00:00
|
|
|
NUM_WORKERS=$NUM_WORKERS DEPS_DIR=$DEPS_DIR OS="$OS"\
|
2019-10-03 08:33:31 +00:00
|
|
|
"$SCRIPT_DIR/win32_deps_build.sh"
|
|
|
|
fi
|
|
|
|
|
|
|
|
mkdir -p $BUILD_DIR
|
|
|
|
cd $BUILD_DIR
|
|
|
|
|
2020-03-27 02:43:22 +00:00
|
|
|
# Due to distribution specific mingw settings, the mingw.cmake file
|
|
|
|
# must be built prior to running cmake.
|
|
|
|
MINGW_CMAKE_FILE="$BUILD_DIR/mingw32.cmake"
|
|
|
|
MINGW_POSIX_FLAGS=1
|
|
|
|
source "$SCRIPT_DIR/mingw_conf.sh"
|
|
|
|
|
2020-08-07 12:11:02 +00:00
|
|
|
if [[ -z $SKIP_CMAKE ]]; then
|
2019-10-03 08:33:31 +00:00
|
|
|
# We'll need to cross compile Boost.Python before enabling
|
|
|
|
# "WITH_MGR".
|
|
|
|
echo "Generating solution. Log: ${BUILD_DIR}/cmake.log"
|
|
|
|
|
|
|
|
# This isn't propagated to some of the subprojects, we'll use an env variable
|
|
|
|
# for now.
|
|
|
|
export CMAKE_PREFIX_PATH=$depsDirs
|
|
|
|
|
|
|
|
if [[ -n $DEV_BUILD ]]; then
|
|
|
|
echo "Dev build enabled."
|
|
|
|
echo "Git versioning will be disabled."
|
|
|
|
ENABLE_GIT_VERSION="OFF"
|
2019-12-19 13:32:47 +00:00
|
|
|
WITH_CEPH_DEBUG_MUTEX="ON"
|
2019-10-03 08:33:31 +00:00
|
|
|
else
|
|
|
|
ENABLE_GIT_VERSION="ON"
|
2019-12-19 13:32:47 +00:00
|
|
|
WITH_CEPH_DEBUG_MUTEX="OFF"
|
2019-10-03 08:33:31 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
# As opposed to Linux, Windows shared libraries can't have unresolved
|
|
|
|
# symbols. Until we fix the dependencies (which are either unspecified
|
|
|
|
# or circular), we'll have to stick to static linking.
|
|
|
|
cmake -D CMAKE_PREFIX_PATH=$depsDirs \
|
2020-03-27 02:43:22 +00:00
|
|
|
-D CMAKE_TOOLCHAIN_FILE="$MINGW_CMAKE_FILE" \
|
2019-10-03 08:33:31 +00:00
|
|
|
-D WITH_RDMA=OFF -D WITH_OPENLDAP=OFF \
|
|
|
|
-D WITH_GSSAPI=OFF -D WITH_FUSE=OFF -D WITH_XFS=OFF \
|
|
|
|
-D WITH_BLUESTORE=OFF -D WITH_LEVELDB=OFF \
|
|
|
|
-D WITH_LTTNG=OFF -D WITH_BABELTRACE=OFF \
|
2019-12-19 13:32:47 +00:00
|
|
|
-D WITH_SYSTEM_BOOST=ON -D WITH_MGR=OFF -D WITH_KVS=OFF \
|
2019-10-03 08:33:31 +00:00
|
|
|
-D WITH_LIBCEPHFS=OFF -D WITH_KRBD=OFF -D WITH_RADOSGW=OFF \
|
2021-01-07 13:14:00 +00:00
|
|
|
-D ENABLE_SHARED=$ENABLE_SHARED -D WITH_RBD=ON -D BUILD_GMOCK=ON \
|
2019-10-03 08:33:31 +00:00
|
|
|
-D WITH_CEPHFS=OFF -D WITH_MANPAGE=OFF \
|
2019-12-19 13:32:47 +00:00
|
|
|
-D WITH_MGR_DASHBOARD_FRONTEND=OFF -D WITH_SYSTEMD=OFF -D WITH_TESTS=ON \
|
2019-10-03 08:33:31 +00:00
|
|
|
-D LZ4_INCLUDE_DIR=$lz4Include -D LZ4_LIBRARY=$lz4Lib \
|
|
|
|
-D Backtrace_INCLUDE_DIR="$backtraceDir/include" \
|
2020-04-02 15:45:44 +00:00
|
|
|
-D Backtrace_LIBRARY="$backtraceDir/lib/libbacktrace.a" \
|
2019-10-03 08:33:31 +00:00
|
|
|
-D ENABLE_GIT_VERSION=$ENABLE_GIT_VERSION \
|
|
|
|
-D ALLOCATOR="$ALLOCATOR" -D CMAKE_BUILD_TYPE=$CMAKE_BUILD_TYPE \
|
rbd: allow mounting images on Windows
This change will allow mapping rbd images on Windows, leveraging the
WNBD[1] Virtual Storport Miniport driver [2].
The behavior and CLI is similar to the Linux rbd-nbd, with a few
notable differences:
* device paths cannot be requested. The disk number and path will
be picked by Windows. If a device path is provided by the user
when mapping an image, it will be used as an identifier, which
can also be used when unmapping the image.
* the "show" command was added, which describes a specific mapping.
This can be used for retrieving the disk path.
* the "service" command was added, allowing rbd-wnbd to run as a
Windows service. All mappings are currently perisistent, being
recreated when the service stops, unless explicitly unmapped.
The service disconnects the mappings when being stopped.
* the "list" command also includes a "status" column.
The purpose of the "service" mode is to ensure that mappings survive
reboots and that the Windows service start order can be adjusted so
that rbd images can be mapped before starting services that may depend
on it, such as VMMS.
The mapped images can either be consumed by the host directly or exposed
to Hyper-V VMs.
While at it, we'll skip building rbd-mirror as it's quite unlikely that
this daemon is going to be used on Windows for now.
[1] https://github.com/cloudbase/wnbd
[2] https://docs.microsoft.com/en-us/windows-hardware/drivers/storage/overview-of-storage-virtual-miniport-drivers
Signed-off-by: Lucian Petrut <lpetrut@cloudbasesolutions.com>
Signed-off-by: Alin Gabriel Serdean <aserdean@cloudbasesolutions.com>
2020-07-30 11:40:31 +00:00
|
|
|
-D WNBD_INCLUDE_DIRS="$wnbdSrcDir/include" \
|
|
|
|
-D WNBD_LIBRARIES="$wnbdLibDir/libwnbd.a" \
|
2019-12-19 13:32:47 +00:00
|
|
|
-D WITH_CEPH_DEBUG_MUTEX=$WITH_CEPH_DEBUG_MUTEX \
|
2019-10-03 08:33:31 +00:00
|
|
|
-G "$generatorUsed" \
|
|
|
|
$CEPH_DIR 2>&1 | tee "${BUILD_DIR}/cmake.log"
|
2020-08-07 12:11:02 +00:00
|
|
|
fi # [[ -z $SKIP_CMAKE ]]
|
2019-10-03 08:33:31 +00:00
|
|
|
|
|
|
|
if [[ -z $SKIP_BUILD ]]; then
|
|
|
|
echo "Building using $NUM_WORKERS workers. Log: ${BUILD_DIR}/build.log"
|
2019-11-25 15:00:59 +00:00
|
|
|
echo "" > "${BUILD_DIR}/build.log"
|
|
|
|
|
|
|
|
# We're going to use an associative array having subdirectories as keys
|
|
|
|
# and targets as values.
|
|
|
|
declare -A make_targets
|
2021-01-13 09:57:12 +00:00
|
|
|
make_targets["src/tools"]="ceph-conf rados"
|
2019-11-25 15:00:59 +00:00
|
|
|
make_targets["src/tools/immutable_object_cache"]="all"
|
|
|
|
make_targets["src/tools/rbd"]="all"
|
rbd: allow mounting images on Windows
This change will allow mapping rbd images on Windows, leveraging the
WNBD[1] Virtual Storport Miniport driver [2].
The behavior and CLI is similar to the Linux rbd-nbd, with a few
notable differences:
* device paths cannot be requested. The disk number and path will
be picked by Windows. If a device path is provided by the user
when mapping an image, it will be used as an identifier, which
can also be used when unmapping the image.
* the "show" command was added, which describes a specific mapping.
This can be used for retrieving the disk path.
* the "service" command was added, allowing rbd-wnbd to run as a
Windows service. All mappings are currently perisistent, being
recreated when the service stops, unless explicitly unmapped.
The service disconnects the mappings when being stopped.
* the "list" command also includes a "status" column.
The purpose of the "service" mode is to ensure that mappings survive
reboots and that the Windows service start order can be adjusted so
that rbd images can be mapped before starting services that may depend
on it, such as VMMS.
The mapped images can either be consumed by the host directly or exposed
to Hyper-V VMs.
While at it, we'll skip building rbd-mirror as it's quite unlikely that
this daemon is going to be used on Windows for now.
[1] https://github.com/cloudbase/wnbd
[2] https://docs.microsoft.com/en-us/windows-hardware/drivers/storage/overview-of-storage-virtual-miniport-drivers
Signed-off-by: Lucian Petrut <lpetrut@cloudbasesolutions.com>
Signed-off-by: Alin Gabriel Serdean <aserdean@cloudbasesolutions.com>
2020-07-30 11:40:31 +00:00
|
|
|
make_targets["src/tools/rbd_wnbd"]="all"
|
2019-11-25 15:00:59 +00:00
|
|
|
make_targets["src/compressor"]="all"
|
|
|
|
|
2021-01-13 09:57:12 +00:00
|
|
|
if [[ -z $SKIP_TESTS ]]; then
|
|
|
|
make_targets["src/tools"]+=" ceph_radosacl ceph_scratchtool"
|
|
|
|
make_targets["src/test"]="all"
|
|
|
|
fi
|
|
|
|
|
2019-11-25 15:00:59 +00:00
|
|
|
for target_subdir in "${!make_targets[@]}"; do
|
|
|
|
echo "Building $target_subdir: ${make_targets[$target_subdir]}" | tee -a "${BUILD_DIR}/build.log"
|
|
|
|
make -j $NUM_WORKERS -C $target_subdir ${make_targets[$target_subdir]} 2>&1 | tee -a "${BUILD_DIR}/build.log"
|
|
|
|
done
|
2019-10-03 08:33:31 +00:00
|
|
|
fi
|
2020-08-07 12:11:02 +00:00
|
|
|
|
|
|
|
if [[ -z $SKIP_DLL_COPY ]]; then
|
2020-03-27 02:43:22 +00:00
|
|
|
# To adjust mingw paths, see 'mingw_conf.sh'.
|
2020-08-07 12:11:02 +00:00
|
|
|
required_dlls=(
|
|
|
|
$zlibDir/zlib1.dll
|
2020-03-23 13:34:37 +00:00
|
|
|
$lz4Dir/lib/dll/liblz4-1.dll
|
2020-08-07 12:11:02 +00:00
|
|
|
$sslDir/bin/libcrypto-1_1-x64.dll
|
|
|
|
$sslDir/bin/libssl-1_1-x64.dll
|
|
|
|
$mingwTargetLibDir/libstdc++-6.dll
|
|
|
|
$mingwTargetLibDir/libgcc_s_seh-1.dll
|
2021-01-07 13:14:00 +00:00
|
|
|
$mingwLibpthreadDir/libwinpthread-1.dll
|
|
|
|
$boostDir/lib/*.dll)
|
2020-08-07 12:11:02 +00:00
|
|
|
echo "Copying required dlls to $binDir."
|
|
|
|
cp ${required_dlls[@]} $binDir
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ -n $BUILD_ZIP ]]; then
|
2020-03-28 00:17:42 +00:00
|
|
|
# Use a temp directory, in order to create a clean zip file
|
|
|
|
ZIP_TMPDIR=$(mktemp -d win_binaries.XXXXX)
|
2020-08-07 12:11:02 +00:00
|
|
|
if [[ -n $STRIP_ZIPPED ]]; then
|
2020-03-28 00:17:42 +00:00
|
|
|
echo "Stripping debug symbols from binaries."
|
2020-03-28 00:57:55 +00:00
|
|
|
rm -rf $strippedBinDir; mkdir $strippedBinDir
|
|
|
|
# Strip files individually, to save time and space
|
|
|
|
for file in $binDir/*.exe $binDir/*.dll; do
|
|
|
|
$MINGW_STRIP -o $strippedBinDir/$(basename $file) $file
|
|
|
|
done
|
|
|
|
# Copy any remaining files to the stripped directory
|
|
|
|
for file in $binDir/*; do
|
|
|
|
[[ ! -f $strippedBinDir/$(basename $file) ]] && \
|
|
|
|
cp $file $strippedBinDir
|
|
|
|
done
|
2020-03-28 00:17:42 +00:00
|
|
|
ln -s $strippedBinDir $ZIP_TMPDIR/ceph
|
|
|
|
else
|
|
|
|
ln -s $binDir $ZIP_TMPDIR/ceph
|
2020-08-07 12:11:02 +00:00
|
|
|
fi
|
|
|
|
echo "Building zip archive $ZIP_DEST."
|
2020-03-28 00:17:42 +00:00
|
|
|
# Include the README file in the archive
|
|
|
|
ln -s $CEPH_DIR/README.windows.rst $ZIP_TMPDIR/ceph/README.windows.rst
|
|
|
|
cd $ZIP_TMPDIR
|
|
|
|
[[ -f $ZIP_DEST ]] && rm $ZIP_DEST
|
|
|
|
zip -r $ZIP_DEST ceph
|
|
|
|
cd -
|
|
|
|
rm -rf $ZIP_TMPDIR/ceph/README.windows.rst $ZIP_TMPDIR
|
|
|
|
echo -e '\n WIN32 files zipped to: '$ZIP_DEST'\n'
|
2020-08-07 12:11:02 +00:00
|
|
|
fi
|