|
|
@ -4,9 +4,9 @@ set -xe
|
|
|
|
|
|
|
|
|
|
|
|
# Set BASE_IMAGE according to env variables
|
|
|
|
# Set BASE_IMAGE according to env variables
|
|
|
|
if [ ${WITH_GPU} == "ON" ]; then
|
|
|
|
if [ ${WITH_GPU} == "ON" ]; then
|
|
|
|
BASE_IMAGE="nvidia/cuda:8.0-cudnn5-runtime-ubuntu14.04"
|
|
|
|
BASE_IMAGE="nvidia/cuda:8.0-cudnn5-runtime-ubuntu16.04"
|
|
|
|
else
|
|
|
|
else
|
|
|
|
BASE_IMAGE="ubuntu:14.04"
|
|
|
|
BASE_IMAGE="ubuntu:16.04"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
DOCKERFILE_GPU_ENV=""
|
|
|
|
DOCKERFILE_GPU_ENV=""
|
|
|
@ -22,6 +22,20 @@ cd /paddle/build
|
|
|
|
# build script will not fail if *.deb does not exist
|
|
|
|
# build script will not fail if *.deb does not exist
|
|
|
|
rm *.deb 2>/dev/null || true
|
|
|
|
rm *.deb 2>/dev/null || true
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cat <<EOF
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
Configuring cmake in /paddle/build ...
|
|
|
|
|
|
|
|
-DCMAKE_BUILD_TYPE=Release
|
|
|
|
|
|
|
|
-DWITH_DOC=OFF
|
|
|
|
|
|
|
|
-DWITH_GPU=${WITH_GPU:-OFF}
|
|
|
|
|
|
|
|
-DWITH_AVX=${WITH_AVX:-OFF}
|
|
|
|
|
|
|
|
-DWITH_SWIG_PY=ON
|
|
|
|
|
|
|
|
-DCUDNN_ROOT=/usr/
|
|
|
|
|
|
|
|
-DWITH_STYLE_CHECK=${WITH_STYLE_CHECK:-OFF}
|
|
|
|
|
|
|
|
-DWITH_TESTING=${WITH_TESTING:-OFF}
|
|
|
|
|
|
|
|
-DCMAKE_EXPORT_COMPILE_COMMANDS=ON
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
EOF
|
|
|
|
cmake .. \
|
|
|
|
cmake .. \
|
|
|
|
-DCMAKE_BUILD_TYPE=Release \
|
|
|
|
-DCMAKE_BUILD_TYPE=Release \
|
|
|
|
-DWITH_DOC=OFF \
|
|
|
|
-DWITH_DOC=OFF \
|
|
|
@ -32,50 +46,61 @@ cmake .. \
|
|
|
|
-DWITH_STYLE_CHECK=${WITH_STYLE_CHECK:-OFF} \
|
|
|
|
-DWITH_STYLE_CHECK=${WITH_STYLE_CHECK:-OFF} \
|
|
|
|
-DWITH_TESTING=${WITH_TESTING:-OFF} \
|
|
|
|
-DWITH_TESTING=${WITH_TESTING:-OFF} \
|
|
|
|
-DCMAKE_EXPORT_COMPILE_COMMANDS=ON
|
|
|
|
-DCMAKE_EXPORT_COMPILE_COMMANDS=ON
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cat <<EOF
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
Building in /paddle/build ...
|
|
|
|
|
|
|
|
Build unit tests: ${WITH_TESTING:-OFF}
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
EOF
|
|
|
|
make -j `nproc`
|
|
|
|
make -j `nproc`
|
|
|
|
if [ ${WITH_TESTING:-OFF} == "ON" ] && [ ${RUN_TEST:-OFF} == "ON" ] ; then
|
|
|
|
if [ ${WITH_TESTING:-OFF} == "ON" ] && [ ${RUN_TEST:-OFF} == "ON" ] ; then
|
|
|
|
pip uninstall -y py-paddle paddle || true
|
|
|
|
pip uninstall -y py-paddle paddle || true
|
|
|
|
ctest -V
|
|
|
|
ctest -V
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cat <<EOF
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
Installing ...
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
EOF
|
|
|
|
make install
|
|
|
|
make install
|
|
|
|
pip install /usr/local/opt/paddle/share/wheels/*.whl
|
|
|
|
pip install /usr/local/opt/paddle/share/wheels/*.whl
|
|
|
|
|
|
|
|
paddle version
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# To build documentation, we need to run cmake twice.
|
|
|
|
# To build documentation, we need to run cmake again after installing
|
|
|
|
# This awkwardness is due to https://github.com/PaddlePaddle/Paddle/issues/1854.
|
|
|
|
# PaddlePaddle. This awkwardness is due to
|
|
|
|
# It also describes a solution.
|
|
|
|
# https://github.com/PaddlePaddle/Paddle/issues/1854. It also
|
|
|
|
|
|
|
|
# describes a solution.
|
|
|
|
if [ ${WITH_DOC} == "ON" ]; then
|
|
|
|
if [ ${WITH_DOC} == "ON" ]; then
|
|
|
|
|
|
|
|
cat <<EOF
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
Building documentation ...
|
|
|
|
|
|
|
|
In /paddle/build_doc
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
EOF
|
|
|
|
mkdir -p /paddle/build_doc
|
|
|
|
mkdir -p /paddle/build_doc
|
|
|
|
pushd /paddle/build_doc
|
|
|
|
pushd /paddle/build_doc
|
|
|
|
cmake .. \
|
|
|
|
cmake .. \
|
|
|
|
-DWITH_DOC=ON \
|
|
|
|
-DWITH_DOC=ON \
|
|
|
|
-DWITH_GPU=OFF \
|
|
|
|
-DWITH_GPU=OFF \
|
|
|
|
-DWITH_AVX=${WITH_AVX:-OFF} \
|
|
|
|
-DWITH_AVX=${WITH_AVX:-ON} \
|
|
|
|
-DWITH_SWIG_PY=ON \
|
|
|
|
-DWITH_SWIG_PY=ON \
|
|
|
|
-DWITH_STYLE_CHECK=OFF
|
|
|
|
-DWITH_STYLE_CHECK=OFF
|
|
|
|
make paddle_docs paddle_docs_cn
|
|
|
|
make paddle_docs paddle_docs_cn
|
|
|
|
DOC_DIR="/paddle/paddle/scripts/tools/build_docs/"
|
|
|
|
|
|
|
|
mkdir -p $DOC_DIR/doc
|
|
|
|
|
|
|
|
mkdir -p $DOC_DIR/doc_cn
|
|
|
|
|
|
|
|
cp -r /paddle/build_doc/doc/en/html/* $DOC_DIR/doc
|
|
|
|
|
|
|
|
cp -r /paddle/build_doc/doc/cn/html/* $DOC_DIR/doc_cn
|
|
|
|
|
|
|
|
popd
|
|
|
|
popd
|
|
|
|
rm -rf /paddle/build_doc
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
# generate deb package for current build
|
|
|
|
|
|
|
|
cpack -D CPACK_GENERATOR='DEB' ..
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if [[ ${WOBOQ:-OFF} == 'ON' ]]; then
|
|
|
|
if [[ ${WOBOQ:-OFF} == 'ON' ]]; then
|
|
|
|
apt-get install -y clang-3.8 llvm-3.8 libclang-3.8-dev
|
|
|
|
cat <<EOF
|
|
|
|
# Install woboq_codebrowser.
|
|
|
|
========================================
|
|
|
|
git clone https://github.com/woboq/woboq_codebrowser /woboq
|
|
|
|
Converting C++ source code into HTML ...
|
|
|
|
cd /woboq
|
|
|
|
========================================
|
|
|
|
cmake -DLLVM_CONFIG_EXECUTABLE=/usr/bin/llvm-config-3.8 \
|
|
|
|
EOF
|
|
|
|
-DCMAKE_BUILD_TYPE=Release \
|
|
|
|
export WOBOQ_OUT=/paddle/build/woboq_out
|
|
|
|
.
|
|
|
|
|
|
|
|
make -j `nproc`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
export WOBOQ_OUT=/woboq_out/paddle
|
|
|
|
|
|
|
|
export BUILD_DIR=/paddle/build
|
|
|
|
|
|
|
|
mkdir -p $WOBOQ_OUT
|
|
|
|
mkdir -p $WOBOQ_OUT
|
|
|
|
cp -rv /woboq/data $WOBOQ_OUT/../data
|
|
|
|
cp -rv /woboq/data $WOBOQ_OUT/../data
|
|
|
|
/woboq/generator/codebrowser_generator \
|
|
|
|
/woboq/generator/codebrowser_generator \
|
|
|
@ -84,11 +109,23 @@ if [[ ${WOBOQ:-OFF} == 'ON' ]]; then
|
|
|
|
-o $WOBOQ_OUT \
|
|
|
|
-o $WOBOQ_OUT \
|
|
|
|
-p paddle:/paddle
|
|
|
|
-p paddle:/paddle
|
|
|
|
/woboq/indexgenerator/codebrowser_indexgenerator $WOBOQ_OUT
|
|
|
|
/woboq/indexgenerator/codebrowser_indexgenerator $WOBOQ_OUT
|
|
|
|
cd /woboq
|
|
|
|
|
|
|
|
make clean
|
|
|
|
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
paddle version
|
|
|
|
# generate deb package for current build
|
|
|
|
|
|
|
|
# FIXME(typhoonzero): should we remove paddle/scripts/deb ?
|
|
|
|
|
|
|
|
cat <<EOF
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
Generating .deb package ...
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
cpack -D CPACK_GENERATOR='DEB' ..
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cat <<EOF
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
Generate /paddle/build/Dockerfile ...
|
|
|
|
|
|
|
|
========================================
|
|
|
|
|
|
|
|
EOF
|
|
|
|
|
|
|
|
|
|
|
|
cat > /paddle/build/Dockerfile <<EOF
|
|
|
|
cat > /paddle/build/Dockerfile <<EOF
|
|
|
|
FROM ${BASE_IMAGE}
|
|
|
|
FROM ${BASE_IMAGE}
|
|
|
|