diff options
author | V3n3RiX <venerix@koprulu.sector> | 2022-11-24 13:10:40 +0000 |
---|---|---|
committer | V3n3RiX <venerix@koprulu.sector> | 2022-11-24 13:10:40 +0000 |
commit | c92d0cd2b34d17bce6d5bb4e3a4fc00af4193c99 (patch) | |
tree | 517559f918260cf91e7bdd4e484aa6fe9085cb9f /dev-lang/spidermonkey/files | |
parent | a59ffccce3bf214fae9932cc42400eeeaec25c6c (diff) |
gentoo auto-resync : 24:11:2022 - 13:10:39
Diffstat (limited to 'dev-lang/spidermonkey/files')
-rw-r--r-- | dev-lang/spidermonkey/files/spidermonkey-68.0-add-riscv-support.patch | 107 | ||||
-rw-r--r-- | dev-lang/spidermonkey/files/spidermonkey-68.0-loong-support.patch | 103 |
2 files changed, 0 insertions, 210 deletions
diff --git a/dev-lang/spidermonkey/files/spidermonkey-68.0-add-riscv-support.patch b/dev-lang/spidermonkey/files/spidermonkey-68.0-add-riscv-support.patch deleted file mode 100644 index cc44da805898..000000000000 --- a/dev-lang/spidermonkey/files/spidermonkey-68.0-add-riscv-support.patch +++ /dev/null @@ -1,107 +0,0 @@ -From f144113688168e2bd86d24a48c8d7cdfdb4ccaab Mon Sep 17 00:00:00 2001 -From: Thomas Deutschmann <whissi@gentoo.org> -Date: Fri, 21 May 2021 17:17:45 +0200 -Subject: [PATCH] bmo#1318905: Make SpiderMonkey build on Linux/RISC-V - -Signed-off-by: Thomas Deutschmann <whissi@gentoo.org> ---- - build/moz.configure/init.configure | 3 +++ - js/src/jit/AtomicOperations.h | 2 +- - js/src/jit/shared/AtomicOperations-feeling-lucky-gcc.h | 5 +++++ - mfbt/tests/TestPoisonArea.cpp | 3 +++ - python/mozbuild/mozbuild/configure/constants.py | 2 ++ - .../mozbuild/test/configure/test_toolchain_configure.py | 4 ++++ - 6 files changed, 18 insertions(+), 1 deletion(-) - -diff --git a/build/moz.configure/init.configure b/build/moz.configure/init.configure -index b887153321a..5c275076061 100644 ---- a/build/moz.configure/init.configure -+++ b/build/moz.configure/init.configure -@@ -755,6 +755,9 @@ def split_triplet(triplet, allow_msvc=False): - elif cpu.startswith('aarch64'): - canonical_cpu = 'aarch64' - endianness = 'little' -+ elif cpu in ('riscv64', 'riscv64gc'): -+ canonical_cpu = 'riscv64' -+ endianness = 'little' - elif cpu == 'sh4': - canonical_cpu = 'sh4' - endianness = 'little' -diff --git a/js/src/jit/AtomicOperations.h b/js/src/jit/AtomicOperations.h -index 0f45ac8b58e..f48d2adce97 100644 ---- a/js/src/jit/AtomicOperations.h -+++ b/js/src/jit/AtomicOperations.h -@@ -392,7 +392,7 @@ inline bool AtomicOperations::isLockfreeJS(int32_t size) { - defined(__ppc64__) || defined(__PPC64__) || defined(__ppc64le__) || \ - defined(__PPC64LE__) || defined(__alpha__) || defined(__hppa__) || \ - defined(__ia64__) || defined(__sh__) || defined(__s390__) || \ -- defined(__s390x__) -+ defined(__s390x__) || defined(__riscv) - # include "jit/shared/AtomicOperations-feeling-lucky.h" - #else - # error "No AtomicOperations support provided for this platform" -diff --git a/js/src/jit/shared/AtomicOperations-feeling-lucky-gcc.h b/js/src/jit/shared/AtomicOperations-feeling-lucky-gcc.h -index f002cd46c93..1ce40efaccc 100644 ---- a/js/src/jit/shared/AtomicOperations-feeling-lucky-gcc.h -+++ b/js/src/jit/shared/AtomicOperations-feeling-lucky-gcc.h -@@ -63,6 +63,11 @@ - # define HAS_64BIT_LOCKFREE - #endif - -+#if defined(__riscv) && __riscv_xlen == 64 -+# define HAS_64BIT_ATOMICS -+# define HAS_64BIT_LOCKFREE -+#endif -+ - #ifdef __sparc__ - # ifdef __LP64__ - # define HAS_64BIT_ATOMICS -diff --git a/mfbt/tests/TestPoisonArea.cpp b/mfbt/tests/TestPoisonArea.cpp -index fbd33647150..9d2ffa498b7 100644 ---- a/mfbt/tests/TestPoisonArea.cpp -+++ b/mfbt/tests/TestPoisonArea.cpp -@@ -132,6 +132,9 @@ - #elif defined _ARCH_PPC || defined _ARCH_PWR || defined _ARCH_PWR2 - # define RETURN_INSTR 0x4E800020 /* blr */ - -+#elif defined __riscv -+# define RETURN_INSTR 0x80828082 /* ret; ret */ -+ - #elif defined __sparc || defined __sparcv9 - # define RETURN_INSTR 0x81c3e008 /* retl */ - -diff --git a/python/mozbuild/mozbuild/configure/constants.py b/python/mozbuild/mozbuild/configure/constants.py -index 7542dcdc636..49ef3b857db 100644 ---- a/python/mozbuild/mozbuild/configure/constants.py -+++ b/python/mozbuild/mozbuild/configure/constants.py -@@ -49,6 +49,7 @@ - 'mips64': 64, - 'ppc': 32, - 'ppc64': 64, -+ 'riscv64': 64, - 's390': 32, - 's390x': 64, - 'sh4': 32, -@@ -87,6 +88,7 @@ - ('sparc', '__sparc__'), - ('mips64', '__mips64'), - ('mips32', '__mips__'), -+ ('riscv64', '__riscv && __riscv_xlen == 64'), - ('sh4', '__sh__'), - )) - -diff --git a/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py b/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py -index 37c4e26f0fb..5d3d5891dca 100755 ---- a/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py -+++ b/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py -@@ -1208,6 +1208,10 @@ class LinuxCrossCompileToolchainTest(BaseToolchainTest): - 'mips-unknown-linux-gnu': big_endian + { - '__mips__': 1, - }, -+ 'riscv64-unknown-linux-gnu': little_endian + { -+ '__riscv': 1, -+ '__riscv_xlen': 64, -+ }, - 'sh4-unknown-linux-gnu': little_endian + { - '__sh__': 1, - }, diff --git a/dev-lang/spidermonkey/files/spidermonkey-68.0-loong-support.patch b/dev-lang/spidermonkey/files/spidermonkey-68.0-loong-support.patch deleted file mode 100644 index f7010d5ebf32..000000000000 --- a/dev-lang/spidermonkey/files/spidermonkey-68.0-loong-support.patch +++ /dev/null @@ -1,103 +0,0 @@ -https://raw.githubusercontent.com/xen0n/loongson-overlay/00901fd4c599ec320c7852cbd30b40d3f6aa8971/dev-lang/spidermonkey/files/spidermonkey-68.0-add-loongarch64-support.patch - ---- a/build/moz.configure/init.configure -+++ b/build/moz.configure/init.configure -@@ -734,6 +734,9 @@ def split_triplet(triplet, allow_unknown - elif cpu == 'sh4': - canonical_cpu = 'sh4' - endianness = 'little' -+ elif cpu == 'loongarch64': -+ canonical_cpu = 'loongarch64' -+ endianness = 'little' - elif allow_unknown: - canonical_cpu = cpu - endianness = 'unknown' ---- a/js/src/jit/AtomicOperations.h -+++ b/js/src/jit/AtomicOperations.h -@@ -382,6 +382,9 @@ inline bool AtomicOperations::isLockfree - # else - # include "jit/shared/AtomicOperations-feeling-lucky.h" - # endif -+#elif defined(__loongarch64) -+// This is only here to avoid merge conflict with spidermonkey-68.0-add-riscv-support.patch. -+# include "jit/shared/AtomicOperations-feeling-lucky.h" - #elif defined(__mips__) - # if defined(__clang__) || defined(__GNUC__) - # include "jit/mips-shared/AtomicOperations-mips-shared.h" ---- a/js/src/jit/shared/AtomicOperations-feeling-lucky-gcc.h -+++ b/js/src/jit/shared/AtomicOperations-feeling-lucky-gcc.h -@@ -57,6 +57,11 @@ - # define HAS_64BIT_LOCKFREE - #endif - -+#ifdef __loongarch64 -+# define HAS_64BIT_ATOMICS -+# define HAS_64BIT_LOCKFREE -+#endif -+ - #if defined(__ppc64__) || defined(__PPC64__) || defined(__ppc64le__) || \ - defined(__PPC64LE__) - # define HAS_64BIT_ATOMICS ---- a/mfbt/tests/TestPoisonArea.cpp -+++ b/mfbt/tests/TestPoisonArea.cpp -@@ -127,6 +127,9 @@ - #elif defined __arm__ || defined _M_ARM - # define RETURN_INSTR 0xE12FFF1E /* bx lr */ - -+#elif defined __loongarch__ -+# define RETURN_INSTR 0x4c000020 /* jirl zero, ra, 0 */ -+ - // PPC has its own style of CPU-id #defines. There is no Windows for - // PPC as far as I know, so no _M_ variant. - #elif defined _ARCH_PPC || defined _ARCH_PWR || defined _ARCH_PWR2 ---- a/python/mozbuild/mozbuild/configure/constants.py -+++ b/python/mozbuild/mozbuild/configure/constants.py -@@ -46,6 +46,7 @@ CPU_bitness = { - 'arm': 32, - 'hppa': 32, - 'ia64': 64, -+ 'loongarch64': 64, - 'mips32': 32, - 'mips64': 64, - 'ppc': 32, -@@ -78,6 +79,7 @@ CPU_preprocessor_checks = OrderedDict(( - ('arm', '__arm__ || _M_ARM'), - ('aarch64', '__aarch64__ || _M_ARM64'), - ('ia64', '__ia64__'), -+ ('loongarch64', '__loongarch64'), - ('s390x', '__s390x__'), - ('s390', '__s390__'), - ('ppc64', '__powerpc64__'), ---- a/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py -+++ b/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py -@@ -1068,6 +1068,10 @@ class LinuxCrossCompileToolchainTest(Bas - 'ia64-unknown-linux-gnu': little_endian + { - '__ia64__': 1, - }, -+ 'loongarch64-unknown-linux-gnu': little_endian + { -+ '__loongarch__': 1, -+ '__loongarch64': 1, -+ }, - 's390x-unknown-linux-gnu': big_endian + { - '__s390x__': 1, - '__s390__': 1, ---- a/intl/icu/source/i18n/double-conversion-utils.h -+++ b/intl/icu/source/i18n/double-conversion-utils.h -@@ -117,6 +117,7 @@ int main(int argc, char** argv) { - #if defined(_M_X64) || defined(__x86_64__) || \ - defined(__ARMEL__) || defined(__avr32__) || defined(_M_ARM) || defined(_M_ARM64) || \ - defined(__hppa__) || defined(__ia64__) || \ -+ defined(__loongarch__) || \ - defined(__mips__) || \ - defined(__nios2__) || defined(__ghs) || \ - defined(__powerpc__) || defined(__ppc__) || defined(__ppc64__) || \ ---- a/mfbt/double-conversion/double-conversion/utils.h -+++ b/mfbt/double-conversion/double-conversion/utils.h -@@ -117,6 +117,7 @@ int main(int argc, char** argv) { - #if defined(_M_X64) || defined(__x86_64__) || \ - defined(__ARMEL__) || defined(__avr32__) || defined(_M_ARM) || defined(_M_ARM64) || \ - defined(__hppa__) || defined(__ia64__) || \ -+ defined(__loongarch__) || \ - defined(__mips__) || \ - defined(__nios2__) || defined(__ghs) || \ - defined(__powerpc__) || defined(__ppc__) || defined(__ppc64__) || \ |