summaryrefslogtreecommitdiff
path: root/devel/xulrunner192/patches/patch-bb
blob: 036a63f092ef84a8a5ee66c4441168ffe2b46dcf (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
$NetBSD: patch-bb,v 1.1.1.1 2011/04/19 11:16:08 tnn Exp $

# make sure the inline assembler code works on the same word size as
# the C/C++ code on sparc64 when compiling for 64bit
# https://bugzilla.mozilla.org/show_bug.cgi?id=550271

--- js/src/jslock.cpp.orig	2010-02-27 02:32:31.000000000 +0000
+++ js/src/jslock.cpp
@@ -159,6 +159,7 @@ NativeCompareAndSwap(jsword *w, jsword o
 {
     unsigned int res;
 
+#if JS_BITS_PER_WORD == 32
     __asm__ __volatile__ (
                   "stbar\n"
                   "cas [%1],%2,%3\n"
@@ -169,6 +170,18 @@ NativeCompareAndSwap(jsword *w, jsword o
                   "1:"
                   : "=r" (res)
                   : "r" (w), "r" (ov), "r" (nv));
+#else
+    __asm__ __volatile__ (
+                  "stbar\n"
+                  "casx [%1],%2,%3\n"
+                  "cmp %2,%3\n"
+                  "be,a 1f\n"
+                  "mov 1,%0\n"
+                  "mov 0,%0\n"
+                  "1:"
+                  : "=r" (res)
+                  : "r" (w), "r" (ov), "r" (nv));
+#endif
     return (int)res;
 }