summaryrefslogtreecommitdiff
path: root/multilib-testing/lib32-mesa
diff options
context:
space:
mode:
Diffstat (limited to 'multilib-testing/lib32-mesa')
-rw-r--r--multilib-testing/lib32-mesa/PKGBUILD257
-rw-r--r--multilib-testing/lib32-mesa/pthread_fix.diff23
2 files changed, 280 insertions, 0 deletions
diff --git a/multilib-testing/lib32-mesa/PKGBUILD b/multilib-testing/lib32-mesa/PKGBUILD
new file mode 100644
index 000000000..fbc3017f4
--- /dev/null
+++ b/multilib-testing/lib32-mesa/PKGBUILD
@@ -0,0 +1,257 @@
+# $Id: PKGBUILD 77208 2012-10-06 21:02:40Z lcarlier $
+# Contributor: Jan de Groot <jgc@archlinux.org>
+# Contributor: Andreas Radke <andyrtr@archlinux.org>
+
+pkgbase=lib32-mesa
+pkgname=('lib32-libglapi' 'lib32-libgl' 'lib32-mesa' 'lib32-osmesa' 'lib32-libgles' 'lib32-ati-dri' 'lib32-intel-dri'
+ 'lib32-nouveau-dri') # lib32-libgbm needs udev
+_git=true
+_gitdate=20121005
+#_git=false
+
+if [ "${_git}" = "true" ]; then
+ pkgver=8.99.git_$_gitdate
+ else
+ pkgver=8.0.4
+fi
+
+pkgrel=1
+arch=('x86_64')
+makedepends=('glproto>=1.4.16' 'lib32-libdrm>=2.4.39' 'lib32-libxxf86vm>=1.1.2' 'lib32-libxdamage>=1.1.3' 'lib32-expat>=2.1.0'
+ 'lib32-libx11>=1.5.0' 'lib32-libxt>=1.1.3' 'lib32-gcc-libs>=4.7.1-6' 'dri2proto>=2.8' 'python2' 'libxml2'
+ 'gcc-multilib' 'imake' 'lib32-llvm')
+url="http://mesa3d.sourceforge.net"
+license=('custom')
+options=('!libtool')
+source=(pthread_fix.diff)
+if [ "${_git}" = "true" ]; then
+ # mesa git shot from 9.0 branch - see for state: http://cgit.freedesktop.org/mesa/mesa/log/?h=9.0
+ #source=(${source[@]} 'ftp://ftp.archlinux.org/other/mesa/mesa-41d14eaf193c6b1eb87fe1998808a887f1c6c698.tar.gz')
+ source=(${source[@]} "MesaLib-git${_gitdate}.zip"::"http://cgit.freedesktop.org/mesa/mesa/snapshot/mesa-542f6feda9bf18267dbd337943a5e871400d425a.tar.gz")
+else
+ source=(${source[@]} "ftp://ftp.freedesktop.org/pub/mesa/${pkgver}/MesaLib-${pkgver}.tar.bz2")
+fi
+md5sums=('03956ac54a44467678120f485b626633'
+ '107b77be1fbe64b4f0d87dfb441218b5')
+
+build() {
+ export CC="gcc -m32"
+ export CXX="g++ -m32"
+ export PKG_CONFIG_PATH="/usr/lib32/pkgconfig"
+ # for our llvm-config for 32 bit
+ export LLVM_CONFIG=/usr/bin/llvm-config32
+
+ # fix segfault with gfx cards > Ati R700
+ export CFLAGS="${CFLAGS} -O1"
+ export CXXFLAGS="${CXXFLAGS} -O1"
+
+ cd ${srcdir}/?esa-*
+
+ # build fix from master http://cgit.freedesktop.org/mesa/mesa/commit/?id=dd4fde8f674f5e3efa19e929f97de4ecfd82391b
+ patch -Np1 -i ${srcdir}/pthread_fix.diff
+
+ COMMONOPTS="--prefix=/usr \
+ --sysconfdir=/etc \
+ --with-dri-driverdir=/usr/lib32/xorg/modules/dri \
+ --with-gallium-drivers=r300,r600,radeonsi,nouveau,swrast \
+ --with-dri-drivers=i915,i965,r200,radeon,nouveau,swrast \
+ --enable-gallium-llvm \
+ --disable-gallium-egl --enable-shared-glapi \
+ --enable-shared-glapi \
+ --enable-glx-tls \
+ --enable-dri \
+ --enable-gles1 \
+ --enable-gles2 \
+ --disable-egl \
+ --enable-texture-float \
+ --enable-osmesa \
+ --enable-32-bit \
+ --libdir=/usr/lib32 "
+ # --enable-gbm disabled because it needs udev
+
+ if [ "${_git}" = "true" ]; then
+ ./autogen.sh \
+ $COMMONOPTS
+ else
+ autoreconf -vfi
+ ./configure \
+ $COMMONOPTS
+ fi
+
+ make
+}
+
+package_lib32-libglapi() {
+ depends=('lib32-glibc' 'libglapi')
+ pkgdesc="free implementation of the GL API -- shared library. The Mesa GL API module is responsible for dispatching all the gl* functions (32-bits)"
+
+ cd ${srcdir}/?esa-*
+
+ make -C src/mapi/shared-glapi DESTDIR="${pkgdir}" install
+
+ install -m755 -d "${pkgdir}/usr/share/licenses/libglapi"
+ ln -s libglapi "${pkgdir}/usr/share/licenses/libglapi/lib32-libglapi"
+}
+
+package_lib32-libgl() {
+ depends=('lib32-libdrm>=2.4.39' 'lib32-libxxf86vm>=1.1.2' 'lib32-libxdamage>=1.1.3' 'lib32-expat>=2.1.0' 'lib32-libglapi'
+ 'libgl')
+ pkgdesc="Mesa 3-D graphics library and DRI software rasterizer (32-bit)"
+ # currently disabled so force the remove
+ conflicts=('lib32-libgbm')
+ replace=('lib32-libgbm')
+
+ cd ${srcdir}/?esa-*
+
+ # fix linking because of splitted package
+ make -C src/mapi/shared-glapi DESTDIR="${pkgdir}" install
+
+ # libGL & libdricore
+ make -C src/glx DESTDIR="${pkgdir}" install
+ make -C src/mesa/libdricore DESTDIR="${pkgdir}" install
+
+ # fix linking because of splitted package - cleanup
+ make -C src/mapi/shared-glapi DESTDIR="${pkgdir}" uninstall
+
+ # --with-gallium-drivers=swrast
+ make -C src/gallium/targets/dri-swrast DESTDIR="${pkgdir}" install
+
+ install -m755 -d "${pkgdir}/usr/share/licenses/libgl"
+ ln -s libgl "${pkgdir}/usr/share/licenses/libgl/lib32-libgl"
+}
+
+package_lib32-mesa() {
+ # check also gl.pc
+ depends=('lib32-libgl' 'lib32-libx11>=1.5.0' 'lib32-libxext>=1.3.1' 'lib32-libxdamage' 'lib32-libxfixes' 'lib32-libxcb'
+ 'lib32-libxxf86vm' 'mesa')
+ pkgdesc="Mesa 3-D graphics libraries and include files (32-bit)"
+
+ cd ${srcdir}/?esa-*
+
+ # .pc files
+ make -C src/mesa DESTDIR="${pkgdir}" install-pkgconfigDATA
+ make -C src/mesa/drivers/dri DESTDIR="${pkgdir}" install-pkgconfigDATA
+
+ install -m755 -d "${pkgdir}/usr/share/licenses/mesa"
+ ln -s mesa "$pkgdir/usr/share/licenses/mesa/lib32-mesa"
+}
+
+package_lib32-osmesa() {
+ depends=('lib32-libglapi' 'lib32-gcc-libs' 'osmesa')
+ optdepends=('opengl-man-pages: for the OpenGL API man pages')
+ pkgdesc="Mesa 3D off-screen rendering library (32-bits)"
+
+ # fix linking because of splitted package
+ make -C ${srcdir}/?esa-*/src/mapi/shared-glapi DESTDIR="${pkgdir}" install
+
+ make -C ${srcdir}/?esa-*/src/mesa/drivers/osmesa DESTDIR="${pkgdir}" install
+
+ # fix linking because of splitted package - cleanup
+ make -C ${srcdir}/?esa-*/src/mapi/shared-glapi DESTDIR="${pkgdir}" uninstall
+}
+
+# package_lib32-libgbm() {
+# depends=('lib32-libglapi' 'lib32-libdrm' 'libgbm')
+# pkgdesc="Mesa gbm library (32-bit)"
+#
+# cd ${srcdir}/?esa-*
+#
+# # fix linking because of splitted package
+# make -C src/mapi/shared-glapi DESTDIR="${pkgdir}" install
+#
+# make -C src/gbm DESTDIR="${pkgdir}" install
+#
+# # fix linking because of splitted package - cleanup
+# make -C src/mapi/shared-glapi DESTDIR="${pkgdir}" uninstall
+#
+# install -m755 -d "${pkgdir}/usr/share/licenses/libgbm"
+# ln -s libgbm "$pkgdir/usr/share/licenses/libgbm/lib32-libgbm"
+# }
+
+package_lib32-libgles() {
+ depends=('lib32-libglapi' 'lib32-libdrm' 'libgles')
+ pkgdesc="Mesa GLES libraries (32-bit)"
+
+ cd ${srcdir}/?esa-*
+
+ # fix linking because of splitted package
+ make -C src/mapi/shared-glapi DESTDIR="${pkgdir}" install
+
+ # --enable-gles1 --enable-gles2
+ make -C src/mapi/es1api DESTDIR="${pkgdir}" install
+ make -C src/mapi/es2api DESTDIR="${pkgdir}" install
+
+ # fix linking because of splitted package - cleanup
+ make -C src/mapi/shared-glapi DESTDIR="${pkgdir}" uninstall
+
+ rm -r "${pkgdir}"/usr/include
+
+ install -m755 -d "${pkgdir}/usr/share/licenses/libgles"
+ ln -s libgles "$pkgdir/usr/share/licenses/libgles/lib32-libgles"
+}
+
+package_lib32-ati-dri() {
+ depends=("lib32-libgl=${pkgver}" 'ati-dri')
+ pkgdesc="Mesa DRI radeon/r200 + Gallium3D for r300 and later chipsets drivers for AMD/ATI Radeon (32-bit)"
+ conflicts=('xf86-video-ati<6.9.0-6')
+
+ cd ${srcdir}/?esa-*
+
+ # fix linking because of splitted package
+ make -C src/mesa/libdricore DESTDIR="${pkgdir}" install
+
+ # classic mesa drivers for radeon,r200
+ make -C src/mesa/drivers/dri/radeon DESTDIR="${pkgdir}" install
+ make -C src/mesa/drivers/dri/r200 DESTDIR="${pkgdir}" install
+ # gallium3D driver for r300,r600
+ make -C src/gallium/targets/dri-r300 DESTDIR="${pkgdir}" install
+ make -C src/gallium/targets/dri-r600 DESTDIR="${pkgdir}" install
+ make -C src/gallium/targets/dri-radeonsi DESTDIR="${pkgdir}" install
+
+ # fix linking because of splitted package - cleanup
+ make -C src/mesa/libdricore DESTDIR="${pkgdir}" uninstall
+
+ install -m755 -d "${pkgdir}/usr/share/licenses/ati-dri"
+ ln -s ati-dri "$pkgdir/usr/share/licenses/ati-dri/lib32-ati-dri"
+}
+
+package_lib32-intel-dri() {
+ depends=("lib32-libgl=${pkgver}" 'intel-dri')
+ pkgdesc="Mesa DRI drivers for Intel (32-bit)"
+
+ cd ${srcdir}/?esa-*
+
+ # fix linking because of splitted package
+ make -C src/mesa/libdricore DESTDIR="${pkgdir}" install
+
+ make -C src/mesa/drivers/dri/i915 DESTDIR="${pkgdir}" install
+ make -C src/mesa/drivers/dri/i965 DESTDIR="${pkgdir}" install
+
+ # fix linking because of splitted package - cleanup
+ make -C src/mesa/libdricore DESTDIR="${pkgdir}" uninstall
+
+ install -m755 -d "${pkgdir}/usr/share/licenses/intel-dri"
+ ln -s intel-dri "$pkgdir/usr/share/licenses/intel-dri/lib32-intel-dri"
+}
+
+package_lib32-nouveau-dri() {
+ depends=("lib32-libgl=${pkgver}" 'nouveau-dri')
+ pkgdesc="Mesa classic DRI + Gallium3D drivers for Nouveau (32-bit)"
+
+ cd ${srcdir}/?esa-*
+
+ # fix linking because of splitted package
+ make -C src/mesa/libdricore DESTDIR="${pkgdir}" install
+
+ # classic mesa driver for nv10 , nv20 nouveau_vieux_dri.so
+ make -C src/mesa/drivers/dri/nouveau DESTDIR="${pkgdir}" install
+ # gallium3D driver for nv30 - nv40 - nv50 nouveau_dri.so
+ make -C src/gallium/targets/dri-nouveau DESTDIR="${pkgdir}" install
+
+ # fix linking because of splitted package - cleanup
+ make -C src/mesa/libdricore DESTDIR="${pkgdir}" uninstall
+
+ install -m755 -d "${pkgdir}/usr/share/licenses/nouveau-dri"
+ ln -s nouveau-dri "$pkgdir/usr/share/licenses/nouveau-dri/lib32-nouveau-dri"
+}
+
diff --git a/multilib-testing/lib32-mesa/pthread_fix.diff b/multilib-testing/lib32-mesa/pthread_fix.diff
new file mode 100644
index 000000000..bdfe2d865
--- /dev/null
+++ b/multilib-testing/lib32-mesa/pthread_fix.diff
@@ -0,0 +1,23 @@
+From dd4fde8f674f5e3efa19e929f97de4ecfd82391b Mon Sep 17 00:00:00 2001
+From: Matt Turner <mattst88@gmail.com>
+Date: Thu, 27 Sep 2012 22:49:52 +0000
+Subject: build: Set PTHREAD_LIBS for pkgconfig files if empty
+
+---
+diff --git a/configure.ac b/configure.ac
+index 770df2f..dc2720d 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -509,6 +509,10 @@ AC_CHECK_DECLS([signbit],[],
+
+ dnl Check for pthreads
+ AX_PTHREAD
++dnl AX_PTHREADS leaves PTHREAD_LIBS empty for gcc and sets PTHREAD_CFLAGS
++dnl to -pthread, which causes problems if we need -lpthread to appear in
++dnl pkgconfig files.
++test -z "$PTHREAD_LIBS" && PTHREAD_LIBS="-lpthread"
+
+ dnl SELinux awareness.
+ AC_ARG_ENABLE([selinux],
+--
+cgit v0.9.0.2-2-gbebe