mirror of
https://github.com/NVIDIA/nvidia-container-toolkit
synced 2025-03-12 07:03:01 +00:00
Merge branch 'add-fedora35' into 'main'
Add fedora35 package targets See merge request nvidia/container-toolkit/container-toolkit!205
This commit is contained in:
commit
5d52ca8909
@ -57,6 +57,10 @@ stages:
|
|||||||
variables:
|
variables:
|
||||||
DIST: debian9
|
DIST: debian9
|
||||||
|
|
||||||
|
.dist-fedora35:
|
||||||
|
variables:
|
||||||
|
DIST: fedora35
|
||||||
|
|
||||||
.dist-opensuse-leap15.1:
|
.dist-opensuse-leap15.1:
|
||||||
variables:
|
variables:
|
||||||
DIST: opensuse-leap15.1
|
DIST: opensuse-leap15.1
|
||||||
|
@ -94,7 +94,7 @@ unit-tests:
|
|||||||
- .multi-arch-build
|
- .multi-arch-build
|
||||||
- .package-artifacts
|
- .package-artifacts
|
||||||
stage: package-build
|
stage: package-build
|
||||||
timeout: 2h 30m
|
timeout: 3h
|
||||||
script:
|
script:
|
||||||
- ./scripts/build-packages.sh ${DIST}-${ARCH}
|
- ./scripts/build-packages.sh ${DIST}-${ARCH}
|
||||||
|
|
||||||
@ -158,6 +158,18 @@ package-debian9-amd64:
|
|||||||
- .dist-debian9
|
- .dist-debian9
|
||||||
- .arch-amd64
|
- .arch-amd64
|
||||||
|
|
||||||
|
package-fedora35-aarch64:
|
||||||
|
extends:
|
||||||
|
- .package-build
|
||||||
|
- .dist-fedora35
|
||||||
|
- .arch-aarch64
|
||||||
|
|
||||||
|
package-fedora35-x86_64:
|
||||||
|
extends:
|
||||||
|
- .package-build
|
||||||
|
- .dist-fedora35
|
||||||
|
- .arch-x86_64
|
||||||
|
|
||||||
package-opensuse-leap15.1-x86_64:
|
package-opensuse-leap15.1-x86_64:
|
||||||
extends:
|
extends:
|
||||||
- .package-build
|
- .package-build
|
||||||
@ -278,6 +290,8 @@ image-packaging:
|
|||||||
- package-centos8-x86_64
|
- package-centos8-x86_64
|
||||||
- package-debian10-amd64
|
- package-debian10-amd64
|
||||||
- package-debian9-amd64
|
- package-debian9-amd64
|
||||||
|
- package-fedora35-aarch64
|
||||||
|
- package-fedora35-x86_64
|
||||||
- package-opensuse-leap15.1-x86_64
|
- package-opensuse-leap15.1-x86_64
|
||||||
- package-ubuntu16.04-amd64
|
- package-ubuntu16.04-amd64
|
||||||
- package-ubuntu16.04-ppc64le
|
- package-ubuntu16.04-ppc64le
|
||||||
|
@ -1,32 +0,0 @@
|
|||||||
disable-require = false
|
|
||||||
#swarm-resource = "DOCKER_RESOURCE_GPU"
|
|
||||||
#accept-nvidia-visible-devices-envvar-when-unprivileged = true
|
|
||||||
#accept-nvidia-visible-devices-as-volume-mounts = false
|
|
||||||
|
|
||||||
[nvidia-container-cli]
|
|
||||||
#root = "/run/nvidia/driver"
|
|
||||||
#path = "/usr/bin/nvidia-container-cli"
|
|
||||||
environment = []
|
|
||||||
#debug = "/var/log/nvidia-container-toolkit.log"
|
|
||||||
#ldcache = "/etc/ld.so.cache"
|
|
||||||
load-kmods = true
|
|
||||||
#no-cgroups = false
|
|
||||||
#user = "root:video"
|
|
||||||
ldconfig = "@/sbin/ldconfig"
|
|
||||||
|
|
||||||
[nvidia-container-runtime]
|
|
||||||
#debug = "/var/log/nvidia-container-runtime.log"
|
|
||||||
log-level = "info"
|
|
||||||
|
|
||||||
# Specify the runtimes to consider. This list is processed in order and the PATH
|
|
||||||
# searched for matching executables unless the entry is an absolute path.
|
|
||||||
runtimes = [
|
|
||||||
"docker-runc",
|
|
||||||
"runc",
|
|
||||||
]
|
|
||||||
|
|
||||||
mode = "auto"
|
|
||||||
|
|
||||||
[nvidia-container-runtime.modes.csv]
|
|
||||||
|
|
||||||
mount-spec-path = "/etc/nvidia-container-runtime/host-files-for-container.d"
|
|
@ -1,76 +0,0 @@
|
|||||||
ARG BASEIMAGE
|
|
||||||
FROM ${BASEIMAGE}
|
|
||||||
|
|
||||||
RUN yum install -y \
|
|
||||||
ca-certificates \
|
|
||||||
gcc \
|
|
||||||
wget \
|
|
||||||
git \
|
|
||||||
rpm-build \
|
|
||||||
make && \
|
|
||||||
rm -rf /var/cache/yum/*
|
|
||||||
|
|
||||||
ARG GOLANG_VERSION=0.0.0
|
|
||||||
RUN set -eux; \
|
|
||||||
\
|
|
||||||
arch="$(uname -m)"; \
|
|
||||||
case "${arch##*-}" in \
|
|
||||||
x86_64 | amd64) ARCH='amd64' ;; \
|
|
||||||
ppc64el | ppc64le) ARCH='ppc64le' ;; \
|
|
||||||
aarch64) ARCH='arm64' ;; \
|
|
||||||
*) echo "unsupported architecture"; exit 1 ;; \
|
|
||||||
esac; \
|
|
||||||
wget -nv -O - https://storage.googleapis.com/golang/go${GOLANG_VERSION}.linux-${ARCH}.tar.gz \
|
|
||||||
| tar -C /usr/local -xz
|
|
||||||
|
|
||||||
ENV GOPATH /go
|
|
||||||
ENV PATH $GOPATH/bin:/usr/local/go/bin:$PATH
|
|
||||||
|
|
||||||
# packaging
|
|
||||||
ARG PKG_NAME
|
|
||||||
ARG PKG_VERS
|
|
||||||
ARG PKG_REV
|
|
||||||
|
|
||||||
ENV VERSION $PKG_VERS
|
|
||||||
ENV RELEASE $PKG_REV
|
|
||||||
|
|
||||||
# output directory
|
|
||||||
ENV DIST_DIR=/tmp/nvidia-container-toolkit-$PKG_VERS/SOURCES
|
|
||||||
RUN mkdir -p $DIST_DIR /dist
|
|
||||||
|
|
||||||
# nvidia-container-toolkit
|
|
||||||
WORKDIR $GOPATH/src/nvidia-container-toolkit
|
|
||||||
COPY . .
|
|
||||||
|
|
||||||
ARG GIT_COMMIT
|
|
||||||
ENV GIT_COMMIT ${GIT_COMMIT}
|
|
||||||
RUN make PREFIX=${DIST_DIR} cmds
|
|
||||||
|
|
||||||
ARG CONFIG_TOML_SUFFIX
|
|
||||||
ENV CONFIG_TOML_SUFFIX ${CONFIG_TOML_SUFFIX}
|
|
||||||
COPY config/config.toml.${CONFIG_TOML_SUFFIX} $DIST_DIR/config.toml
|
|
||||||
|
|
||||||
# Hook for Project Atomic's fork of Docker: https://github.com/projectatomic/docker/tree/docker-1.13.1-rhel#add-dockerhooks-exec-custom-hooks-for-prestartpoststop-containerspatch
|
|
||||||
# This might not be useful on Amazon Linux, but it's simpler to keep the RHEL
|
|
||||||
# and Amazon Linux packages identical.
|
|
||||||
COPY oci-nvidia-hook $DIST_DIR/oci-nvidia-hook
|
|
||||||
|
|
||||||
# Hook for libpod/CRI-O: https://github.com/containers/libpod/blob/v0.8.5/pkg/hooks/docs/oci-hooks.5.md
|
|
||||||
COPY oci-nvidia-hook.json $DIST_DIR/oci-nvidia-hook.json
|
|
||||||
|
|
||||||
WORKDIR $DIST_DIR/..
|
|
||||||
COPY packaging/rpm .
|
|
||||||
|
|
||||||
ARG LIBNVIDIA_CONTAINER_TOOLS_VERSION
|
|
||||||
ENV LIBNVIDIA_CONTAINER_TOOLS_VERSION ${LIBNVIDIA_CONTAINER_TOOLS_VERSION}
|
|
||||||
|
|
||||||
CMD arch=$(uname -m) && \
|
|
||||||
rpmbuild --clean --target=$arch -bb \
|
|
||||||
-D "_topdir $PWD" \
|
|
||||||
-D "release_date $(date +'%a %b %d %Y')" \
|
|
||||||
-D "git_commit ${GIT_COMMIT}" \
|
|
||||||
-D "version $VERSION" \
|
|
||||||
-D "libnvidia_container_tools_version ${LIBNVIDIA_CONTAINER_TOOLS_VERSION}" \
|
|
||||||
-D "release $RELEASE" \
|
|
||||||
SPECS/nvidia-container-toolkit.spec && \
|
|
||||||
mv RPMS/$arch/*.rpm /dist
|
|
@ -1,3 +1,19 @@
|
|||||||
|
# Copyright (c) 2022, NVIDIA CORPORATION. All rights reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
|
||||||
|
# This is the dockerfile for building packages on yum-based RPM systems.
|
||||||
|
|
||||||
ARG BASEIMAGE
|
ARG BASEIMAGE
|
||||||
FROM ${BASEIMAGE}
|
FROM ${BASEIMAGE}
|
||||||
|
|
@ -14,10 +14,10 @@
|
|||||||
|
|
||||||
# Supported OSs by architecture
|
# Supported OSs by architecture
|
||||||
AMD64_TARGETS := ubuntu20.04 ubuntu18.04 ubuntu16.04 debian10 debian9
|
AMD64_TARGETS := ubuntu20.04 ubuntu18.04 ubuntu16.04 debian10 debian9
|
||||||
X86_64_TARGETS := centos7 centos8 rhel7 rhel8 amazonlinux2 opensuse-leap15.1
|
X86_64_TARGETS := fedora35 centos7 centos8 rhel7 rhel8 amazonlinux2 opensuse-leap15.1
|
||||||
PPC64LE_TARGETS := ubuntu18.04 ubuntu16.04 centos7 centos8 rhel7 rhel8
|
PPC64LE_TARGETS := ubuntu18.04 ubuntu16.04 centos7 centos8 rhel7 rhel8
|
||||||
ARM64_TARGETS := ubuntu20.04 ubuntu18.04
|
ARM64_TARGETS := ubuntu20.04 ubuntu18.04
|
||||||
AARCH64_TARGETS := centos8 rhel8 amazonlinux2
|
AARCH64_TARGETS := fedora35 centos8 rhel8 amazonlinux2
|
||||||
|
|
||||||
# Define top-level build targets
|
# Define top-level build targets
|
||||||
docker%: SHELL:=/bin/bash
|
docker%: SHELL:=/bin/bash
|
||||||
@ -104,12 +104,26 @@ LIBNVIDIA_CONTAINER_TAG ?= $(LIB_TAG)
|
|||||||
--centos%: OS := centos
|
--centos%: OS := centos
|
||||||
--centos%: PKG_REV := $(if $(LIB_TAG),0.1.$(LIB_TAG),1)
|
--centos%: PKG_REV := $(if $(LIB_TAG),0.1.$(LIB_TAG),1)
|
||||||
--centos%: LIBNVIDIA_CONTAINER_TOOLS_VERSION := $(LIBNVIDIA_CONTAINER_VERSION)-$(if $(LIBNVIDIA_CONTAINER_TAG),0.1.$(LIBNVIDIA_CONTAINER_TAG),1)
|
--centos%: LIBNVIDIA_CONTAINER_TOOLS_VERSION := $(LIBNVIDIA_CONTAINER_VERSION)-$(if $(LIBNVIDIA_CONTAINER_TAG),0.1.$(LIBNVIDIA_CONTAINER_TAG),1)
|
||||||
|
--centos%: DOCKERFILE = $(CURDIR)/docker/Dockerfile.rpm-yum
|
||||||
|
--centos%: CONFIG_TOML_SUFFIX := rpm-yum
|
||||||
--centos8%: BASEIMAGE = quay.io/centos/centos:stream8
|
--centos8%: BASEIMAGE = quay.io/centos/centos:stream8
|
||||||
|
|
||||||
|
# private fedora target
|
||||||
|
--fedora%: OS := fedora
|
||||||
|
--fedora%: PKG_REV := $(if $(LIB_TAG),0.1.$(LIB_TAG),1)
|
||||||
|
--fedora%: LIBNVIDIA_CONTAINER_TOOLS_VERSION := $(LIBNVIDIA_CONTAINER_VERSION)-$(if $(LIBNVIDIA_CONTAINER_TAG),0.1.$(LIBNVIDIA_CONTAINER_TAG),1)
|
||||||
|
--fedora%: DOCKERFILE = $(CURDIR)/docker/Dockerfile.rpm-yum
|
||||||
|
--fedora%: CONFIG_TOML_SUFFIX := rpm-yum
|
||||||
|
# The fedora(35) base image has very slow performance when building aarch64 packages.
|
||||||
|
# Since our primary concern here is glibc versions, we use the older glibc version available in centos8.
|
||||||
|
--fedora35%: BASEIMAGE = quay.io/centos/centos:stream8
|
||||||
|
|
||||||
# private amazonlinux target
|
# private amazonlinux target
|
||||||
--amazonlinux%: OS := amazonlinux
|
--amazonlinux%: OS := amazonlinux
|
||||||
--amazonlinux%: LIBNVIDIA_CONTAINER_TOOLS_VERSION := $(LIBNVIDIA_CONTAINER_VERSION)-$(if $(LIBNVIDIA_CONTAINER_TAG),0.1.$(LIBNVIDIA_CONTAINER_TAG),1)
|
--amazonlinux%: LIBNVIDIA_CONTAINER_TOOLS_VERSION := $(LIBNVIDIA_CONTAINER_VERSION)-$(if $(LIBNVIDIA_CONTAINER_TAG),0.1.$(LIBNVIDIA_CONTAINER_TAG),1)
|
||||||
--amazonlinux%: PKG_REV := $(if $(LIB_TAG),0.1.$(LIB_TAG),1)
|
--amazonlinux%: PKG_REV := $(if $(LIB_TAG),0.1.$(LIB_TAG),1)
|
||||||
|
--amazonlinux%: DOCKERFILE = $(CURDIR)/docker/Dockerfile.rpm-yum
|
||||||
|
--amazonlinux%: CONFIG_TOML_SUFFIX := rpm-yum
|
||||||
|
|
||||||
# private opensuse-leap target
|
# private opensuse-leap target
|
||||||
--opensuse-leap%: OS = opensuse-leap
|
--opensuse-leap%: OS = opensuse-leap
|
||||||
@ -123,8 +137,11 @@ LIBNVIDIA_CONTAINER_TAG ?= $(LIB_TAG)
|
|||||||
--rhel%: PKG_REV := $(if $(LIB_TAG),0.1.$(LIB_TAG),1)
|
--rhel%: PKG_REV := $(if $(LIB_TAG),0.1.$(LIB_TAG),1)
|
||||||
--rhel%: VERSION = $(patsubst rhel%-$(ARCH),%,$(TARGET_PLATFORM))
|
--rhel%: VERSION = $(patsubst rhel%-$(ARCH),%,$(TARGET_PLATFORM))
|
||||||
--rhel%: ARTIFACTS_DIR = $(DIST_DIR)/rhel$(VERSION)/$(ARCH)
|
--rhel%: ARTIFACTS_DIR = $(DIST_DIR)/rhel$(VERSION)/$(ARCH)
|
||||||
|
--rhel%: DOCKERFILE = $(CURDIR)/docker/Dockerfile.rpm-yum
|
||||||
|
--rhel%: CONFIG_TOML_SUFFIX := rpm-yum
|
||||||
--rhel8%: BASEIMAGE = quay.io/centos/centos:stream8
|
--rhel8%: BASEIMAGE = quay.io/centos/centos:stream8
|
||||||
|
|
||||||
|
|
||||||
# We allow the CONFIG_TOML_SUFFIX to be overridden.
|
# We allow the CONFIG_TOML_SUFFIX to be overridden.
|
||||||
CONFIG_TOML_SUFFIX ?= $(OS)
|
CONFIG_TOML_SUFFIX ?= $(OS)
|
||||||
|
|
||||||
|
@ -37,6 +37,8 @@ all=(
|
|||||||
centos8-x86_64
|
centos8-x86_64
|
||||||
debian10-amd64
|
debian10-amd64
|
||||||
debian9-amd64
|
debian9-amd64
|
||||||
|
fedora35-aarch64
|
||||||
|
fedora35-x86_64
|
||||||
opensuse-leap15.1-x86_64
|
opensuse-leap15.1-x86_64
|
||||||
ubuntu16.04-amd64
|
ubuntu16.04-amd64
|
||||||
ubuntu16.04-ppc64le
|
ubuntu16.04-ppc64le
|
||||||
|
@ -148,6 +148,8 @@ all=(
|
|||||||
centos8-x86_64
|
centos8-x86_64
|
||||||
debian10-amd64
|
debian10-amd64
|
||||||
debian9-amd64
|
debian9-amd64
|
||||||
|
fedora35-aarch64
|
||||||
|
fedora35-x86_64
|
||||||
opensuse-leap15.1-x86_64
|
opensuse-leap15.1-x86_64
|
||||||
ubuntu16.04-amd64
|
ubuntu16.04-amd64
|
||||||
ubuntu16.04-ppc64le
|
ubuntu16.04-ppc64le
|
||||||
|
2
third_party/libnvidia-container
vendored
2
third_party/libnvidia-container
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 72a9d90adca6dfb78b7ea8b270f8f5c64c3169e4
|
Subproject commit 5c7ea1d6bfa727e20e4feded4a3d689ab5beb56c
|
@ -24,7 +24,7 @@ NVIDIA_CONTAINER_RUNTIME_VERSION := 3.11.0
|
|||||||
# Specify the expected libnvidia-container0 version for arm64-based ubuntu builds.
|
# Specify the expected libnvidia-container0 version for arm64-based ubuntu builds.
|
||||||
LIBNVIDIA_CONTAINER0_VERSION := 0.10.0+jetpack
|
LIBNVIDIA_CONTAINER0_VERSION := 0.10.0+jetpack
|
||||||
|
|
||||||
CUDA_VERSION := 11.7.0
|
CUDA_VERSION := 11.7.1
|
||||||
GOLANG_VERSION := 1.17.8
|
GOLANG_VERSION := 1.17.8
|
||||||
|
|
||||||
GIT_COMMIT ?= $(shell git describe --dirty --long --always 2> /dev/null || echo "")
|
GIT_COMMIT ?= $(shell git describe --dirty --long --always 2> /dev/null || echo "")
|
||||||
|
Loading…
Reference in New Issue
Block a user