# syntax = docker/dockerfile:experimental ARG ROCM_VERSION=3.7 ARG BASE_CUDA_VERSION=10.2 ARG GPU_IMAGE=nvidia/cuda:${BASE_CUDA_VERSION}-devel-centos7 FROM quay.io/pypa/manylinux2014_x86_64 as base ENV LC_ALL en_US.UTF-8 ENV LANG en_US.UTF-8 ENV LANGUAGE en_US.UTF-8 RUN sed -i s/mirror.centos.org/vault.centos.org/g /etc/yum.repos.d/*.repo RUN sed -i s/^#.*baseurl=http/baseurl=http/g /etc/yum.repos.d/*.repo RUN sed -i s/^mirrorlist=http/#mirrorlist=http/g /etc/yum.repos.d/*.repo RUN yum install -y wget curl perl util-linux xz bzip2 git patch which perl zlib-devel RUN yum install -y yum-utils centos-release-scl sudo RUN yum-config-manager --enable rhel-server-rhscl-7-rpms RUN yum install -y devtoolset-7-gcc devtoolset-7-gcc-c++ devtoolset-7-gcc-gfortran devtoolset-7-binutils ENV PATH=/opt/rh/devtoolset-7/root/usr/bin:$PATH ENV LD_LIBRARY_PATH=/opt/rh/devtoolset-7/root/usr/lib64:/opt/rh/devtoolset-7/root/usr/lib:$LD_LIBRARY_PATH # cmake RUN yum install -y cmake3 && \ ln -s /usr/bin/cmake3 /usr/bin/cmake FROM base as openssl # Install openssl (this must precede `build python` step) # (In order to have a proper SSL module, Python is compiled # against a recent openssl [see env vars above], which is linked # statically. We delete openssl afterwards.) ADD ./common/install_openssl.sh install_openssl.sh RUN bash ./install_openssl.sh && rm install_openssl.sh # remove unncessary python versions RUN rm -rf /opt/python/cp26-cp26m /opt/_internal/cpython-2.6.9-ucs2 RUN rm -rf /opt/python/cp26-cp26mu /opt/_internal/cpython-2.6.9-ucs4 RUN rm -rf /opt/python/cp33-cp33m /opt/_internal/cpython-3.3.6 RUN rm -rf /opt/python/cp34-cp34m /opt/_internal/cpython-3.4.6 FROM base as cuda ARG BASE_CUDA_VERSION=10.2 # Install CUDA ADD ./common/install_cuda.sh install_cuda.sh RUN bash ./install_cuda.sh ${BASE_CUDA_VERSION} && rm install_cuda.sh FROM base as intel # MKL ADD ./common/install_mkl.sh install_mkl.sh RUN bash ./install_mkl.sh && rm install_mkl.sh FROM base as magma ARG BASE_CUDA_VERSION=10.2 # Install magma ADD ./common/install_magma.sh install_magma.sh RUN bash ./install_magma.sh ${BASE_CUDA_VERSION} && rm install_magma.sh FROM base as jni # Install java jni header ADD ./common/install_jni.sh install_jni.sh ADD ./java/jni.h jni.h RUN bash ./install_jni.sh && rm install_jni.sh FROM base as libpng # Install libpng ADD ./common/install_libpng.sh install_libpng.sh RUN bash ./install_libpng.sh && rm install_libpng.sh FROM ${GPU_IMAGE} as common RUN sed -i s/mirror.centos.org/vault.centos.org/g /etc/yum.repos.d/*.repo RUN sed -i s/^#.*baseurl=http/baseurl=http/g /etc/yum.repos.d/*.repo RUN sed -i s/^mirrorlist=http/#mirrorlist=http/g /etc/yum.repos.d/*.repo ENV LC_ALL en_US.UTF-8 ENV LANG en_US.UTF-8 ENV LANGUAGE en_US.UTF-8 RUN yum install -y \ aclocal \ autoconf \ automake \ bison \ bzip2 \ curl \ diffutils \ file \ git \ make \ patch \ perl \ unzip \ util-linux \ wget \ which \ xz \ yasm RUN yum install -y \ https://repo.ius.io/ius-release-el7.rpm \ https://ossci-linux.s3.amazonaws.com/epel-release-7-14.noarch.rpm RUN yum swap -y git git236-core # git236+ would refuse to run git commands in repos owned by other users # Which causes version check to fail, as pytorch repo is bind-mounted into the image # Override this behaviour by treating every folder as safe # For more details see https://github.com/pytorch/pytorch/issues/78659#issuecomment-1144107327 RUN git config --global --add safe.directory "*" ENV SSL_CERT_FILE=/opt/_internal/certs.pem # Install LLVM version COPY --from=openssl /opt/openssl /opt/openssl COPY --from=base /opt/python /opt/python COPY --from=base /opt/_internal /opt/_internal COPY --from=base /usr/local/bin/auditwheel /usr/local/bin/auditwheel COPY --from=intel /opt/intel /opt/intel COPY --from=base /usr/local/bin/patchelf /usr/local/bin/patchelf COPY --from=libpng /usr/local/bin/png* /usr/local/bin/ COPY --from=libpng /usr/local/bin/libpng* /usr/local/bin/ COPY --from=libpng /usr/local/include/png* /usr/local/include/ COPY --from=libpng /usr/local/include/libpng* /usr/local/include/ COPY --from=libpng /usr/local/lib/libpng* /usr/local/lib/ COPY --from=libpng /usr/local/lib/pkgconfig /usr/local/lib/pkgconfig COPY --from=jni /usr/local/include/jni.h /usr/local/include/jni.h FROM common as cpu_final ARG BASE_CUDA_VERSION=10.2 RUN yum install -y yum-utils centos-release-scl RUN yum-config-manager --enable rhel-server-rhscl-7-rpms RUN yum install -y devtoolset-7-gcc devtoolset-7-gcc-c++ devtoolset-7-gcc-gfortran devtoolset-7-binutils ENV PATH=/opt/rh/devtoolset-7/root/usr/bin:$PATH ENV LD_LIBRARY_PATH=/opt/rh/devtoolset-7/root/usr/lib64:/opt/rh/devtoolset-7/root/usr/lib:$LD_LIBRARY_PATH # cmake RUN yum install -y cmake3 && \ ln -s /usr/bin/cmake3 /usr/bin/cmake # ninja RUN yum install -y http://repo.okay.com.mx/centos/7/x86_64/release/okay-release-1-1.noarch.rpm RUN yum install -y ninja-build FROM cpu_final as cuda_final RUN rm -rf /usr/local/cuda-${BASE_CUDA_VERSION} COPY --from=cuda /usr/local/cuda-${BASE_CUDA_VERSION} /usr/local/cuda-${BASE_CUDA_VERSION} COPY --from=magma /usr/local/cuda-${BASE_CUDA_VERSION} /usr/local/cuda-${BASE_CUDA_VERSION} FROM common as rocm_final ARG ROCM_VERSION=3.7 # Install ROCm ADD ./common/install_rocm.sh install_rocm.sh RUN bash ./install_rocm.sh ${ROCM_VERSION} && rm install_rocm.sh # cmake is already installed inside the rocm base image, but both 2 and 3 exist # cmake3 is needed for the later MIOpen custom build, so that step is last. RUN yum install -y cmake3 && \ rm -f /usr/bin/cmake && \ ln -s /usr/bin/cmake3 /usr/bin/cmake ADD ./common/install_miopen.sh install_miopen.sh RUN bash ./install_miopen.sh ${ROCM_VERSION} && rm install_miopen.sh