diff options
author | Chí-Thanh Christopher Nguyễn <chithanh@gentoo.org> | 2012-08-08 13:50:48 +0000 |
---|---|---|
committer | Chí-Thanh Christopher Nguyễn <chithanh@gentoo.org> | 2012-08-08 13:50:48 +0000 |
commit | 3f0e4d76906f1cb5b8215b9a67e5974ac0b8aab2 (patch) | |
tree | 7c078eda97166460aece714297846ef090b0d485 /x11-libs | |
parent | Stable for x86, wrt bug #419063 (diff) | |
download | gentoo-2-3f0e4d76906f1cb5b8215b9a67e5974ac0b8aab2.tar.gz gentoo-2-3f0e4d76906f1cb5b8215b9a67e5974ac0b8aab2.tar.bz2 gentoo-2-3f0e4d76906f1cb5b8215b9a67e5974ac0b8aab2.zip |
Fix building against xorg-server-1.13, bug #428786.
(Portage version: 2.2.0_alpha120/cvs/Linux x86_64)
Diffstat (limited to 'x11-libs')
-rw-r--r-- | x11-libs/glamor/ChangeLog | 8 | ||||
-rw-r--r-- | x11-libs/glamor/files/glamor-0.4.1-xorg-server-1.13.patch | 269 | ||||
-rw-r--r-- | x11-libs/glamor/glamor-0.4.1-r1.ebuild | 39 |
3 files changed, 315 insertions, 1 deletions
diff --git a/x11-libs/glamor/ChangeLog b/x11-libs/glamor/ChangeLog index 21fa4e7fd963..445a01bcd2e2 100644 --- a/x11-libs/glamor/ChangeLog +++ b/x11-libs/glamor/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for x11-libs/glamor # Copyright 1999-2012 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/x11-libs/glamor/ChangeLog,v 1.4 2012/07/31 12:14:31 chithanh Exp $ +# $Header: /var/cvsroot/gentoo-x86/x11-libs/glamor/ChangeLog,v 1.5 2012/08/08 13:50:48 chithanh Exp $ + +*glamor-0.4.1-r1 (08 Aug 2012) + + 08 Aug 2012; Chí-Thanh Christopher Nguyễn <chithanh@gentoo.org> + +files/glamor-0.4.1-xorg-server-1.13.patch, +glamor-0.4.1-r1.ebuild: + Fix building against xorg-server-1.13, bug #428786. 31 Jul 2012; Chí-Thanh Christopher Nguyễn <chithanh@gentoo.org> glamor-0.4.1.ebuild: diff --git a/x11-libs/glamor/files/glamor-0.4.1-xorg-server-1.13.patch b/x11-libs/glamor/files/glamor-0.4.1-xorg-server-1.13.patch new file mode 100644 index 000000000000..4e16ad584694 --- /dev/null +++ b/x11-libs/glamor/files/glamor-0.4.1-xorg-server-1.13.patch @@ -0,0 +1,269 @@ +From 726ad264f485ce1d39aa387e93ac224fb46ed059 Mon Sep 17 00:00:00 2001 +From: Zhigang Gong <zhigang.gong@linux.intel.com> +Date: Mon, 16 Jul 2012 03:25:09 +0000 +Subject: Synch with xorg 1.13 change. + +As xorg 1.13 change the scrn interaces and remove those +global arrays. Some API change cause we can't build. Now +fix it. + +Signed-off-by: Zhigang Gong <zhigang.gong@linux.intel.com> +--- +diff --git a/src/glamor.c b/src/glamor.c +index 8b7dc93..d51811e 100644 +--- a/src/glamor.c ++++ b/src/glamor.c +@@ -491,7 +491,7 @@ glamor_set_pixmap_private(PixmapPtr pixmap, glamor_pixmap_private *priv) + } + + Bool +-glamor_close_screen(int idx, ScreenPtr screen) ++glamor_close_screen(CLOSE_SCREEN_ARGS_DECL) + { + glamor_screen_private *glamor_priv; + PixmapPtr screen_pixmap; +@@ -533,7 +533,7 @@ glamor_close_screen(int idx, ScreenPtr screen) + + glamor_release_screen_priv(screen); + +- return screen->CloseScreen(idx, screen); ++ return screen->CloseScreen(CLOSE_SCREEN_ARGS); + } + + +diff --git a/src/glamor.h b/src/glamor.h +index fe3e4f8..bafd543 100644 +--- a/src/glamor.h ++++ b/src/glamor.h +@@ -30,9 +30,8 @@ + #define GLAMOR_H + + #include <scrnintstr.h> +-#ifdef GLAMOR_FOR_XORG ++#include <xf86.h> + #include <xf86str.h> +-#endif + #include <pixmapstr.h> + #include <gcstruct.h> + #include <picturestr.h> +@@ -117,7 +116,11 @@ extern _X_EXPORT void glamor_fini(ScreenPtr screen); + * screen pixmap which must be a glamor pixmap and requires + * the internal data structure still exist at that time. + * Otherwise, the glamor internal structure will not be freed.*/ +-extern _X_EXPORT Bool glamor_close_screen(int idx, ScreenPtr screen); ++#ifndef XF86_SCRN_INTERFACE ++extern _X_EXPORT Bool glamor_close_screen(int scrnIndex, ScreenPtr screen); ++#else ++extern _X_EXPORT Bool glamor_close_screen(ScreenPtr screen); ++#endif + + + /* Let glamor to know the screen's fbo. The low level +diff --git a/src/glamor_egl.c b/src/glamor_egl.c +index 07acf1a..da9283b 100644 +--- a/src/glamor_egl.c ++++ b/src/glamor_egl.c +@@ -59,6 +59,7 @@ + #include <EGL/eglext.h> + + #include "glamor.h" ++#include "compat-api.h" + #include "glamor_gl_dispatch.h" + #ifdef GLX_USE_SHARED_DISPATCH + #include "glapi.h" +@@ -365,7 +366,7 @@ glamor_egl_destroy_textured_pixmap(PixmapPtr pixmap) + } + + static Bool +-glamor_egl_close_screen(int idx, ScreenPtr screen) ++glamor_egl_close_screen(CLOSE_SCREEN_ARGS_DECL) + { + ScrnInfoPtr scrn; + struct glamor_egl_screen_private *glamor_egl; +@@ -391,7 +392,7 @@ glamor_egl_close_screen(int idx, ScreenPtr screen) + + screen->CloseScreen = glamor_egl->saved_close_screen; + +- return screen->CloseScreen(idx, screen); ++ return screen->CloseScreen(CLOSE_SCREEN_ARGS); + } + + static Bool +@@ -430,10 +431,15 @@ glamor_egl_screen_init(ScreenPtr screen) + } + + static void +-glamor_egl_free_screen(int scrnIndex, int flags) ++glamor_egl_free_screen(FREE_SCREEN_ARGS_DECL) + { +- ScrnInfoPtr scrn = xf86Screens[scrnIndex]; ++ ScrnInfoPtr scrn; + struct glamor_egl_screen_private *glamor_egl; ++#ifndef XF86_SCRN_INTERFACE ++ scrn = xf86Screens[arg]; ++#else ++ scrn = arg; ++#endif + + glamor_egl = glamor_egl_get_screen_private(scrn); + if (glamor_egl != NULL) { +@@ -447,7 +453,7 @@ glamor_egl_free_screen(int scrnIndex, int flags) + #endif + scrn->FreeScreen = glamor_egl->saved_free_screen; + free(glamor_egl); +- scrn->FreeScreen(scrnIndex, flags); ++ scrn->FreeScreen(FREE_SCREEN_ARGS); + } + } + +diff --git a/src/glamor_priv.h b/src/glamor_priv.h +index 3b64c31..11d09c4 100644 +--- a/src/glamor_priv.h ++++ b/src/glamor_priv.h +@@ -38,6 +38,7 @@ + #define NDEBUG + #endif + #include "glamor.h" ++#include "compat-api.h" + + #define GL_GLEXT_PROTOTYPES + +diff --git a/src/glamor_utils.h b/src/glamor_utils.h +index a282985..eb2e202 100644 +--- a/src/glamor_utils.h ++++ b/src/glamor_utils.h +@@ -798,7 +798,10 @@ region_is_empty(pixman_region16_t *region) + return region->data && region->data->numRects == 0; + } + ++#ifndef ARRAY_SIZE + #define ARRAY_SIZE(x) (sizeof(x) / sizeof(x[0])) ++#endif ++ + #define ALIGN(i,m) (((i) + (m) - 1) & ~((m) - 1)) + #define MIN(a,b) ((a) < (b) ? (a) : (b)) + #define MAX(a,b) ((a) > (b) ? (a) : (b)) +-- +cgit v0.9.0.2-2-gbebe +From ab212d3b90cd288da46af43390feacb489db77b1 Mon Sep 17 00:00:00 2001 +From: Zhigang Gong <zhigang.gong@linux.intel.com> +Date: Mon, 16 Jul 2012 09:27:22 +0000 +Subject: Added the missed header file for xorg 1.13 compat. + +Signed-off-by: Zhigang Gong <zhigang.gong@linux.intel.com> +--- +diff --git a/src/compat-api.h b/src/compat-api.h +new file mode 100644 +index 0000000..1608478 +--- a/dev/null ++++ b/src/compat-api.h +@@ -0,0 +1,107 @@ ++/* ++ * Copyright 2012 Red Hat, Inc. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining a ++ * copy of this software and associated documentation files (the "Software"), ++ * to deal in the Software without restriction, including without limitation ++ * the rights to use, copy, modify, merge, publish, distribute, sublicense, ++ * and/or sell copies of the Software, and to permit persons to whom the ++ * Software is furnished to do so, subject to the following conditions: ++ * ++ * The above copyright notice and this permission notice (including the next ++ * paragraph) shall be included in all copies or substantial portions of the ++ * Software. ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ++ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ++ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL ++ * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING ++ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER ++ * DEALINGS IN THE SOFTWARE. ++ * ++ * Author: Dave Airlie <airlied@redhat.com> ++ */ ++ ++/* this file provides API compat between server post 1.13 and pre it, ++ it should be reused inside as many drivers as possible */ ++#ifndef COMPAT_API_H ++#define COMPAT_API_H ++ ++#ifndef GLYPH_HAS_GLYPH_PICTURE_ACCESSOR ++#define GetGlyphPicture(g, s) GlyphPicture((g))[(s)->myNum] ++#define SetGlyphPicture(g, s, p) GlyphPicture((g))[(s)->myNum] = p ++#endif ++ ++#ifndef XF86_HAS_SCRN_CONV ++#define xf86ScreenToScrn(s) xf86Screens[(s)->myNum] ++#define xf86ScrnToScreen(s) screenInfo.screens[(s)->scrnIndex] ++#endif ++ ++#ifndef XF86_SCRN_INTERFACE ++ ++#define SCRN_ARG_TYPE int ++#define SCRN_INFO_PTR(arg1) ScrnInfoPtr scrn = xf86Screens[(arg1)] ++ ++#define SCREEN_ARG_TYPE int ++#define SCREEN_PTR(arg1) ScreenPtr screen = screenInfo.screens[(arg1)] ++ ++#define SCREEN_INIT_ARGS_DECL int scrnIndex, ScreenPtr screen, int argc, char **argv ++ ++#define BLOCKHANDLER_ARGS_DECL int arg, pointer blockData, pointer timeout, pointer read_mask ++#define BLOCKHANDLER_ARGS arg, blockData, timeout, read_mask ++ ++#define WAKEUPHANDLER_ARGS_DECL int arg, pointer wakeupData, unsigned long result, pointer read_mask ++#define WAKEUPHANDLER_ARGS arg, wakeupData, result, read_mask ++ ++#define CLOSE_SCREEN_ARGS_DECL int scrnIndex, ScreenPtr screen ++#define CLOSE_SCREEN_ARGS scrnIndex, screen ++ ++#define ADJUST_FRAME_ARGS_DECL int arg, int x, int y, int flags ++#define ADJUST_FRAME_ARGS(arg, x, y) (arg)->scrnIndex, x, y, 0 ++ ++#define SWITCH_MODE_ARGS_DECL int arg, DisplayModePtr mode, int flags ++#define SWITCH_MODE_ARGS(arg, m) (arg)->scrnIndex, m, 0 ++ ++#define FREE_SCREEN_ARGS_DECL int arg, int flags ++#define FREE_SCREEN_ARGS arg, flags ++ ++#define VT_FUNC_ARGS_DECL int arg, int flags ++#define VT_FUNC_ARGS(flags) scrn->scrnIndex, (flags) ++ ++#define XF86_ENABLEDISABLEFB_ARG(x) ((x)->scrnIndex) ++ ++#else ++#define SCRN_ARG_TYPE ScrnInfoPtr ++#define SCRN_INFO_PTR(arg1) ScrnInfoPtr scrn = (arg1) ++ ++#define SCREEN_ARG_TYPE ScreenPtr ++#define SCREEN_PTR(arg1) ScreenPtr screen = (arg1) ++ ++#define SCREEN_INIT_ARGS_DECL ScreenPtr screen, int argc, char **argv ++ ++#define BLOCKHANDLER_ARGS_DECL ScreenPtr arg, pointer timeout, pointer read_mask ++#define BLOCKHANDLER_ARGS arg, timeout, read_mask ++ ++#define WAKEUPHANDLER_ARGS_DECL ScreenPtr arg, unsigned long result, pointer read_mask ++#define WAKEUPHANDLER_ARGS arg, result, read_mask ++ ++#define CLOSE_SCREEN_ARGS_DECL ScreenPtr screen ++#define CLOSE_SCREEN_ARGS screen ++ ++#define ADJUST_FRAME_ARGS_DECL ScrnInfoPtr arg, int x, int y ++#define ADJUST_FRAME_ARGS(arg, x, y) arg, x, y ++ ++#define SWITCH_MODE_ARGS_DECL ScrnInfoPtr arg, DisplayModePtr mode ++#define SWITCH_MODE_ARGS(arg, m) arg, m ++ ++#define FREE_SCREEN_ARGS_DECL ScrnInfoPtr arg ++#define FREE_SCREEN_ARGS arg ++ ++#define VT_FUNC_ARGS_DECL ScrnInfoPtr arg ++#define VT_FUNC_ARGS(flags) scrn ++ ++#define XF86_ENABLEDISABLEFB_ARG(x) (x) ++ ++#endif ++#endif +-- +cgit v0.9.0.2-2-gbebe diff --git a/x11-libs/glamor/glamor-0.4.1-r1.ebuild b/x11-libs/glamor/glamor-0.4.1-r1.ebuild new file mode 100644 index 000000000000..bf95cf5e1de6 --- /dev/null +++ b/x11-libs/glamor/glamor-0.4.1-r1.ebuild @@ -0,0 +1,39 @@ +# Copyright 1999-2012 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/x11-libs/glamor/glamor-0.4.1-r1.ebuild,v 1.1 2012/08/08 13:50:48 chithanh Exp $ + +EAPI=4 + +XORG_DRI=always +XORG_EAUTORECONF=yes +inherit xorg-2 + +DESCRIPTION="OpenGL based 2D rendering acceleration library" +SRC_URI="mirror://gentoo/glamor-0.4.1.tar.gz" + +KEYWORDS="~amd64 ~ia64 ~x86" +IUSE="gles" + +RDEPEND=">=x11-base/xorg-server-1.10 + media-libs/mesa[egl,gbm] + gles? ( + || ( media-libs/mesa[gles2] media-libs/mesa[gles] ) + ) + >=x11-libs/pixman-0.21.8" +DEPEND="${RDEPEND}" + +PATCHES=( + "${FILESDIR}"/${P}-xorg-server-1.13.patch +) + +pkg_setup() { + xorg-2_pkg_setup + XORG_CONFIGURE_OPTIONS=( + $(use_enable gles glamor-gles2) + ) +} + +src_prepare() { + sed -i 's/inst_LTLIBRARIES/lib_LTLIBRARIES/' src/Makefile.am || die + xorg-2_src_prepare +} |