Blame mozjs17-0001-Add-AArch64-support.patch

15c0732
diff --git a/js/src/assembler/jit/ExecutableAllocator.h b/js/src/assembler/jit/ExecutableAllocator.h
15c0732
index c071c33..90764c3 100644
15c0732
--- a/js/src/assembler/jit/ExecutableAllocator.h
15c0732
+++ b/js/src/assembler/jit/ExecutableAllocator.h
15c0732
@@ -382,6 +382,12 @@ public:
15c0732
     {
15c0732
         reprotectRegion(start, size, Executable);
15c0732
     }
15c0732
+#elif WTF_CPU_AARCH64 && WTF_PLATFORM_LINUX
15c0732
+    static void cacheFlush(void* code, size_t size)
15c0732
+    {
15c0732
+        intptr_t end = reinterpret_cast<intptr_t>(code) + size;
15c0732
+        __builtin___clear_cache(reinterpret_cast<char*>(code), reinterpret_cast<char*>(end));
15c0732
+    }
15c0732
 #else
15c0732
     static void makeWritable(void*, size_t) {}
15c0732
     static void makeExecutable(void*, size_t) {}
15c0732
diff --git a/js/src/assembler/wtf/Platform.h b/js/src/assembler/wtf/Platform.h
15c0732
index 0c84896..e8763a7 100644
15c0732
--- a/js/src/assembler/wtf/Platform.h
15c0732
+++ b/js/src/assembler/wtf/Platform.h
15c0732
@@ -325,6 +325,10 @@
15c0732
 #define WTF_THUMB_ARCH_VERSION 0
15c0732
 #endif
15c0732
 
15c0732
+/* CPU(AArch64) - 64-bit ARM */
15c0732
+#if defined(__aarch64__)
15c0732
+#define WTF_CPU_AARCH64 1
15c0732
+#endif
15c0732
 
15c0732
 /* WTF_CPU_ARMV5_OR_LOWER - ARM instruction set v5 or earlier */
15c0732
 /* On ARMv5 and below the natural alignment is required. 
15c0732
diff --git a/js/src/configure.in b/js/src/configure.in
15c0732
index 15605b2..19fd704 100644
15c0732
--- a/js/src/configure.in
15c0732
+++ b/js/src/configure.in
15c0732
@@ -1121,6 +1121,10 @@ arm*)
15c0732
     CPU_ARCH=arm
15c0732
     ;;
15c0732
 
15c0732
+aarch64)
15c0732
+    CPU_ARCH=aarch64
15c0732
+    ;;
15c0732
+
15c0732
 mips|mipsel)
15c0732
     CPU_ARCH="mips"
15c0732
     ;;
15c0732
diff --git a/mfbt/double-conversion/utils.h b/mfbt/double-conversion/utils.h
15c0732
index 0eec2d9..fe26dab 100644
15c0732
--- a/mfbt/double-conversion/utils.h
15c0732
+++ b/mfbt/double-conversion/utils.h
15c0732
@@ -58,6 +58,7 @@
15c0732
     defined(__mips__) || defined(__powerpc__) || \
15c0732
     defined(__sparc__) || defined(__sparc) || defined(__s390__) || \
15c0732
     defined(__SH4__) || defined(__alpha__) || \
15c0732
+    defined(__aarch64__) || \
15c0732
     defined(_MIPS_ARCH_MIPS32R2)
15c0732
 #define DOUBLE_CONVERSION_CORRECT_DOUBLE_OPERATIONS 1
15c0732
 #elif defined(_M_IX86) || defined(__i386__) || defined(__i386)