364 lines
14 KiB
Docker
364 lines
14 KiB
Docker
#
|
|
# DO NOT EDIT THIS DOCKERFILE
|
|
#
|
|
# This file is auto-generated via scripts/build-dockerfile
|
|
# by using environment substitution while concatenating the
|
|
# contents of templates/*, and then adding the contents
|
|
# of Dockerfile.solution.rhel-8.0
|
|
#
|
|
# Most solution specific changes should be isolated in
|
|
# Dockerfile.solution.rhel-8.0. After making changes, you can then re-run
|
|
# scripts/build-dockerfile
|
|
#
|
|
|
|
#
|
|
# Template from templates/rhel/00-from.in
|
|
#
|
|
# Pull internal RHEL image
|
|
FROM dockerv2-gfx-build.gfx-assets.intel.com/upstream/rhel:8.0.0 AS xe-base-stage
|
|
|
|
# Flush cached package lists to prevent stale data
|
|
RUN dnf clean all
|
|
|
|
|
|
#
|
|
# Template from templates/rhel/05-intel-proxy.in
|
|
#
|
|
# Configure Intel proxy values
|
|
|
|
ARG http_proxy="http://proxy-chain.intel.com:911/"
|
|
ARG https_proxy="http://proxy-chain.intel.com:912/"
|
|
ARG ftp_proxy="ftp://proxy-chain.intel.com:911/"
|
|
ARG socks_proxy="socks://proxy-chain.intel.com:1080/"
|
|
ARG no_proxy="localhost,*.*.intel.com"
|
|
|
|
ENV http_proxy="${http_proxy}"
|
|
ENV https_proxy="${https_proxy}"
|
|
ENV no_proxy="${no_proxy}"
|
|
ENV ftp_proxy="${http_proxy}"
|
|
ENV socks_proxy="${socks_proxy}"
|
|
|
|
ENV HTTP_PROXY="${http_proxy}"
|
|
ENV HTTPS_PROXY="${http_proxy}"
|
|
ENV NO_PROXY="${no_proxy}"
|
|
|
|
# Configure DNF and YUM proxies
|
|
RUN { \
|
|
echo "proxy=${http_proxy}" ; \
|
|
echo "no_proxy=${no_proxy}" ; \
|
|
} | tee -a /etc/dnf/dnf.conf /etc/yum.conf
|
|
|
|
|
|
#
|
|
# Template from templates/rhel/10-rhel-partner.in
|
|
#
|
|
|
|
# Remove any pre-configured repositories
|
|
RUN rm -rf /etc/yum.repos.d/*
|
|
|
|
# Install the Red Hat partner repositories
|
|
RUN { \
|
|
echo "[RHEL-8-appstream-partners]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (AppStream) - x86_64" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/AppStream/x86_64/os" ; \
|
|
echo "enabled=1" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-appstream-partners-debug]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (AppStream) - x86_64 - Debug" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/AppStream/x86_64/debug/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-appstream-partners-source]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (AppStream) - Source" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/AppStream/source/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
} > /etc/yum.repos.d/RHEL-8-appstream-intel-partner.repo
|
|
RUN { \
|
|
echo "[RHEL-8-baseos-partners]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (BaseOS) - x86_64" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/BaseOS/x86_64/os" ; \
|
|
echo "enabled=1" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-baseos-partners-debug]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (BaseOS) - x86_64 - Debug" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/BaseOS/x86_64/debug/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-baseos-partners-source]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (BaseOS) - Source" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/BaseOS/source/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
} > /etc/yum.repos.d/RHEL-8-baseos-intel-partner.repo
|
|
RUN { \
|
|
echo "[RHEL-8-crb-partners]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (CRB) - x86_64" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/CRB/x86_64/os" ; \
|
|
echo "enabled=1" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-crb-partners-debug]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (CRB) - x86_64 - Debug" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/CRB/x86_64/debug/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-crb-partners-source]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (CRB) - Source" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/CRB/source/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
} > /etc/yum.repos.d/RHEL-8-crb-intel-partner.repo
|
|
RUN { \
|
|
echo "[RHEL-8-highavailability-partners]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (HighAvailability) - x86_64" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/HighAvailability/x86_64/os" ; \
|
|
echo "enabled=1" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-highavailability-partners-debug]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (HighAvailability) - x86_64 - Debug" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/HighAvailability/x86_64/debug/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-highavailability-partners-source]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (HighAvailability) - Source" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/HighAvailability/source/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
} > /etc/yum.repos.d/RHEL-8-highavailability-intel-partner.repo
|
|
RUN { \
|
|
echo "[RHEL-8-resilientstorage-partners]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (ResilientStorage) - x86_64" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/ResilientStorage/x86_64/os" ; \
|
|
echo "enabled=1" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-resilientstorage-partners-debug]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (ResilientStorage) - x86_64 - Debug" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/ResilientStorage/x86_64/debug/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-resilientstorage-partners-source]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (ResilientStorage) - Source" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/ResilientStorage/source/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
} > /etc/yum.repos.d/RHEL-8-resilientstorage-intel-partner.repo
|
|
RUN { \
|
|
echo "[RHEL-8-rt-partners]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (RT) - x86_64" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/RT/x86_64/os" ; \
|
|
echo "enabled=1" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-rt-partners-debug]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (RT) - x86_64 - Debug" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/RT/x86_64/debug/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
echo "[RHEL-8-rt-partners-source]" ; \
|
|
echo "name=Red Hat Enterprise Linux 8.0.0 Partners (RT) - Source" ; \
|
|
echo "baseurl=ftp://partners.redhat.com/1c5d859a/91fe32f09e2de2cc3eb0f86526b4c7ca/RHEL-8.0.0-GA/RT/source/tree" ; \
|
|
echo "enabled=0" ; \
|
|
echo "gpgcheck=1" ; \
|
|
echo "gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release,file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-beta" ; \
|
|
echo "skip_if_unavailable=1" ; \
|
|
echo "" ; \
|
|
} > /etc/yum.repos.d/RHEL-8-rt-intel-partner.repo
|
|
|
|
#
|
|
# Template from templates/rhel/20-repositories-intel-com.in
|
|
#
|
|
# repositories.intel.com content begins here
|
|
#
|
|
# Intel certificates which would allow internal signed certs to be
|
|
# used are not being installed, so turn sslverify=0 on the
|
|
# repository.
|
|
#
|
|
# To install the certs would be something like:
|
|
#
|
|
# A. Copy ca certs to /etc/pki/ca-trust/source/anchors/
|
|
# B. run update-ca-trust
|
|
#
|
|
# Once that is done, the 'sslverify=0' can be removed from
|
|
# the repository definition below.
|
|
#
|
|
# Add Intel Graphics repository
|
|
#
|
|
RUN { \
|
|
echo "[intel-graphics]" ; \
|
|
echo "name=Intel Graphics Drivers Repository" ; \
|
|
echo "baseurl=https://repositories.intel.com/graphics/rhel/8.0/" ; \
|
|
echo "sslverify=0" ; \
|
|
echo "enabled=1" ; \
|
|
echo "gpgcheck=0" ; \
|
|
} > /etc/yum.repos.d/intel-graphics.repo
|
|
|
|
#
|
|
# Template from templates/rhel/25-graphics-user.in
|
|
#
|
|
# Create user 'user' and add them to 'sudo' for sudo access and set
|
|
# the passwd to 'user'
|
|
|
|
FROM xe-base-stage AS xe-user-stage
|
|
|
|
RUN dnf install -y sudo
|
|
|
|
# NOTE: Requires 'sudo' package to already be installed
|
|
RUN groupadd -r user \
|
|
&& useradd --no-log-init \
|
|
-s /bin/bash \
|
|
-r -m \
|
|
-g user \
|
|
-G sudo \
|
|
-p $(echo "user" | openssl passwd -stdin) user
|
|
|
|
# Set 'sudo' to NOPASSWD for all container users
|
|
RUN sed -i -e 's,%sudo.*,%sudo ALL=(ALL) NOPASSWD:ALL,g' /etc/sudoers
|
|
|
|
USER user
|
|
|
|
#
|
|
# Template from templates/rhel/30-clean-up.in
|
|
#
|
|
# Clean dnf cache
|
|
RUN dnf clean all
|
|
|
|
#
|
|
# Solution begins here (from Dockerfile.solution.rhel-8.0)
|
|
#
|
|
# Docker.solution based on the Intel-Media-SDK instructions available here:
|
|
#
|
|
# https://github.com/Intel-Media-SDK/MediaSDK/wiki/Build-and-use-ffmpeg-with-MediaSDK
|
|
#
|
|
# This should really be part of a multi-stage build so the final
|
|
# image isn't polluted with build artifacts
|
|
#
|
|
# NOTE: This image will only work with Ubuntu 19.04 (eoan) and newer
|
|
FROM xe-user-stage AS solution-build
|
|
|
|
USER root
|
|
|
|
# Install git and build tools, clone ffmpeg, and get ready to build it
|
|
RUN dnf groupinstall -y 'Development Tools'
|
|
|
|
# Install all required common packages:
|
|
# Adapted from
|
|
RUN dnf install -y \
|
|
libva-devel$LIBVA_DEV_VERSION \
|
|
intel-mediasdk-devel$INTEL_MEDIASDK_DEVEL_VERSION \
|
|
libva-utils$LIBVA_UTILS_VERSION
|
|
|
|
USER user
|
|
|
|
# Clone ffmpeg
|
|
# NOTE: This explicitly clones the FFMPEG_TAG_VERSION (see SOLUTIONS)
|
|
RUN git clone --depth 1 --branch n4.2.1 https://github.com/ffmpeg/ffmpeg /home/user/ffmpeg
|
|
|
|
# Build FFmpeg
|
|
WORKDIR /home/user/ffmpeg
|
|
|
|
ENV LIBVA_DRIVER_NAME=iHD
|
|
|
|
RUN ./configure --arch=x86_64 --disable-yasm --enable-vaapi --enable-libmfx \
|
|
&& make -j $(nproc --all) \
|
|
&& sudo make install
|
|
|
|
FROM xe-user-stage
|
|
|
|
USER root
|
|
|
|
# Update and install the Mesa, OpenCL, and Media from repositories.intel.com
|
|
#
|
|
# NOTE: libva requires libpciaccess0, however it doesn't depend on it
|
|
# so explicitly install it.
|
|
RUN dnf install -y \
|
|
intel-media$INTEL_MEDIA_VERSION \
|
|
libva$LIBVA_VERSION \
|
|
intel-mediasdk$INTEL_MEDIASDK_VERSION \
|
|
libva-utils$LIBVA_UTILS_VERSION \
|
|
libpciaccess \
|
|
pciutils
|
|
|
|
# Copy ffmpeg and ffprobe from build container
|
|
COPY --from=solution-build /usr/local/bin/ /usr/local/bin/
|
|
|
|
RUN dnf clean all
|
|
|
|
ENV LIBVA_DRIVER_NAME=iHD
|
|
|
|
USER user
|
|
|
|
#
|
|
# Standard ending begins here (from templates/ending.in)
|
|
#
|
|
# NOTE: This should be added as the last template entry
|
|
# as it will always modify a layer (since the Dockerfile
|
|
# changes,) causing all subsequent layers to be
|
|
# regenerated.
|
|
|
|
# Copy boiler plate entry point
|
|
COPY assets/ /assets/
|
|
ENTRYPOINT [ "/assets/entry" ]
|
|
|
|
# Ensure that each Docker container self-documents the
|
|
# versions included in it
|
|
|
|
RUN { \
|
|
echo "PACKAGE_REPOSITORY=https://repositories.intel.com/graphics" ; \
|
|
echo "RELEASE_INFO=N/A" ; \
|
|
echo "PACKAGE_STREAM=8.0" ; \
|
|
echo "OS_DISTRO=rhel" ; \
|
|
echo "OS_RELEASE=8.0" ; \
|
|
} | sudo tee /assets/SOLUTION
|
|
COPY MANIFEST /assets/
|
|
COPY Dockerfile.rhel-8.0 /assets/Dockerfile
|