summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--x11-drivers/ati-drivers/ChangeLog7
-rw-r--r--x11-drivers/ati-drivers/ati-drivers-9.6.ebuild196
-rw-r--r--x11-drivers/ati-drivers/metadata.xml3
3 files changed, 110 insertions, 96 deletions
diff --git a/x11-drivers/ati-drivers/ChangeLog b/x11-drivers/ati-drivers/ChangeLog
index a4f133b3ebe4..b74b661ac0bb 100644
--- a/x11-drivers/ati-drivers/ChangeLog
+++ b/x11-drivers/ati-drivers/ChangeLog
@@ -1,6 +1,11 @@
# ChangeLog for x11-drivers/ati-drivers
# Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/x11-drivers/ati-drivers/ChangeLog,v 1.165 2009/07/06 11:12:47 scarabeus Exp $
+# $Header: /var/cvsroot/gentoo-x86/x11-drivers/ati-drivers/ChangeLog,v 1.166 2009/07/15 09:54:12 scarabeus Exp $
+
+ 15 Jul 2009; Tomáš Chvátal <scarabeus@gentoo.org>
+ ati-drivers-9.6.ebuild, metadata.xml:
+ Make modules build optional, per bug #276893. Add die where mandatory.
+ Cleanup deps.
06 Jul 2009; Tomáš Chvátal <scarabeus@gentoo.org>
ati-drivers-9.6.ebuild:
diff --git a/x11-drivers/ati-drivers/ati-drivers-9.6.ebuild b/x11-drivers/ati-drivers/ati-drivers-9.6.ebuild
index af5a6250c2eb..4033d279e038 100644
--- a/x11-drivers/ati-drivers/ati-drivers-9.6.ebuild
+++ b/x11-drivers/ati-drivers/ati-drivers-9.6.ebuild
@@ -1,10 +1,8 @@
# Copyright 1999-2009 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/x11-drivers/ati-drivers/ati-drivers-9.6.ebuild,v 1.9 2009/07/06 11:12:47 scarabeus Exp $
+# $Header: /var/cvsroot/gentoo-x86/x11-drivers/ati-drivers/ati-drivers-9.6.ebuild,v 1.10 2009/07/15 09:54:12 scarabeus Exp $
-EAPI="1"
-
-IUSE="acpi debug"
+EAPI="2"
inherit eutils multilib linux-mod toolchain-funcs versionator
@@ -12,6 +10,8 @@ DESCRIPTION="Ati precompiled drivers for r600 (HD Series) and newer chipsets"
HOMEPAGE="http://www.ati.com"
ATI_URL="https://a248.e.akamai.net/f/674/9206/0/www2.ati.com/drivers/linux/"
SRC_URI="${ATI_URL}/ati-driver-installer-${PV/./-}-x86.x86_64.run"
+IUSE="acpi debug +modules"
+
LICENSE="AMD GPL-2 QPL-1.0 as-is"
KEYWORDS="~amd64 ~x86"
@@ -21,11 +21,9 @@ RDEPEND="
!x11-drivers/ati-drivers:0
!x11-apps/ati-drivers-extra
>=app-admin/eselect-opengl-1.0.7
- sys-libs/libstdc++-v3
>=x11-base/xorg-server-1.5.3-r7
x11-libs/libXinerama
x11-libs/libXrandr
- amd64? ( app-emulation/emul-linux-x86-xlibs )
acpi? (
sys-power/acpid
x11-apps/xauth
@@ -43,30 +41,7 @@ EMULTILIB_PKG="true"
S="${WORKDIR}"
-pkg_setup() {
- # Define module dir.
- MODULE_DIR="${S}/common/lib/modules/fglrx/build_mod"
-
- # check kernel and sets up KV_OBJ
- MODULE_NAMES="fglrx(video:${S}/common/lib/modules/fglrx/build_mod/2.6.x)"
- BUILD_TARGETS="kmod_build"
- linux-mod_pkg_setup
- BUILD_PARAMS="GCC_VER_MAJ=$(gcc-major-version) KVER=${KV_FULL} KDIR=${KV_DIR}"
-
- # xorg folder
- BASE_DIR="${S}/x740"
-
- # amd64/x86
- if use amd64 ; then
- MY_BASE_DIR="${BASE_DIR}_64a"
- PKG_LIBDIR=lib64
- ARCH_DIR="${S}/arch/x86_64"
- else
- MY_BASE_DIR="${BASE_DIR}"
- PKG_LIBDIR=lib
- ARCH_DIR="${S}/arch/x86"
- fi
-
+_check_kernel_config() {
if ! kernel_is 2 6; then
eerror "You need a 2.6 linux kernel to compile against!"
die "No 2.6 Kernel found"
@@ -137,8 +112,15 @@ pkg_setup() {
eerror "in the kernel config."
die "CONFIG_PCI_MSI disabled"
fi
+}
+
+pkg_setup() {
+ # Define module dir.
+ MODULE_DIR="${S}/common/lib/modules/fglrx/build_mod"
+ # xorg folder
+ BASE_DIR="${S}/x740"
- # This is used like $(get_libdir) for paths in ati's package.
+ # amd64/x86
if use amd64 ; then
MY_BASE_DIR="${BASE_DIR}_64a"
PKG_LIBDIR=lib64
@@ -149,6 +131,14 @@ pkg_setup() {
ARCH_DIR="${S}/arch/x86"
fi
+ if use modules; then
+ MODULE_NAMES="fglrx(video:${S}/common/lib/modules/fglrx/build_mod/2.6.x)"
+ BUILD_TARGETS="kmod_build"
+ BUILD_PARAMS="GCC_VER_MAJ=$(gcc-major-version) KVER=${KV_FULL} KDIR=${KV_DIR}"
+ linux-mod_pkg_setup
+ _check_kernel_config
+ fi
+
elog
elog "Please note that this driver supports only graphic cards based on"
elog "r600 chipset and newer."
@@ -157,22 +147,34 @@ pkg_setup() {
elog "If your card is older then usage of ${CATEGORY}/xf86-video-ati"
elog "as replacement is highly recommended. Rather than staying with"
elog "old versions of this driver."
+ elog "For migration informations please reffer to:"
+ elog "http://www.gentoo.org/proj/en/desktop/x/x11/ati-migration-guide.xml"
einfo
}
src_unpack() {
- #Switching to a standard way to extract the files since otherwise no signature file
- #would be created
+ # Switching to a standard way to extract the files since otherwise no signature file
+ # would be created
local src="${DISTDIR}/${A}"
sh "${src}" --extract "${S}" 2&>1 /dev/null
- cd "${S}"
- epatch "${FILESDIR}"/ati-drivers-xen.patch || die "epatch failed"
+}
- if kernel_is ge 2 6 29; then
- epatch "${FILESDIR}"/kernel/2.6.29*.patch
- fi
- if kernel_is ge 2 6 30; then
- epatch "${FILESDIR}"/kernel/2.6.30*.patch
+src_prepare() {
+ epatch "${FILESDIR}"/ati-drivers-xen.patch
+
+ # All kernel options for prepare are ment to be in here
+ if use modules; then
+ if kernel_is ge 2 6 29; then
+ epatch "${FILESDIR}"/kernel/2.6.29*.patch
+ fi
+ if kernel_is ge 2 6 30; then
+ epatch "${FILESDIR}"/kernel/2.6.30*.patch
+ fi
+ if use debug; then
+ sed -i '/^#define DRM_DEBUG_CODE/s/0/1/' \
+ "${MODULE_DIR}/firegl_public.c" \
+ || die "Failed to enable debug output."
+ fi
fi
# These are the userspace utilities that we also have source for.
@@ -182,13 +184,6 @@ src_unpack() {
"${ARCH_DIR}"/usr/X11R6/${PKG_LIBDIR}/libfglrx_gamma* \
|| die "bin rm failed"
- if use debug; then
- # Enable debug mode in the Source Code.
- sed -i '/^#define DRM_DEBUG_CODE/s/0/1/' \
- "${MODULE_DIR}/firegl_public.c" \
- || die "Failed to enable debug output."
- fi
-
if use acpi; then
sed -i \
-e "s:/var/lib/xdm/authdir/authfiles/:/var/run/xauth/:" \
@@ -205,7 +200,7 @@ src_unpack() {
epatch "${FILESDIR}"/ati-powermode-opt-path-2.patch || die "Failed to epatch powermode-opt-path-2.patch"
fi
- pushd ${MODULE_DIR} >/dev/null
+ cd "${MODULE_DIR}"
ln -s "${ARCH_DIR}"/lib/modules/fglrx/build_mod/libfglrx_ip.a.GCC$(gcc-major-version) \
|| die "symlinking precompiled core failed"
@@ -219,7 +214,7 @@ src_unpack() {
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"
- popd >/dev/null
+ cd "${S}"
mkdir extra || die "mkdir failed"
cd extra
@@ -231,9 +226,9 @@ src_unpack() {
}
src_compile() {
- linux-mod_src_compile
+ use modules && linux-mod_src_compile
- einfo "Building fgl_glxgears"
+ ebegin "Building fgl_glxgears"
cd "${S}"/extra/fgl_glxgears
# These extra libs/utils either have an Imakefile that does not
# work very well without tweaking or a Makefile ignoring CFLAGS
@@ -244,26 +239,29 @@ src_compile() {
"$(tc-getCC)" -o fgl_glxgears ${CFLAGS} ${LDFLAGS} -DUSE_GLU \
-I"${S}"/common/usr/include fgl_glxgears.c \
-lGL -lGLU -lX11 -lm || die "fgl_glxgears build failed"
+ eend $?
- einfo "Building fglrx_gamma lib"
+ ebegin "Building fglrx_gamma lib"
cd "${S}"/extra/lib/fglrx_gamma
"$(tc-getCC)" -shared -fpic -o libfglrx_gamma.so.1.0 ${CFLAGS} ${LDFLAGS} \
-DXF86MISC -Wl,-soname,libfglrx_gamma.so.1.0 fglrx_gamma.c \
-lXext || die "fglrx_gamma lib build failed"
ln -s libfglrx_gamma.so.1.0 libfglrx_gamma.so || die "ln failed"
ln -s libfglrx_gamma.so.1.0 libfglrx_gamma.so.1 || die "ln failed"
+ eend $?
- einfo "Building fglrx_gamma util"
+ ebegin "Building fglrx_gamma util"
cd "${S}"/extra/programs/fglrx_gamma
"$(tc-getCC)" -o fglrx_xgamma ${CFLAGS} ${LDFLAGS} \
-I../../../common/usr/X11R6/include -L../../lib/fglrx_gamma \
fglrx_xgamma.c -lm -lfglrx_gamma -lX11 \
|| die "fglrx_gamma util build failed"
+ eend $?
}
src_install() {
- linux-mod_src_install
+ use modules && linux-mod_src_install
# We can do two things here, and neither of them is very nice.
@@ -290,7 +288,7 @@ src_install() {
# below.
echo "COLON_SEPARATED=LIBGL_DRIVERS_PATH" > "${T}/03ati-colon-sep"
- doenvd "${T}/03ati-colon-sep"
+ doenvd "${T}/03ati-colon-sep" || die
# All libraries that we have a 32 bit and 64 bit version of on
# amd64 are installed in src_install-libs. Everything else
@@ -316,20 +314,20 @@ src_install() {
# X modules.
exeinto /usr/$(get_libdir)/xorg/modules/drivers
- doexe "${MY_BASE_DIR}"/usr/X11R6/${PKG_LIBDIR}/modules/drivers/fglrx_drv.so
+ doexe "${MY_BASE_DIR}"/usr/X11R6/${PKG_LIBDIR}/modules/drivers/fglrx_drv.so || die
exeinto /usr/$(get_libdir)/xorg/modules/linux
- doexe "${MY_BASE_DIR}"/usr/X11R6/${PKG_LIBDIR}/modules/linux/libfglrxdrm.so
+ doexe "${MY_BASE_DIR}"/usr/X11R6/${PKG_LIBDIR}/modules/linux/libfglrxdrm.so || die
exeinto /usr/$(get_libdir)/xorg/modules
- doexe "${MY_BASE_DIR}"/usr/X11R6/${PKG_LIBDIR}/modules/{esut.a,glesx.so,amdxmm.so}
+ doexe "${MY_BASE_DIR}"/usr/X11R6/${PKG_LIBDIR}/modules/{esut.a,glesx.so,amdxmm.so} || die
# Arch-specific files.
# (s)bin.
into /opt
if use acpi; then
- dosbin "${ARCH_DIR}"/usr/sbin/atieventsd
+ dosbin "${ARCH_DIR}"/usr/sbin/atieventsd || die
fi
# We cleaned out the compilable stuff in src_unpack
- dobin "${ARCH_DIR}"/usr/X11R6/bin/*
+ dobin "${ARCH_DIR}"/usr/X11R6/bin/* || die
# lib.
exeinto /usr/$(get_libdir)
@@ -347,60 +345,60 @@ src_install() {
doins common/etc/ati/{logo*,control,atiogl.xml,signature,amdpcsdb.default}
if use acpi; then
insopts -m0755
- doins common/etc/ati/authatieventsd.sh
+ doins common/etc/ati/authatieventsd.sh || die
fi
# include.
insinto /usr
- doins -r common/usr/include
+ doins -r common/usr/include || die
insinto /usr/include/X11/extensions
- doins common/usr/X11R6/include/X11/extensions/fglrx_gamma.h
+ doins common/usr/X11R6/include/X11/extensions/fglrx_gamma.h || die
# Just the atigetsysteminfo.sh script.
into /usr
- dosbin common/usr/sbin/*
+ dosbin common/usr/sbin/* || die
# data files for the control panel.
insinto /usr/share
- doins -r common/usr/share/ati
+ doins -r common/usr/share/ati || die
insinto /usr/share/pixmaps
- doins common/usr/share/icons/ccc_{large,small}.xpm
+ doins common/usr/share/icons/ccc_{large,small}.xpm || die
make_desktop_entry amdcccle 'ATI Catalyst Control Center' \
ccc_large System
# doc.
- dohtml -r common/usr/share/doc/fglrx
+ dohtml -r common/usr/share/doc/fglrx || die
if use acpi; then
- doman common/usr/share/man/man8/atieventsd.8
+ doman common/usr/share/man/man8/atieventsd.8 || die
- pushd common/usr/share/doc/fglrx/examples/etc/acpi >/dev/null
+ pushd common/usr/share/doc/fglrx/examples/etc/acpi > /dev/null
exeinto /etc/acpi
- doexe ati-powermode.sh
+ doexe ati-powermode.sh || die
insinto /etc/acpi/events
- doins events/*
+ doins events/* || die
- popd >/dev/null
+ popd > /dev/null
fi
# Done with the "source" tree. Install tools we rebuilt:
- dobin extra/fgl_glxgears/fgl_glxgears
- newdoc extra/fgl_glxgears/README README.fgl_glxgears
+ dobin extra/fgl_glxgears/fgl_glxgears || die
+ newdoc extra/fgl_glxgears/README README.fgl_glxgears || die
- dolib extra/lib/fglrx_gamma/*so*
- newdoc extra/lib/fglrx_gamma/README README.libfglrx_gamma
+ dolib extra/lib/fglrx_gamma/*so* || die
+ newdoc extra/lib/fglrx_gamma/README README.libfglrx_gamma || die
- dobin extra/programs/fglrx_gamma/fglrx_xgamma
- doman extra/programs/fglrx_gamma/fglrx_xgamma.1
- newdoc extra/programs/fglrx_gamma/README README.fglrx_gamma
+ dobin extra/programs/fglrx_gamma/fglrx_xgamma || die
+ doman extra/programs/fglrx_gamma/fglrx_xgamma.1 || die
+ newdoc extra/programs/fglrx_gamma/README README.fglrx_gamma || die
# Gentoo-specific stuff:
if use acpi; then
newinitd "${FILESDIR}"/atieventsd.init atieventsd \
|| die "Failed to install atieventsd.init.d"
echo 'ATIEVENTSDOPTS=""' > "${T}"/atieventsd.conf
- newconfd "${T}"/atieventsd.conf atieventsd
+ newconfd "${T}"/atieventsd.conf atieventsd || die
fi
}
@@ -424,21 +422,30 @@ src_install-libs() {
# The GLX libraries
# (yes, this really is "lib" even on amd64/multilib --marienz)
exeinto ${ATI_ROOT}/lib
- doexe "${MY_ARCH_DIR}"/usr/X11R6/${pkglibdir}/libGL.so.${libver}
- dosym libGL.so.${libver} ${ATI_ROOT}/lib/libGL.so.${libmajor}
- dosym libGL.so.${libver} ${ATI_ROOT}/lib/libGL.so
+ doexe "${MY_ARCH_DIR}"/usr/X11R6/${pkglibdir}/libGL.so.${libver} || die
+ dosym libGL.so.${libver} ${ATI_ROOT}/lib/libGL.so.${libmajor} || die
+ dosym libGL.so.${libver} ${ATI_ROOT}/lib/libGL.so || die
exeinto ${ATI_ROOT}/extensions
- doexe "${EX_BASE_DIR}"/usr/X11R6/${pkglibdir}/modules/extensions/*
+ doexe "${EX_BASE_DIR}"/usr/X11R6/${pkglibdir}/modules/extensions/* || die
# DRI modules, installed into the path used by recent versions of mesa.
exeinto /usr/$(get_libdir)/dri
- doexe "${MY_ARCH_DIR}"/usr/X11R6/${pkglibdir}/modules/dri/fglrx_dri.so
+ doexe "${MY_ARCH_DIR}"/usr/X11R6/${pkglibdir}/modules/dri/fglrx_dri.so || die
# AMD Cal libraries
exeinto /usr/$(get_libdir)
- doexe "${MY_ARCH_DIR}"/usr/${pkglibdir}/*.so
-
+ doexe "${MY_ARCH_DIR}"/usr/${pkglibdir}/*.so || die
+
+ # warn about removal of .la file
+ # WILL BE NEEDED IN FUTURE
+ #if [[ -e ${ATI_ROOT}/lib/libGL.la ]]; then
+ # ewarn "Since this version the libGL.la is not installed"
+ # ewarn "For fixing this issues please take look on:"
+ # ewarn " dev-util/lafilefixer"
+ # ewarn "This step is needed because the libGL.la is going"
+ # ewarn "to be removed by newer versions of the media-libs/mesa"
+ #fi
# Make up a libGL.la. Ati does not provide one, but mesa does. If
# a (libtool-based) libfoo is built with libGL.la present a
# reference to it is put into libfoo.la, and compiling
@@ -458,12 +465,10 @@ src_install-libs() {
envname="${envname}-${ABI}"
fi
echo "LIBGL_DRIVERS_PATH=/usr/$(get_libdir)/dri" > "${envname}"
- doenvd "${envname}"
+ doenvd "${envname}" || die
}
pkg_postinst() {
- /usr/bin/eselect opengl set --use-old ati
-
elog "To switch to ATI OpenGL, run \"eselect opengl set ati\""
elog "To change your xorg.conf you can use the bundled \"aticonfig\""
elog
@@ -479,15 +484,16 @@ pkg_postinst() {
ewarn ' Option "XAANoOffscreenPixmaps" "true"'
ewarn "in the Device Section of /etc/X11/xorg.conf."
- linux-mod_pkg_postinst
+ use modules && linux-mod_pkg_postinst
+ "${ROOT}"/usr/bin/eselect opengl set --use-old ati
}
pkg_prerm() {
- linux-mod_pkg_prerm
- /usr/bin/eselect opengl set --use-old xorg-x11
+ use modules && linux-mod_pkg_prerm
+ "${ROOT}"/usr/bin/eselect opengl set --use-old xorg-x11
}
pkg_postrm() {
- linux-mod_pkg_postrm
- /usr/bin/eselect opengl set --use-old xorg-x11
+ use modules && linux-mod_pkg_postrm
+ "${ROOT}"/usr/bin/eselect opengl set --use-old xorg-x11
}
diff --git a/x11-drivers/ati-drivers/metadata.xml b/x11-drivers/ati-drivers/metadata.xml
index 3e5d05fc10d7..81883df349ce 100644
--- a/x11-drivers/ati-drivers/metadata.xml
+++ b/x11-drivers/ati-drivers/metadata.xml
@@ -8,4 +8,7 @@
<maintainer>
<email>scarabeus@gentoo.org</email>
</maintainer>
+ <use>
+ <flag name='modules'>Build the kernel modules</flag>
+ </use>
</pkgmetadata>