From 831af41ae4ea718e255b7f857df7a49e4fb2eb06 Mon Sep 17 00:00:00 2001 From: David Craven Date: Thu, 26 Jul 2018 19:30:26 +0200 Subject: [PATCH] Implement __mulsi3. --- library/compiler-builtins/src/lib.rs | 3 +++ library/compiler-builtins/src/riscv32.rs | 17 +++++++++++++++++ 2 files changed, 20 insertions(+) create mode 100644 library/compiler-builtins/src/riscv32.rs diff --git a/library/compiler-builtins/src/lib.rs b/library/compiler-builtins/src/lib.rs index 02b6c7db953a..9f1dd15120c0 100644 --- a/library/compiler-builtins/src/lib.rs +++ b/library/compiler-builtins/src/lib.rs @@ -58,6 +58,9 @@ pub mod arm; #[cfg(all(kernel_user_helpers, target_os = "linux", target_arch = "arm"))] pub mod arm_linux; +#[cfg(any(target_arch = "riscv32"))] +pub mod riscv32; + #[cfg(target_arch = "x86")] pub mod x86; diff --git a/library/compiler-builtins/src/riscv32.rs b/library/compiler-builtins/src/riscv32.rs new file mode 100644 index 000000000000..ebaa354a4b30 --- /dev/null +++ b/library/compiler-builtins/src/riscv32.rs @@ -0,0 +1,17 @@ +intrinsics! { + // Implementation from gcc + // https://raw.githubusercontent.com/gcc-mirror/gcc/master/libgcc/config/epiphany/mulsi3.c + pub extern "C" fn __mulsi3(mut a: u32, mut b: u32) -> u32 { + let mut r: usize = 0; + + while a > 0 { + if a & 1 > 0 { + r += b; + } + a >>= 1; + b <<= 1; + } + + r + } +}