From 548acc1f09af7912133e0585af8141d414e93a911eedb6f8ef8b58b7d5fe8baf Mon Sep 17 00:00:00 2001 From: Stefan Dirsch Date: Wed, 21 Mar 2012 15:12:39 +0000 Subject: [PATCH 1/3] - U_gallium-rtasm-properly-detect-SSE-and-SSE2.patch * gallium/rtasm: properly detect SSE and SSE2; this should fix crashes on ancient processors. (bnc#728737) OBS-URL: https://build.opensuse.org/package/show/X11:XOrg/Mesa?expand=0&rev=203 --- Mesa.changes | 7 ++ Mesa.spec | 2 + ...m-rtasm-properly-detect-SSE-and-SSE2.patch | 85 +++++++++++++++++++ 3 files changed, 94 insertions(+) create mode 100644 U_gallium-rtasm-properly-detect-SSE-and-SSE2.patch diff --git a/Mesa.changes b/Mesa.changes index 27e2194..5198058 100644 --- a/Mesa.changes +++ b/Mesa.changes @@ -1,3 +1,10 @@ +------------------------------------------------------------------- +Wed Mar 21 14:55:19 UTC 2012 - sndirsch@suse.com + +- U_gallium-rtasm-properly-detect-SSE-and-SSE2.patch + * gallium/rtasm: properly detect SSE and SSE2; this should fix + crashes on ancient processors. (bnc#728737) + ------------------------------------------------------------------- Thu Mar 1 08:22:41 UTC 2012 - coolo@suse.com diff --git a/Mesa.spec b/Mesa.spec index 266f92b..c65c826 100644 --- a/Mesa.spec +++ b/Mesa.spec @@ -86,6 +86,7 @@ Patch1: Mesa-nodate.diff # to be upstreamed Patch11: u_Fix-crash-in-swrast-when-setting-a-texture-for-a-pix.patch # already upstream +Patch12: U_gallium-rtasm-properly-detect-SSE-and-SSE2.patch BuildRoot: %{_tmppath}/%{name}-%{version}-build %description @@ -367,6 +368,7 @@ rm -f include/GL/{glut.h,uglglutshapes.h,glutf90.h} # remove some docs rm -rf docs/README.{VMS,WIN32,OS2} #%patch11 -p1 +%patch12 -p1 %build diff --git a/U_gallium-rtasm-properly-detect-SSE-and-SSE2.patch b/U_gallium-rtasm-properly-detect-SSE-and-SSE2.patch new file mode 100644 index 0000000..e3c6900 --- /dev/null +++ b/U_gallium-rtasm-properly-detect-SSE-and-SSE2.patch @@ -0,0 +1,85 @@ +From 74d303521e6ba41d1cbeb75edb2f834ebbe8c550 Mon Sep 17 00:00:00 2001 +From: =?UTF-8?q?Marek=20Ol=C5=A1=C3=A1k?= +Date: Fri, 24 Feb 2012 19:29:48 +0100 +Subject: [PATCH] gallium/rtasm: properly detect SSE and SSE2 + +This should fix crashes on ancient processors. +--- + src/gallium/auxiliary/rtasm/rtasm_cpu.c | 48 +++++++++++++++--------------- + 1 files changed, 24 insertions(+), 24 deletions(-) + +diff --git a/src/gallium/auxiliary/rtasm/rtasm_cpu.c b/src/gallium/auxiliary/rtasm/rtasm_cpu.c +index 0461c81..7afcf14 100644 +--- a/src/gallium/auxiliary/rtasm/rtasm_cpu.c ++++ b/src/gallium/auxiliary/rtasm/rtasm_cpu.c +@@ -25,43 +25,43 @@ + * + **************************************************************************/ + ++#include "pipe/p_config.h" ++#include "rtasm_cpu.h" ++ ++#if defined(PIPE_ARCH_X86) || defined(PIPE_ARCH_X86_64) + + #include "util/u_debug.h" +-#include "rtasm_cpu.h" ++#include "util/u_cpu_detect.h" + ++DEBUG_GET_ONCE_BOOL_OPTION(nosse, "GALLIUM_NOSSE", FALSE); + +-#if defined(PIPE_ARCH_X86) || defined(PIPE_ARCH_X86_64) +-static boolean rtasm_sse_enabled(void) ++static struct util_cpu_caps *get_cpu_caps(void) + { +- static boolean firsttime = 1; +- static boolean enabled; +- +- /* This gets called quite often at the moment: +- */ +- if (firsttime) { +- enabled = !debug_get_bool_option("GALLIUM_NOSSE", FALSE); +- firsttime = FALSE; +- } +- return enabled; ++ util_cpu_detect(); ++ return &util_cpu_caps; + } +-#endif + + int rtasm_cpu_has_sse(void) + { +- /* FIXME: actually detect this at run-time */ +-#if defined(PIPE_ARCH_X86) || defined(PIPE_ARCH_X86_64) +- return rtasm_sse_enabled(); +-#else +- return 0; +-#endif ++ return !debug_get_option_nosse() && get_cpu_caps()->has_sse; + } + + int rtasm_cpu_has_sse2(void) + { +- /* FIXME: actually detect this at run-time */ +-#if defined(PIPE_ARCH_X86) || defined(PIPE_ARCH_X86_64) +- return rtasm_sse_enabled(); ++ return !debug_get_option_nosse() && get_cpu_caps()->has_sse2; ++} ++ ++ + #else ++ ++int rtasm_cpu_has_sse(void) ++{ + return 0; +-#endif + } ++ ++int rtasm_cpu_has_sse2(void) ++{ ++ return 0; ++} ++ ++#endif +-- +1.7.3.4 + From 73b68acd16b47df8bc9a006715f00cbe120ef90dccb4f01bd381b6e9e301bb8d Mon Sep 17 00:00:00 2001 From: Stefan Dirsch Date: Wed, 21 Mar 2012 20:07:18 +0000 Subject: [PATCH 2/3] Accepting request 110475 from home:jengelh:branches:X11:XOrg - Adjust baselibs.conf for OSMesa soname change OBS-URL: https://build.opensuse.org/request/show/110475 OBS-URL: https://build.opensuse.org/package/show/X11:XOrg/Mesa?expand=0&rev=204 --- Mesa.changes | 5 +++++ baselibs.conf | 2 +- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/Mesa.changes b/Mesa.changes index 5198058..4ed352f 100644 --- a/Mesa.changes +++ b/Mesa.changes @@ -1,3 +1,8 @@ +------------------------------------------------------------------- +Wed Mar 21 18:06:27 UTC 2012 - jengelh@medozas.de + +- Adjust baselibs.conf for OSMesa soname change + ------------------------------------------------------------------- Wed Mar 21 14:55:19 UTC 2012 - sndirsch@suse.com diff --git a/baselibs.conf b/baselibs.conf index 76fc56e..4fc5a85 100644 --- a/baselibs.conf +++ b/baselibs.conf @@ -36,7 +36,7 @@ Mesa-libGLU-devel requires -Mesa-libGLU- requires "Mesa-libGLU1- = " Mesa-libIndirectGL1 -libOSMesa7 +libOSMesa8 libgbm1 libgbm-devel requires -libgbm- From bbcb7f2883f2fc73220b63f65767f24b3eb50c55e62a15b64299e1b4e92ddb05 Mon Sep 17 00:00:00 2001 From: Stefan Dirsch Date: Thu, 22 Mar 2012 11:18:14 +0000 Subject: [PATCH 3/3] Accepting request 110520 from home:ryanbach:branches:X11:XOrg Changed software rasterizer to llvmpipe for supported architectures: X86/X86-64. OBS-URL: https://build.opensuse.org/request/show/110520 OBS-URL: https://build.opensuse.org/package/show/X11:XOrg/Mesa?expand=0&rev=205 --- Mesa.changes | 7 +++++++ Mesa.spec | 1 + 2 files changed, 8 insertions(+) diff --git a/Mesa.changes b/Mesa.changes index 4ed352f..f692082 100644 --- a/Mesa.changes +++ b/Mesa.changes @@ -1,3 +1,10 @@ +------------------------------------------------------------------- +Wed Mar 21 23:21:24 UTC 2012 - ryanbach@adelphia.net + +-- Updated software rasterizer to use llvmpipe the advanced, +- multithreaded,software rasterizer if availaible for that +- archetecture (ie. X86/X86-64). + ------------------------------------------------------------------- Wed Mar 21 18:06:27 UTC 2012 - jengelh@medozas.de diff --git a/Mesa.spec b/Mesa.spec index c65c826..a3cd62b 100644 --- a/Mesa.spec +++ b/Mesa.spec @@ -386,6 +386,7 @@ autoreconf -fi --enable-shared-dricore \ --with-dri-searchpath=/usr/%{_lib}/dri/updates:/usr/%{_lib}/dri \ %ifarch %ix86 x86_64 + --enable-gallium-llvm \ --with-dri-drivers=i915,i965,nouveau,r200,radeon \ --with-gallium-drivers=r300,r600,nouveau,swrast \ %endif