2023-09-29 12:46:16 -04:00
|
|
|
From ff5fd2c08a0d6f0b39a9970f3b10e31a46e99383 Mon Sep 17 00:00:00 2001
|
2022-11-15 12:25:32 -05:00
|
|
|
From: Khem Raj <raj.khem@gmail.com>
|
2023-09-29 12:46:16 -04:00
|
|
|
Date: Sun, 24 Oct 2021 22:32:50 -0700
|
2022-11-15 12:25:32 -05:00
|
|
|
Subject: [PATCH] Add RISCV32 support
|
2022-05-28 11:20:07 -04:00
|
|
|
|
|
|
|
Upstream-Status: Pending
|
|
|
|
Signed-off-by: Khem Raj <raj.khem@gmail.com>
|
|
|
|
|
2022-11-15 12:25:32 -05:00
|
|
|
---
|
|
|
|
build/moz.configure/init.configure | 3 +++
|
|
|
|
python/mozbuild/mozbuild/configure/constants.py | 2 ++
|
|
|
|
.../mozbuild/test/configure/test_toolchain_configure.py | 1 +
|
|
|
|
3 files changed, 6 insertions(+)
|
|
|
|
|
|
|
|
diff --git a/build/moz.configure/init.configure b/build/moz.configure/init.configure
|
2023-09-29 12:46:16 -04:00
|
|
|
index 53bbc4203f..2ac40d3d39 100644
|
2022-05-28 11:20:07 -04:00
|
|
|
--- a/build/moz.configure/init.configure
|
|
|
|
+++ b/build/moz.configure/init.configure
|
2023-09-29 12:46:16 -04:00
|
|
|
@@ -584,6 +584,9 @@ def split_triplet(triplet, allow_wasi=False):
|
2022-05-28 11:20:07 -04:00
|
|
|
elif cpu.startswith("aarch64"):
|
|
|
|
canonical_cpu = "aarch64"
|
|
|
|
endianness = "little"
|
|
|
|
+ elif cpu in ("riscv32", "riscv32gc"):
|
|
|
|
+ canonical_cpu = "riscv32"
|
|
|
|
+ endianness = "little"
|
|
|
|
elif cpu in ("riscv64", "riscv64gc"):
|
|
|
|
canonical_cpu = "riscv64"
|
|
|
|
endianness = "little"
|
2022-11-15 12:25:32 -05:00
|
|
|
diff --git a/python/mozbuild/mozbuild/configure/constants.py b/python/mozbuild/mozbuild/configure/constants.py
|
2023-09-29 12:46:16 -04:00
|
|
|
index a36152651d..a6050be5d8 100644
|
2022-05-28 11:20:07 -04:00
|
|
|
--- a/python/mozbuild/mozbuild/configure/constants.py
|
|
|
|
+++ b/python/mozbuild/mozbuild/configure/constants.py
|
2023-09-29 12:46:16 -04:00
|
|
|
@@ -51,6 +51,7 @@ CPU_bitness = {
|
2022-05-28 11:20:07 -04:00
|
|
|
"mips64": 64,
|
|
|
|
"ppc": 32,
|
|
|
|
"ppc64": 64,
|
|
|
|
+ 'riscv32': 32,
|
|
|
|
"riscv64": 64,
|
|
|
|
"s390": 32,
|
|
|
|
"s390x": 64,
|
2023-09-29 12:46:16 -04:00
|
|
|
@@ -98,6 +99,7 @@ CPU_preprocessor_checks = OrderedDict(
|
2022-05-28 11:20:07 -04:00
|
|
|
("m68k", "__m68k__"),
|
|
|
|
("mips64", "__mips64"),
|
|
|
|
("mips32", "__mips__"),
|
|
|
|
+ ("riscv32", "__riscv && __riscv_xlen == 32"),
|
|
|
|
("riscv64", "__riscv && __riscv_xlen == 64"),
|
2022-11-15 12:25:32 -05:00
|
|
|
("loongarch64", "__loongarch64"),
|
2022-05-28 11:20:07 -04:00
|
|
|
("sh4", "__sh__"),
|
2022-11-15 12:25:32 -05:00
|
|
|
diff --git a/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py b/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py
|
2023-09-29 12:46:16 -04:00
|
|
|
index c6af3d99d4..7ef02e1a85 100644
|
2022-05-28 11:20:07 -04:00
|
|
|
--- a/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py
|
|
|
|
+++ b/python/mozbuild/mozbuild/test/configure/test_toolchain_configure.py
|
2023-09-29 12:46:16 -04:00
|
|
|
@@ -1325,6 +1325,7 @@ class LinuxCrossCompileToolchainTest(BaseToolchainTest):
|
2022-05-28 11:20:07 -04:00
|
|
|
"m68k-unknown-linux-gnu": big_endian + {"__m68k__": 1},
|
|
|
|
"mips64-unknown-linux-gnuabi64": big_endian + {"__mips64": 1, "__mips__": 1},
|
|
|
|
"mips-unknown-linux-gnu": big_endian + {"__mips__": 1},
|
|
|
|
+ "riscv32-unknown-linux-gnu": little_endian + {"__riscv": 1, "__riscv_xlen": 32},
|
|
|
|
"riscv64-unknown-linux-gnu": little_endian + {"__riscv": 1, "__riscv_xlen": 64},
|
|
|
|
"sh4-unknown-linux-gnu": little_endian + {"__sh__": 1},
|
|
|
|
}
|