Patch that allows xulrunner (for firefox 3.6) build further.
svn path=/nixpkgs/branches/stdenv-updates/; revision=23582
This commit is contained in:
parent
cd8cd01bad
commit
c700d8c5ee
2 changed files with 208 additions and 1 deletions
|
@ -48,7 +48,7 @@ rec {
|
|||
|
||||
# To be removed when the change gets upstream. I don't know if the patch
|
||||
# affects xulrunner or firefox.
|
||||
patches = [ ./symlinks-bug551152.patch ];
|
||||
patches = [ ./symlinks-bug551152.patch ./xulrunner-chromium-mips.patch ];
|
||||
|
||||
buildInputs =
|
||||
[ pkgconfig gtk perl zip libIDL libjpeg libpng zlib cairo bzip2
|
||||
|
|
|
@ -0,0 +1,207 @@
|
|||
http://gentoo-overlays.zugaina.org/loongson/portage/net-libs/xulrunner/files/xulrunner-chromium-mips.patch
|
||||
|
||||
diff --git a/ipc/chromium/src/base/atomicops.h b/ipc/chromium/src/base/atomicops.h
|
||||
index 87df918..363bf63 100644
|
||||
--- a/ipc/chromium/src/base/atomicops.h
|
||||
+++ b/ipc/chromium/src/base/atomicops.h
|
||||
@@ -132,6 +132,8 @@ Atomic64 Release_Load(volatile const Atomic64* ptr);
|
||||
#include "base/atomicops_internals_x86_gcc.h"
|
||||
#elif defined(COMPILER_GCC) && defined(ARCH_CPU_ARM_FAMILY)
|
||||
#include "base/atomicops_internals_arm_gcc.h"
|
||||
+#elif defined(COMPILER_GCC) && defined(ARCH_CPU_MIPS_FAMILY)
|
||||
+#include "base/atomicops_internals_mips_gcc.h"
|
||||
#else
|
||||
#error "Atomic operations are not supported on your platform"
|
||||
#endif
|
||||
diff --git a/ipc/chromium/src/base/atomicops_internals_mips_gcc.h b/ipc/chromium/src/base/atomicops_internals_mips_gcc.h
|
||||
new file mode 100644
|
||||
index 0000000..d1b87ee
|
||||
--- /dev/null
|
||||
+++ b/ipc/chromium/src/base/atomicops_internals_mips_gcc.h
|
||||
@@ -0,0 +1,160 @@
|
||||
+// Copyright (c) 2010 Zhang, Le <r0bertz@gentoo.org>
|
||||
+// Use of this source code is governed by GPLv2.
|
||||
+
|
||||
+// This file is an internal atomic implementation, use base/atomicops.h instead.
|
||||
+
|
||||
+#ifndef BASE_ATOMICOPS_INTERNALS_MIPS_GCC_H_
|
||||
+#define BASE_ATOMICOPS_INTERNALS_MIPS_GCC_H_
|
||||
+
|
||||
+#define ATOMICOPS_COMPILER_BARRIER() __asm__ __volatile__("" : : : "memory")
|
||||
+
|
||||
+namespace base {
|
||||
+namespace subtle {
|
||||
+
|
||||
+// 32-bit low-level operations on any platform.
|
||||
+
|
||||
+inline Atomic32 NoBarrier_CompareAndSwap(volatile Atomic32* ptr,
|
||||
+ Atomic32 old_value,
|
||||
+ Atomic32 new_value) {
|
||||
+ Atomic32 prev;
|
||||
+ __asm__ __volatile__(
|
||||
+ " .set push \n"
|
||||
+ " .set noat \n"
|
||||
+ " .set mips3 \n"
|
||||
+ "1: ll %0, %2 \n"
|
||||
+ " bne %0, %z3, 2f \n"
|
||||
+ " .set mips0 \n"
|
||||
+ " move $1, %z4 \n"
|
||||
+ " .set mips3 \n"
|
||||
+ " sc $1, %1 \n"
|
||||
+ " beqz $1, 3f \n"
|
||||
+ "2: \n"
|
||||
+ " .subsection 2 \n"
|
||||
+ "3: b 1b \n"
|
||||
+ " .previous \n"
|
||||
+ " .set pop \n"
|
||||
+ : "=&r" (prev), "=R" (*ptr)
|
||||
+ : "R" (*ptr), "Jr" (old_value), "Jr" (new_value)
|
||||
+ : "memory");
|
||||
+ return prev;
|
||||
+}
|
||||
+
|
||||
+inline Atomic32 NoBarrier_AtomicExchange(volatile Atomic32* ptr,
|
||||
+ Atomic32 new_value) {
|
||||
+ unsigned int ret_value;
|
||||
+ unsigned long dummy;
|
||||
+
|
||||
+ __asm__ __volatile__(" .set mips3 \n"
|
||||
+ "1: ll %0, %3 # xchg_u32 \n"
|
||||
+ " .set mips0 \n"
|
||||
+ " move %2, %z4 \n"
|
||||
+ " .set mips3 \n"
|
||||
+ " sc %2, %1 \n"
|
||||
+ " beqz %2, 2f \n"
|
||||
+ " .subsection 2 \n"
|
||||
+ "2: b 1b \n"
|
||||
+ " .previous \n"
|
||||
+ " .set mips0 \n"
|
||||
+ : "=&r" (ret_value), "=m" (*ptr), "=&r" (dummy)
|
||||
+ : "R" (*ptr), "Jr" (new_value)
|
||||
+ : "memory");
|
||||
+
|
||||
+ return ret_value; // Now it's the previous value.
|
||||
+}
|
||||
+
|
||||
+inline Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr,
|
||||
+ Atomic32 increment) {
|
||||
+ Atomic32 temp, result;
|
||||
+ __asm__ __volatile__(
|
||||
+ " .set mips3 \n"
|
||||
+ "1: ll %1, %2 # atomic_add_return \n"
|
||||
+ " addu %0, %1, %3 \n"
|
||||
+ " sc %0, %2 \n"
|
||||
+ " beqz %0, 2f \n"
|
||||
+ " addu %0, %1, %3 \n"
|
||||
+ " .subsection 2 \n"
|
||||
+ "2: b 1b \n"
|
||||
+ " .previous \n"
|
||||
+ " .set mips0 \n"
|
||||
+ : "=&r" (result), "=&r" (temp), "=m" (*ptr)
|
||||
+ : "Ir" (increment), "m" (*ptr)
|
||||
+ : "memory");
|
||||
+ return result;
|
||||
+}
|
||||
+
|
||||
+inline Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr,
|
||||
+ Atomic32 increment) {
|
||||
+ Atomic32 temp, result;
|
||||
+ __asm__ __volatile__(
|
||||
+ " .set mips3 \n"
|
||||
+ "1: ll %1, %2 # atomic_add_return \n"
|
||||
+ " addu %0, %1, %3 \n"
|
||||
+ " sc %0, %2 \n"
|
||||
+ " beqz %0, 2f \n"
|
||||
+ " addu %0, %1, %3 \n"
|
||||
+ " .subsection 2 \n"
|
||||
+ "2: b 1b \n"
|
||||
+ " .previous \n"
|
||||
+ " .set mips0 \n"
|
||||
+ : "=&r" (result), "=&r" (temp), "=m" (*ptr)
|
||||
+ : "Ir" (increment), "m" (*ptr)
|
||||
+ : "memory");
|
||||
+ __asm__ __volatile__("sync" : : : "memory");
|
||||
+ return result;
|
||||
+}
|
||||
+
|
||||
+inline Atomic32 Acquire_CompareAndSwap(volatile Atomic32* ptr,
|
||||
+ Atomic32 old_value,
|
||||
+ Atomic32 new_value) {
|
||||
+ Atomic32 x = NoBarrier_CompareAndSwap(ptr, old_value, new_value);
|
||||
+ __asm__ __volatile__("sync" : : : "memory");
|
||||
+ return x;
|
||||
+}
|
||||
+
|
||||
+inline Atomic32 Release_CompareAndSwap(volatile Atomic32* ptr,
|
||||
+ Atomic32 old_value,
|
||||
+ Atomic32 new_value) {
|
||||
+ return NoBarrier_CompareAndSwap(ptr, old_value, new_value);
|
||||
+}
|
||||
+
|
||||
+inline void NoBarrier_Store(volatile Atomic32* ptr, Atomic32 value) {
|
||||
+ *ptr = value;
|
||||
+}
|
||||
+
|
||||
+inline void MemoryBarrier() {
|
||||
+ __asm__ __volatile__("sync" : : : "memory");
|
||||
+}
|
||||
+
|
||||
+inline void Acquire_Store(volatile Atomic32* ptr, Atomic32 value) {
|
||||
+ *ptr = value;
|
||||
+ __asm__ __volatile__("sync" : : : "memory");
|
||||
+}
|
||||
+
|
||||
+inline void Release_Store(volatile Atomic32* ptr, Atomic32 value) {
|
||||
+ ATOMICOPS_COMPILER_BARRIER();
|
||||
+ *ptr = value; // An x86 store acts as a release barrier.
|
||||
+ // See comments in Atomic64 version of Release_Store(), below.
|
||||
+}
|
||||
+
|
||||
+inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) {
|
||||
+ return *ptr;
|
||||
+}
|
||||
+
|
||||
+inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) {
|
||||
+ Atomic32 value = *ptr; // An x86 load acts as a acquire barrier.
|
||||
+ // See comments in Atomic64 version of Release_Store(), below.
|
||||
+ ATOMICOPS_COMPILER_BARRIER();
|
||||
+ return value;
|
||||
+}
|
||||
+
|
||||
+inline Atomic32 Release_Load(volatile const Atomic32* ptr) {
|
||||
+ MemoryBarrier();
|
||||
+ return *ptr;
|
||||
+}
|
||||
+
|
||||
+} // namespace base::subtle
|
||||
+} // namespace base
|
||||
+
|
||||
+#undef ATOMICOPS_COMPILER_BARRIER
|
||||
+
|
||||
+#endif // BASE_ATOMICOPS_INTERNALS_MIPS_GCC_H_
|
||||
diff --git a/ipc/chromium/src/base/debug_util_posix.cc b/ipc/chromium/src/base/debug_util_posix.cc
|
||||
index f7c58b4..50fb41d 100644
|
||||
--- a/ipc/chromium/src/base/debug_util_posix.cc
|
||||
+++ b/ipc/chromium/src/base/debug_util_posix.cc
|
||||
@@ -108,7 +108,7 @@ bool DebugUtil::BeingDebugged() {
|
||||
|
||||
// static
|
||||
void DebugUtil::BreakDebugger() {
|
||||
-#if !defined(ARCH_CPU_ARM_FAMILY)
|
||||
+#if !defined(ARCH_CPU_ARM_FAMILY) && !defined(ARCH_CPU_MIPS_FAMILY)
|
||||
asm ("int3");
|
||||
#endif
|
||||
}
|
||||
diff --git a/ipc/chromium/src/build/build_config.h b/ipc/chromium/src/build/build_config.h
|
||||
index 36f83e7..128bbc7 100644
|
||||
--- a/ipc/chromium/src/build/build_config.h
|
||||
+++ b/ipc/chromium/src/build/build_config.h
|
||||
@@ -57,6 +57,8 @@
|
||||
#define ARCH_CPU_ARMEL 1
|
||||
#define ARCH_CPU_32_BITS 1
|
||||
#define WCHAR_T_IS_UNSIGNED 1
|
||||
+#elif defined(__MIPSEL__)
|
||||
+#define ARCH_CPU_MIPS_FAMILY 1
|
||||
#else
|
||||
#error Please add support for your architecture in build/build_config.h
|
||||
#endif
|
Loading…
Reference in a new issue