1
0
intel-media-ffmpeg/Dockerfile.rhel-8.0
James Ketrenos 82aba14ec6 Red Hat images can now be built and pushed. See README.md
Signed-off-by: James Ketrenos <james.p.ketrenos@intel.com>
2019-11-07 11:59:01 -08:00

300 lines
13 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-everything.in
#
FROM dockerv2-gfx-build.gfx-assets.intel.com/upstream/rhel:8.0.0 AS agama-user
# Configure DNF and YUM proxies
RUN echo "proxy=http://proxy-chain.intel.com:911" >> /etc/dnf/dnf.conf \
&& echo -e 'proxy=http://proxy-chain.intel.com:911\nno_proxy=.intel.com' >> /etc/yum.conf
# 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
# Update package lists, and upgrade to the latest Red Hat packages
RUN dnf clean all \
&& dnf -y upgrade \
&& dnf clean all
# Agama specific 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
# Disable proxy for Intel URLs
RUN echo "no_proxy=.jf.intel.com" >> /etc/yum.conf
#
# 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 (disco) and newer
FROM agama-user AS solution-build
# Install git and build tools, clone ffmpeg, and get ready to build it
RUN dnf groupinstall -y 'Development Tools'
# 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 /ffmpeg
# 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 \
&& dnf clean all
ENV LIBVA_DRIVER_NAME=iHD
# Build FFmpeg
WORKDIR /ffmpeg
RUN ./configure --arch=x86_64 --disable-yasm --enable-vaapi --enable-libmfx \
&& make -j $(nproc --all) \
&& make install
FROM agama-user
ENV LIBVA_DRIVER_NAME=iHD
# Update and install the Mesa, OpenCL, and Media from Agama
#
# NOTE: libva requires libpciaccess0, however it doesn't depend on it
# so explicitly install it.
# intel-media-va-driver-non-free$INTEL_MEDIA_VA_DRIVER_NON_FREE_VERSION \
RUN dnf install -y \
intel-media$INTEL_MEDIA_VERSION \
libva$LIBVA_VERSION \
intel-mediasdk$INTEL_MEDIASDK_VERSION \
libva-utils$LIBVA_UTILS_VERSION \
libpciaccess \
pciutils \
&& dnf clean all
# Copy ffmpeg and ffprobe from build container
COPY --from=solution-build /usr/local/bin/ /usr/local/bin/
#
# 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" ; \
} > /assets/SOLUTION
COPY MANIFEST /assets/
COPY Dockerfile.rhel-8.0 /assets/Dockerfile