mozilla-sle11.patch
author Wolfgang Rosenauer <wr@rosenauer.org>
Thu, 07 Jul 2011 07:59:51 +0200
changeset 287 79d59c9143a2
parent 285 0287f70d86e9
child 294 5330447b83a3
permissions -rw-r--r--
fixed branding package version provides
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
285
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     1
Subject: Patches needed to build on SLE11/11.1
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     2
References:
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     3
https://bugzilla.mozilla.org/show_bug.cgi?id=513422
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     4
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     5
diff --git a/gfx/cairo/cairo/src/cairo-xlib-surface.c b/gfx/cairo/cairo/src/cairo-xlib-surface.c
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     6
--- a/gfx/cairo/cairo/src/cairo-xlib-surface.c
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     7
+++ b/gfx/cairo/cairo/src/cairo-xlib-surface.c
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     8
@@ -4041,17 +4041,19 @@ _cairo_xlib_surface_add_glyph (Display *
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
     9
 	    new = malloc (4 * c);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    10
 	    if (unlikely (new == NULL)) {
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    11
 		status = _cairo_error (CAIRO_STATUS_NO_MEMORY);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    12
 		goto BAIL;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    13
 	    }
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    14
 	    n = new;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    15
 	    d = (uint32_t *) data;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    16
 	    do {
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    17
-		*n++ = bswap_32 (*d++);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    18
+		*n = bswap_32 (*d);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    19
+                *n++;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    20
+                *d++;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    21
 	    } while (--c);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    22
 	    data = (uint8_t *) new;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    23
 	}
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    24
 	break;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    25
     case CAIRO_FORMAT_RGB24:
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    26
     default:
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    27
 	ASSERT_NOT_REACHED;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    28
 	break;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    29
diff --git a/xpcom/glue/SSE.cpp b/xpcom/glue/SSE.cpp
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    30
--- a/xpcom/glue/SSE.cpp
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    31
+++ b/xpcom/glue/SSE.cpp
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    32
@@ -44,26 +44,77 @@ namespace {
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    33
 // SSE.h has parallel #ifs which declare MOZILLA_SSE_HAVE_CPUID_DETECTION.
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    34
 // We can't declare these functions in the header file, however, because
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    35
 // <intrin.h> conflicts with <windows.h> on MSVC 2005, and some files want to
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    36
 // include both SSE.h and <windows.h>.
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    37
 
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    38
 #if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 3)) && (defined(__i386__) || defined(__x86_64__))
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    39
 
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    40
 // cpuid.h is available on gcc 4.3 and higher on i386 and x86_64
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    41
-#include <cpuid.h>
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    42
+//#include <cpuid.h>
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    43
 
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    44
 enum CPUIDRegister { eax = 0, ebx = 1, ecx = 2, edx = 3 };
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    45
 
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    46
+#ifdef __i386__
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    47
+#define _my_cpuid(level, a, b, c, d)                    \
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    48
+  __asm__ ("xchg{l}\t{%%}ebx, %1\n\t"                   \
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    49
+           "cpuid\n\t"                                  \
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    50
+           "xchg{l}\t{%%}ebx, %1\n\t"                   \
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    51
+           : "=a" (a), "=r" (b), "=c" (c), "=d" (d)     \
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    52
+           : "0" (level))
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    53
+#else
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    54
+#define _my_cpuid(level, a, b, c, d)                    \
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    55
+  __asm__ ("cpuid\n\t"                                  \
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    56
+           : "=a" (a), "=b" (b), "=c" (c), "=d" (d)     \
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    57
+           : "0" (level))
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    58
+#endif
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    59
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    60
+static __inline unsigned int
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    61
+my_cpuid_max (unsigned int __ext, unsigned int *__sig)
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    62
+{
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    63
+  unsigned int __eax, __ebx, __ecx, __edx;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    64
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    65
+#ifdef __i386__
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    66
+  __asm__ ("pushf{l|d}\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    67
+           "pushf{l|d}\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    68
+           "pop{l}\t%0\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    69
+           "mov{l}\t{%0, %1|%1, %0}\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    70
+           "xor{l}\t{%2, %0|%0, %2}\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    71
+           "push{l}\t%0\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    72
+           "popf{l|d}\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    73
+           "pushf{l|d}\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    74
+           "pop{l}\t%0\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    75
+           "popf{l|d}\n\t"
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    76
+           : "=&r" (__eax), "=&r" (__ebx)
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    77
+           : "i" (0x00200000));
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    78
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    79
+  if (!((__eax ^ __ebx) & 0x00200000))
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    80
+    return 0;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    81
+#endif
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    82
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    83
+  /* Host supports cpuid.  Return highest supported cpuid input value.  */
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    84
+  _my_cpuid (__ext, __eax, __ebx, __ecx, __edx);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    85
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    86
+  if (__sig)
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    87
+    *__sig = __ebx;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    88
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    89
+  return __eax;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    90
+}
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    91
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    92
 static bool
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    93
 has_cpuid_bit(unsigned int level, CPUIDRegister reg, unsigned int bit)
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    94
 {
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    95
   unsigned int regs[4];
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    96
-  return __get_cpuid(level, &regs[0], &regs[1], &regs[2], &regs[3]) &&
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    97
-         (regs[reg] & bit);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    98
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
    99
+  unsigned int __ext = level & 0x80000000;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   100
+  if (my_cpuid_max(__ext, 0) < level)
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   101
+    return false;
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   102
+
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   103
+  _my_cpuid(level, regs[0], regs[1], regs[2], regs[3]);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   104
+  return !!(unsigned(regs[reg]) & bit);
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   105
 }
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   106
 
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   107
 #elif defined(_MSC_VER) && _MSC_VER >= 1400 && (defined(_M_IX86) || defined(_M_AMD64))
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   108
 
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   109
 // MSVC 2005 or newer on x86-32 or x86-64
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   110
 #include <intrin.h>
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   111
 
0287f70d86e9 SLE11 compatibility:
Wolfgang Rosenauer <wr@rosenauer.org>
parents:
diff changeset
   112
 enum CPUIDRegister { eax = 0, ebx = 1, ecx = 2, edx = 3 };