|
| 1 | +ARG CUDA_VERSION=latest |
| 2 | + |
| 3 | +FROM nvcr.io/nvidia/cuda:${CUDA_VERSION}-base-amzn2023 AS build |
| 4 | +FROM amazonlinux:2 |
| 5 | + |
| 6 | +ARG TARGETARCH |
| 7 | +ARG CUDA_VERSION |
| 8 | + |
| 9 | +SHELL ["/bin/bash", "-c"] |
| 10 | + |
| 11 | +# Remove cuda repository to avoid GPG errors |
| 12 | +RUN rm -f /etc/yum.repos.d/cuda* |
| 13 | + |
| 14 | +RUN yum update -y && yum install -y yum-utils && \ |
| 15 | + yum-config-manager --setopt=skip_missing_names_on_install=False && \ |
| 16 | + yum install -y \ |
| 17 | + gcc \ |
| 18 | + gcc-c++ \ |
| 19 | + make \ |
| 20 | + ca-certificates \ |
| 21 | + git -y && \ |
| 22 | + yum clean all |
| 23 | + |
| 24 | +ENV GOLANG_VERSION=1.23.1 |
| 25 | + |
| 26 | +# download appropriate binary based on the target architecture for multi-arch builds |
| 27 | +RUN OS_ARCH=$(echo ${TARGETARCH} | sed 's/x86_64/amd64/' ) && \ |
| 28 | + curl -s https://storage.googleapis.com/golang/go${GOLANG_VERSION}.linux-${OS_ARCH}.tar.gz \ |
| 29 | + | tar -C /usr/local -xz |
| 30 | + |
| 31 | +ENV PATH /usr/local/go/bin:$PATH |
| 32 | + |
| 33 | +WORKDIR /work |
| 34 | + |
| 35 | +RUN git clone https://github.com/NVIDIA/gpu-driver-container driver && \ |
| 36 | + cd driver/vgpu/src && \ |
| 37 | + go build -o vgpu-util && \ |
| 38 | + mv vgpu-util /work |
| 39 | +COPY --from=build /work/vgpu-util /usr/local/bin |
| 40 | + |
| 41 | +FROM nvcr.io/nvidia/cuda:${CUDA_VERSION}-base-amzn2023 |
| 42 | + |
| 43 | +SHELL ["/bin/bash", "-c"] |
| 44 | + |
| 45 | +ARG BASE_URL=https://us.download.nvidia.com/tesla |
| 46 | +ARG TARGETARCH |
| 47 | +ENV TARGETARCH=$TARGETARCH |
| 48 | +ARG DRIVER_VERSION |
| 49 | +ENV DRIVER_VERSION=$DRIVER_VERSION |
| 50 | + |
| 51 | +# Arg to indicate if driver type is either of passthrough(baremetal) or vgpu |
| 52 | +ARG DRIVER_TYPE=passthrough |
| 53 | +ENV DRIVER_TYPE=$DRIVER_TYPE |
| 54 | +ARG DRIVER_BRANCH=550 |
| 55 | +ENV DRIVER_BRANCH=$DRIVER_BRANCH |
| 56 | +ARG VGPU_LICENSE_SERVER_TYPE=NLS |
| 57 | +ENV VGPU_LICENSE_SERVER_TYPE=$VGPU_LICENSE_SERVER_TYPE |
| 58 | +# Enable vGPU version compability check by default |
| 59 | +ARG DISABLE_VGPU_VERSION_CHECK=true |
| 60 | +ENV DISABLE_VGPU_VERSION_CHECK=$DISABLE_VGPU_VERSION_CHECK |
| 61 | +ENV NVIDIA_VISIBLE_DEVICES=void |
| 62 | + |
| 63 | +RUN echo "TARGETARCH=$TARGETARCH" |
| 64 | + |
| 65 | +ADD install.sh /tmp |
| 66 | + |
| 67 | +RUN /tmp/install.sh reposetup && /tmp/install.sh depinstall && \ |
| 68 | + curl -fsSL -o /usr/local/bin/donkey https://github.com/3XX0/donkey/releases/download/v1.1.0/donkey && \ |
| 69 | + chmod +x /usr/local/bin/donkey |
| 70 | + |
| 71 | +COPY nvidia-driver /usr/local/bin |
| 72 | + |
| 73 | +ADD drivers drivers/ |
| 74 | + |
| 75 | +# Fetch the installer automatically for passthrough/baremetal types |
| 76 | +RUN if [ "$DRIVER_TYPE" != "vgpu" ]; then \ |
| 77 | + cd drivers && \ |
| 78 | + /tmp/install.sh download_installer; fi |
| 79 | + |
| 80 | +RUN if [ "$DRIVER_TYPE" != "vgpu" ] && [ "$TARGETARCH" != "arm64" ]; then \ |
| 81 | + yum update -y && \ |
| 82 | + yum install -y \ |
| 83 | + nvidia-fabric-manager-${DRIVER_VERSION}-1 \ |
| 84 | + libnvidia-nscq-${DRIVER_BRANCH}-${DRIVER_VERSION}-1; fi |
| 85 | + |
| 86 | +WORKDIR /drivers |
| 87 | + |
| 88 | +ARG PUBLIC_KEY=empty |
| 89 | +COPY ${PUBLIC_KEY} kernel/pubkey.x509 |
| 90 | + |
| 91 | +# Install / upgrade packages here that are required to resolve CVEs |
| 92 | +ARG CVE_UPDATES |
| 93 | +RUN if [ -n "${CVE_UPDATES}" ]; then \ |
| 94 | + yum update -y && yum install -y yum-utils && \ |
| 95 | + yum-config-manager --setopt=skip_missing_names_on_install=False && \ |
| 96 | + yum install -y \ |
| 97 | + ${CVE_UPDATES} && \ |
| 98 | + yum clean all; fi |
| 99 | + |
| 100 | +# Remove cuda repository to avoid GPG errors |
| 101 | +RUN rm -f /etc/yum.repos.d/cuda* |
| 102 | + |
| 103 | +# Add NGC DL license from the CUDA image |
| 104 | +RUN mkdir /licenses && mv /NGC-DL-CONTAINER-LICENSE /licenses/NGC-DL-CONTAINER-LICENSE |
| 105 | + |
| 106 | +ENTRYPOINT ["nvidia-driver", "init"] |
0 commit comments