aboutsummaryrefslogtreecommitdiff
path: root/utils
diff options
context:
space:
mode:
Diffstat (limited to 'utils')
-rw-r--r--utils/build_scripts/android32.Dockerfile81
-rw-r--r--utils/build_scripts/android64.Dockerfile83
-rw-r--r--utils/systemd/monerod.service11
3 files changed, 167 insertions, 8 deletions
diff --git a/utils/build_scripts/android32.Dockerfile b/utils/build_scripts/android32.Dockerfile
new file mode 100644
index 000000000..da81b6435
--- /dev/null
+++ b/utils/build_scripts/android32.Dockerfile
@@ -0,0 +1,81 @@
+FROM debian:jessie
+
+RUN apt-get update && apt-get install -y unzip automake build-essential curl file pkg-config git python
+
+WORKDIR /opt/android
+## INSTALL ANDROID SDK
+RUN curl -s -O http://dl.google.com/android/android-sdk_r24.4.1-linux.tgz \
+ && tar --no-same-owner -xzf android-sdk_r24.4.1-linux.tgz \
+ && rm -f android-sdk_r24.4.1-linux.tgz
+
+## INSTALL ANDROID NDK
+ENV ANDROID_NDK_REVISION 14
+RUN curl -s -O https://dl.google.com/android/repository/android-ndk-r${ANDROID_NDK_REVISION}-linux-x86_64.zip \
+ && unzip android-ndk-r${ANDROID_NDK_REVISION}-linux-x86_64.zip \
+ && rm -f android-ndk-r${ANDROID_NDK_REVISION}-linux-x86_64.zip
+
+ENV WORKDIR /opt/android
+ENV ANDROID_SDK_ROOT ${WORKDIR}/android-sdk-linux
+ENV ANDROID_NDK_ROOT ${WORKDIR}/android-ndk-r${ANDROID_NDK_REVISION}
+
+## INSTALL BOOST
+ENV BOOST_VERSION 1_62_0
+ENV BOOST_VERSION_DOT 1.62.0
+RUN curl -s -L -o boost_${BOOST_VERSION}.tar.bz2 https://sourceforge.net/projects/boost/files/boost/${BOOST_VERSION_DOT}/boost_${BOOST_VERSION}.tar.bz2/download \
+ && tar -xvf boost_${BOOST_VERSION}.tar.bz2 \
+ && rm -f /usr/boost_${BOOST_VERSION}.tar.bz2 \
+ && cd boost_${BOOST_VERSION} \
+ && ./bootstrap.sh
+
+ENV TOOLCHAIN_DIR ${WORKDIR}/toolchain-arm
+RUN ${ANDROID_NDK_ROOT}/build/tools/make_standalone_toolchain.py \
+ --arch arm \
+ --api 21 \
+ --install-dir $TOOLCHAIN_DIR \
+ --stl=libc++
+ENV PATH $TOOLCHAIN_DIR/arm-linux-androideabi/bin:$TOOLCHAIN_DIR/bin:$PATH
+
+## Build BOOST
+RUN cd boost_${BOOST_VERSION} \
+ && ./b2 --build-type=minimal link=static runtime-link=static --with-chrono --with-date_time --with-filesystem --with-program_options --with-regex --with-serialization --with-system --with-thread --build-dir=android32 --stagedir=android32 toolset=clang threading=multi threadapi=pthread target-os=android stage
+
+#INSTALL cmake (avoid 3.7 : https://github.com/android-ndk/ndk/issues/254)
+ENV CMAKE_VERSION 3.6.3
+RUN cd /usr \
+ && curl -s -O https://cmake.org/files/v3.6/cmake-${CMAKE_VERSION}-Linux-x86_64.tar.gz \
+ && tar -xzf /usr/cmake-${CMAKE_VERSION}-Linux-x86_64.tar.gz \
+ && rm -f /usr/cmake-${CMAKE_VERSION}-Linux-x86_64.tar.gz
+ENV PATH /usr/cmake-${CMAKE_VERSION}-Linux-x86_64/bin:$PATH
+
+#Note : we build openssl because the default lacks DSA1
+
+# download, configure and make Zlib
+ENV ZLIB_VERSION 1.2.11
+RUN curl -s -O http://zlib.net/zlib-${ZLIB_VERSION}.tar.gz \
+ && tar -xzf zlib-${ZLIB_VERSION}.tar.gz \
+ && rm zlib-${ZLIB_VERSION}.tar.gz \
+ && mv zlib-${ZLIB_VERSION} zlib \
+ && cd zlib && CC=clang CXX=clang++ ./configure --static \
+ && make
+# open ssl
+ENV OPENSSL_VERSION 1.0.2j
+RUN curl -s -O https://www.openssl.org/source/openssl-${OPENSSL_VERSION}.tar.gz \
+ && tar -xzf openssl-${OPENSSL_VERSION}.tar.gz \
+ && rm openssl-${OPENSSL_VERSION}.tar.gz \
+ && cd openssl-${OPENSSL_VERSION} \
+ && sed -i -e "s/mandroid/target\ armv7\-none\-linux\-androideabi/" Configure \
+ && CC=clang CXX=clang++ \
+ ./Configure android-armv7 \
+ no-asm \
+ no-shared --static \
+ --with-zlib-include=${WORKDIR}/zlib/include --with-zlib-lib=${WORKDIR}/zlib/lib \
+ && make build_crypto build_ssl \
+ && cd .. && mv openssl-${OPENSSL_VERSION} openssl
+
+RUN git clone https://github.com/monero-project/monero.git \
+ && cd monero \
+ && mkdir -p build/release \
+ && CC=clang CXX=clang++ \
+ BOOST_ROOT=${WORKDIR}/boost_${BOOST_VERSION} BOOST_LIBRARYDIR=${WORKDIR}/boost_${BOOST_VERSION}/android32/lib/ \
+ OPENSSL_ROOT_DIR=${WORKDIR}/openssl/ \
+ make release-static-android
diff --git a/utils/build_scripts/android64.Dockerfile b/utils/build_scripts/android64.Dockerfile
new file mode 100644
index 000000000..5e6bc05af
--- /dev/null
+++ b/utils/build_scripts/android64.Dockerfile
@@ -0,0 +1,83 @@
+FROM debian:jessie
+
+RUN apt-get update && apt-get install -y unzip automake build-essential curl file pkg-config git python
+
+WORKDIR /opt/android
+## INSTALL ANDROID SDK
+RUN curl -s -O http://dl.google.com/android/android-sdk_r24.4.1-linux.tgz \
+ && tar --no-same-owner -xzf android-sdk_r24.4.1-linux.tgz \
+ && rm -f android-sdk_r24.4.1-linux.tgz
+
+## INSTALL ANDROID NDK
+ENV ANDROID_NDK_REVISION 14
+RUN curl -s -O https://dl.google.com/android/repository/android-ndk-r${ANDROID_NDK_REVISION}-linux-x86_64.zip \
+ && unzip android-ndk-r${ANDROID_NDK_REVISION}-linux-x86_64.zip \
+ && rm -f android-ndk-r${ANDROID_NDK_REVISION}-linux-x86_64.zip
+
+ENV WORKDIR /opt/android
+ENV ANDROID_SDK_ROOT ${WORKDIR}/android-sdk-linux
+ENV ANDROID_NDK_ROOT ${WORKDIR}/android-ndk-r${ANDROID_NDK_REVISION}
+
+## INSTALL BOOST
+ENV BOOST_VERSION 1_62_0
+ENV BOOST_VERSION_DOT 1.62.0
+RUN curl -s -L -o boost_${BOOST_VERSION}.tar.bz2 https://sourceforge.net/projects/boost/files/boost/${BOOST_VERSION_DOT}/boost_${BOOST_VERSION}.tar.bz2/download \
+ && tar -xvf boost_${BOOST_VERSION}.tar.bz2 \
+ && rm -f /usr/boost_${BOOST_VERSION}.tar.bz2 \
+ && cd boost_${BOOST_VERSION} \
+ && ./bootstrap.sh
+
+ENV TOOLCHAIN_DIR ${WORKDIR}/toolchain-arm
+RUN ${ANDROID_NDK_ROOT}/build/tools/make_standalone_toolchain.py \
+ --arch arm64 \
+ --api 21 \
+ --install-dir $TOOLCHAIN_DIR \
+ --stl=libc++
+ENV PATH $TOOLCHAIN_DIR/aarch64-linux-android/bin:$TOOLCHAIN_DIR/bin:$PATH
+
+## Build BOOST
+RUN cd boost_${BOOST_VERSION} \
+ && ./b2 --build-type=minimal link=static runtime-link=static --with-chrono --with-date_time --with-filesystem --with-program_options --with-regex --with-serialization --with-system --with-thread --build-dir=android64 --stagedir=android64 toolset=clang threading=multi threadapi=pthread target-os=android stage
+
+#INSTALL cmake (avoid 3.7 : https://github.com/android-ndk/ndk/issues/254)
+ENV CMAKE_VERSION 3.6.3
+RUN cd /usr \
+ && curl -s -O https://cmake.org/files/v3.6/cmake-${CMAKE_VERSION}-Linux-x86_64.tar.gz \
+ && tar -xzf /usr/cmake-${CMAKE_VERSION}-Linux-x86_64.tar.gz \
+ && rm -f /usr/cmake-${CMAKE_VERSION}-Linux-x86_64.tar.gz
+ENV PATH /usr/cmake-${CMAKE_VERSION}-Linux-x86_64/bin:$PATH
+
+#Note : we build openssl because the default lacks DSA1
+
+# download, configure and make Zlib
+ENV ZLIB_VERSION 1.2.11
+RUN curl -s -O http://zlib.net/zlib-${ZLIB_VERSION}.tar.gz \
+ && tar -xzf zlib-${ZLIB_VERSION}.tar.gz \
+ && rm zlib-${ZLIB_VERSION}.tar.gz \
+ && mv zlib-${ZLIB_VERSION} zlib \
+ && cd zlib && CC=clang CXX=clang++ ./configure --static \
+ && make
+# open ssl
+ENV OPENSSL_VERSION 1.0.2j
+RUN curl -s -O https://www.openssl.org/source/openssl-${OPENSSL_VERSION}.tar.gz \
+ && tar -xzf openssl-${OPENSSL_VERSION}.tar.gz \
+ && rm openssl-${OPENSSL_VERSION}.tar.gz \
+ && cd openssl-${OPENSSL_VERSION} \
+ && sed -i -e "s/mandroid/target\ aarch64\-none\-linux\-android/" Configure \
+ && CC=clang CXX=clang++ \
+ ./Configure android \
+ no-asm \
+ no-shared --static \
+ --with-zlib-include=${WORKDIR}/zlib/include --with-zlib-lib=${WORKDIR}/zlib/lib \
+ && make build_crypto build_ssl \
+ && cd .. && mv openssl-${OPENSSL_VERSION} openssl
+
+RUN git clone https://github.com/monero-project/monero.git \
+ && cd monero \
+ && mkdir -p build/release \
+ && cd build/release \
+ && CC=clang CXX=clang++ \
+ BOOST_ROOT=${WORKDIR}/boost_${BOOST_VERSION} BOOST_LIBRARYDIR=${WORKDIR}/boost_${BOOST_VERSION}/android64/lib/ \
+ OPENSSL_ROOT_DIR=${WORKDIR}/openssl/ \
+ cmake -D BUILD_TESTS=OFF -D ARCH="armv8-a" -D STATIC=ON -D BUILD_64=ON -D CMAKE_BUILD_TYPE=release -D ANDROID=true -D INSTALL_VENDORED_LIBUNBOUND=ON -D BUILD_TAG="android" ../.. \
+ && make -j3
diff --git a/utils/systemd/monerod.service b/utils/systemd/monerod.service
index 182878ebb..12395eb8c 100644
--- a/utils/systemd/monerod.service
+++ b/utils/systemd/monerod.service
@@ -8,15 +8,10 @@ Group=monero
WorkingDirectory=~
Type=forking
-ExecStart=/usr/bin/monerod --config-file /etc/monerod.conf --detach
+PIDFile=/var/run/monerod.pid
-# This is necessary because monerod does not yet support
-# writing a PID file, which means systemd tries to guess the PID
-# by default, but it guesses wrong (sometimes, depending on
-# random timing of events), because the daemon forks twice.
-# The ultimate fix is for the daemon to write a PID file, and
-# a workaround is to disable the guessing feature in systemd.
-GuessMainPID=no
+ExecStart=/usr/bin/monerod --config-file /etc/monerod.conf \
+ --detach --pidfile /var/run/monerod.pid
[Install]
WantedBy=multi-user.target