commit:     3e594905ea4fce9c4327dee6dbb7db16d23d0814
Author:     Emil Karlson <jekarlson <AT> gmail <DOT> com>
AuthorDate: Wed Mar 26 05:40:49 2014 +0000
Commit:     Emil Karlson <jekarlson <AT> gmail <DOT> com>
CommitDate: Wed Mar 26 05:40:49 2014 +0000
URL:        
http://git.overlays.gentoo.org/gitweb/?p=proj/x11.git;a=commit;h=3e594905

x11-drivers/ati-drivers: beta version bump

---
 ...rs-13.1.ebuild => ati-drivers-14.3_beta.ebuild} | 140 ++++++++++++---------
 1 file changed, 84 insertions(+), 56 deletions(-)

diff --git a/x11-drivers/ati-drivers/ati-drivers-13.1.ebuild 
b/x11-drivers/ati-drivers/ati-drivers-14.3_beta.ebuild
similarity index 82%
rename from x11-drivers/ati-drivers/ati-drivers-13.1.ebuild
rename to x11-drivers/ati-drivers/ati-drivers-14.3_beta.ebuild
index 138e3b0..92b54d9 100644
--- a/x11-drivers/ati-drivers/ati-drivers-13.1.ebuild
+++ b/x11-drivers/ati-drivers/ati-drivers-14.3_beta.ebuild
@@ -4,30 +4,27 @@
 
 EAPI=5
 
-inherit eutils multilib linux-info linux-mod toolchain-funcs versionator
+inherit eutils multilib linux-info linux-mod toolchain-funcs versionator 
pax-utils
 
 DESCRIPTION="Ati precompiled drivers for Radeon Evergreen (HD5000 Series) and 
newer chipsets"
 HOMEPAGE="http://www.amd.com";
-MY_V=( $(get_version_components) )
-#RUN="${WORKDIR}/amd-driver-installer-9.00-x86.x86_64.run"
+RUN="${WORKDIR}/fglrx-13.35.1005/amd-driver-installer-13.35.1005-x86.x86_64.run"
 SLOT="1"
-if [[ legacy != ${SLOT} ]]; then
-       
DRIVERS_URI="http://www2.ati.com/drivers/linux/amd-driver-installer-catalyst-${PV}-linux-x86.x86_64.zip";
-else
-       
DRIVERS_URI="http://www2.ati.com/drivers/legacy/amd-driver-installer-catalyst-$(get_version_component_range
 1-2)-legacy-linux-x86.x86_64.zip"
-fi
+# Uses javascript for download YESSSS
+#DRIVERS_URI="http://www2.ati.com/drivers/linux/amd-catalyst-13.12-linux-x86.x86_64.zip";
+DRIVERS_URI="http://dev.gentooexperimental.org/~scarabeus/Linux_AMD_Catalyst_14.3_Beta_V1.0_B22_March12_2014.zip";
 
XVBA_SDK_URI="http://developer.amd.com/wordpress/media/2012/10/xvba-sdk-0.74-404001.tar.gz";
 SRC_URI="${DRIVERS_URI} ${XVBA_SDK_URI}"
 FOLDER_PREFIX="common/"
-IUSE="debug +modules multilib qt4 static-libs disable-watermark pax_kernel"
+IUSE="debug +modules multilib qt4 static-libs pax_kernel"
 
 LICENSE="AMD GPL-2 QPL-1.0"
 KEYWORDS="-* ~amd64 ~x86"
 
-RESTRICT="bindist test"
+RESTRICT="bindist test fetch"
 
 RDEPEND="
-       <=x11-base/xorg-server-1.13.49[-minimal]
+       <=x11-base/xorg-server-1.15.49[-minimal]
        >=app-admin/eselect-opengl-1.0.7
        app-admin/eselect-opencl
        sys-power/acpid
@@ -40,7 +37,16 @@ RDEPEND="
        virtual/glu
        multilib? (
                        app-emulation/emul-linux-x86-opengl
-                       app-emulation/emul-linux-x86-xlibs
+                       || (
+                               (
+                                       x11-libs/libX11[abi_x86_32]
+                                       x11-libs/libXext[abi_x86_32]
+                                       x11-libs/libXinerama[abi_x86_32]
+                                       x11-libs/libXrandr[abi_x86_32]
+                                       x11-libs/libXrender[abi_x86_32]
+                               )
+                               app-emulation/emul-linux-x86-xlibs
+                       )
        )
        qt4? (
                        x11-libs/libICE
@@ -104,6 +110,8 @@ QA_PRESTRIPPED="
        usr/lib\(32\|64\)\?/libAMDXvBA.so.1.0
        usr/lib\(32\|64\)\?/libaticaldd.so
        usr/lib\(32\|64\)\?/dri/fglrx_dri.so
+       usr/lib\(32\|64\)\?/OpenCL/vendors/amd/libOpenCL.so.1
+       usr/lib\(32\|64\)\?/OpenCL/vendors/amd/libamdocl\(32\|64\).so
 "
 
 QA_SONAME="
@@ -144,33 +152,47 @@ QA_DT_HASH="
        usr/lib\(32\|64\)\?/OpenCL/vendors/amd/libOpenCL.so.1
 "
 
-CONFIG_CHECK="~MTRR ~!DRM ACPI PCI_MSI !LOCKDEP"
-use amd64 && CONFIG_CHECK="${CONFIG_CHECK} COMPAT"
-ERROR_MTRR="CONFIG_MTRR required for direct rendering."
-ERROR_DRM="CONFIG_DRM must be disabled or compiled as a module for direct
-       rendering."
-ERROR_LOCKDEP="CONFIG_LOCKDEP (lock tracking) exports the symbol lock_acquire
-       as GPL-only. This prevents ${P} from compiling with an error like this:
-       FATAL: modpost: GPL-incompatible module fglrx.ko uses GPL-only symbol 
'lock_acquire'"
-
-_check_kernel_config() {
-       if ! linux_chkconfig_present AGP && \
-               ! linux_chkconfig_present PCIEPORTBUS; then
-               ewarn "You don't have AGP and/or PCIe support enabled in the 
kernel"
-               ewarn "Direct rendering will not work."
-       fi
+pkg_nofetch() {
+       einfo "The driver package"
+       einfo "Linux_AMD_Catalyst_14.3_Beta_V1.0_B22_March12_2014.zip"
+       einfo "needs to be downloaded manually from"
+       einfo "http://support.amd.com/en-us/download/desktop?os=Linux%20x86_64";
 
-       kernel_is ge 2 6 37 && kernel_is le 2 6 38 && if ! 
linux_chkconfig_present BKL ; then
-               die "CONFIG_BKL must be enabled for kernels 2.6.37-2.6.38."
-       fi
 }
 
 pkg_pretend() {
+       local CONFIG_CHECK="~MTRR ~!DRM ACPI PCI_MSI !LOCKDEP 
!PAX_KERNEXEC_PLUGIN_METHOD_OR"
+       use amd64 && CONFIG_CHECK+=" COMPAT"
+
+       local ERROR_MTRR="CONFIG_MTRR required for direct rendering."
+       local ERROR_DRM="CONFIG_DRM must be disabled or compiled as a module 
and not loaded for direct
+               rendering to work."
+       local ERROR_LOCKDEP="CONFIG_LOCKDEP (lock tracking) exports the symbol 
lock_acquire
+               as GPL-only. This prevents ${P} from compiling with an error 
like this:
+               FATAL: modpost: GPL-incompatible module fglrx.ko uses GPL-only 
symbol 'lock_acquire'"
+       local ERROR_PAX_KERNEXEC_PLUGIN_METHOD_OR="This config option will cause
+               kernel to reject loading the fglrx module with
+               \"ERROR: could not insert 'fglrx': Exec format error.\"
+               You may want to try CONFIG_PAX_KERNEXEC_PLUGIN_METHOD_BTS 
instead."
+       local ERROR_BKL="CONFIG_BKL must be enabled for kernels 2.6.37-2.6.38."
+
        # workaround until bug 365543 is solved
        if use modules; then
                linux-info_pkg_setup
                require_configured_kernel
-               _check_kernel_config
+               kernel_is ge 2 6 37 && kernel_is le 2 6 38 && CONFIG_CHECK+=" 
BKL"
+               check_extra_config
+               if ! linux_chkconfig_present AGP && \
+                       ! linux_chkconfig_present PCIEPORTBUS; then
+                       ewarn "You don't have AGP and/or PCIe support enabled 
in the kernel"
+                       ewarn "Direct rendering will not work."
+               fi
+       fi
+
+       if ! has XT ${PAX_MARKINGS} && use pax_kernel; then
+               ewarn "You have disabled xattr pax markings for portage."
+               ewarn "This will likely cause programs using ati-drivers 
provided"
+               ewarn "libraries to be killed kernel."
        fi
 }
 
@@ -229,12 +251,16 @@ src_unpack() {
                else
                        RUN="${DISTDIR}/${DRIVERS_DISTFILE}"
                fi
-               sh ${RUN} --extract "${S}" 2>&1 > /dev/null || die
+               sh "${RUN}" --extract "${S}" 2>&1 > /dev/null || die
        fi
 
        mkdir xvba_sdk
        cd xvba_sdk
        unpack ${XVBA_SDK_DISTFILE}
+
+       mkdir -p "${WORKDIR}/extra" || die "mkdir extra failed"
+       cd "${WORKDIR}/extra"
+       tar -xf "../${FOLDER_PREFIX}usr/src/ati/fglrx_sample_source.tgz"
 }
 
 src_prepare() {
@@ -275,16 +301,24 @@ src_prepare() {
        # first hunk applied upstream second (x32 related) was not
        epatch "${FILESDIR}"/ati-drivers-x32_something_something.patch
 
-       # compile fix for linux-3.7
-       # https://bugs.gentoo.org/show_bug.cgi?id=438516
-       epatch "${FILESDIR}/ati-drivers-vm-reserverd.patch"
-
        # compile fix for AGP-less kernel, bug #435322
        epatch 
"${FILESDIR}"/ati-drivers-12.9-KCL_AGP_FindCapsRegisters-stub.patch
 
-       # Use ACPI_DEVICE_HANDLE wrapper to make driver build on linux-3.8
-       # see https://bugs.gentoo.org/show_bug.cgi?id=448216
-       epatch "${FILESDIR}/ati-drivers-kernel-3.8-acpihandle.patch"
+       # Compile fix for kernel typesafe uid types #469160
+       epatch "${FILESDIR}/typesafe-kuid.diff"
+
+       epatch "${FILESDIR}/ati-drivers-13.8-beta-include-seq_file.patch"
+
+       epatch "${FILESDIR}/check-for-iommu-only-if-iommu-is-supported.patch"
+
+       # Fix #483400
+       epatch "${FILESDIR}/fgl_glxgears-do-not-include-glATI.patch"
+
+       # Fix build on new kernels
+       #epatch "${FILESDIR}/ati-drivers-13.12-acpi.patch"
+
+       # Add support for linux-3.13. See #498766
+       #epatch "${FILESDIR}/ati-drivers-linux-3.13-acpi-handle.patch"
 
        # Compile fix, https://bugs.gentoo.org/show_bug.cgi?id=454870
        use pax_kernel && epatch "${FILESDIR}/const-notifier-block.patch"
@@ -304,22 +338,6 @@ src_prepare() {
        sed -i -e 's/__SMP__/CONFIG_SMP/' *.c *h || die "SMP sed failed"
        sed -i -e 's/ifdef MODVERSIONS/ifdef CONFIG_MODVERSIONS/' *.c *.h \
                || die "MODVERSIONS sed failed"
-       cd "${S}"
-
-       mkdir extra || die "mkdir extra failed"
-       cd extra
-       unpack ./../${FOLDER_PREFIX}usr/src/ati/fglrx_sample_source.tgz
-
-       # Get rid of watermark. Oldest known reference:
-       # 
http://phoronix.com/forums/showthread.php?19875-Unsupported-Hardware-watermark
-       if use disable-watermark; then
-               ebegin "Disabling watermark"
-               
driver="${MY_BASE_DIR}"/usr/X11R6/${PKG_LIBDIR}/modules/drivers/fglrx_drv.so
-               for x in $(objdump -d ${driver}|awk '/call/&&/EnableLogo/{print 
"\\x"$2"\\x"$3"\\x"$4"\\x"$5"\\x"$6}'); do
-               sed -i "s/${x/x5b/\x5b}/\x90\x90\x90\x90\x90/g" ${driver} || 
break 1
-               done
-               eend $? || die "Disabling watermark failed"
-       fi
 }
 
 src_compile() {
@@ -412,7 +430,7 @@ src_install() {
        insinto /etc/ati
        exeinto /etc/ati
        # Everything except for the authatieventsd.sh script.
-       doins 
${FOLDER_PREFIX}etc/ati/{logo*,control,atiogl.xml,signature,amdpcsdb.default}
+       doins ${FOLDER_PREFIX}etc/ati/{logo*,control,signature,amdpcsdb.default}
        doexe ${FOLDER_PREFIX}etc/ati/authatieventsd.sh
 
        # include.
@@ -549,6 +567,10 @@ src_install-libs() {
 
        #install xvba sdk headers
        doheader xvba_sdk/include/amdxvba.h
+
+       if use pax_kernel; then
+               pax-mark m "${D}"/usr/lib*/opengl/ati/lib/libGL.so.1.2 || die 
"pax-mark failed"
+       fi
 }
 
 pkg_postinst() {
@@ -578,6 +600,12 @@ pkg_postinst() {
                ewarn "try disabling sna for xf86-video-intel."
                ewarn "For details, see 
https://bugs.gentoo.org/show_bug.cgi?id=430000";
        fi
+
+       if use pax_kernel; then
+               ewarn "Please run \"revdep-pax -s libGL.so.1 -me\" after 
installation and"
+               ewarn "after you have run \"eselect opengl set ati\". 
Executacle"
+               ewarn "revdep-pax is part of package sys-apps/elfix."
+       fi
 }
 
 pkg_preinst() {

Reply via email to