fix unsafe warnings
This commit is contained in:
parent
fd69beba29
commit
c82403551d
|
@ -25,7 +25,4 @@ compiler-rt = { path = "compiler-rt" }
|
||||||
c = []
|
c = []
|
||||||
weak = ["rlibc/weak"]
|
weak = ["rlibc/weak"]
|
||||||
|
|
||||||
[profile.dev]
|
|
||||||
debug-assertions = false
|
|
||||||
|
|
||||||
[workspace]
|
[workspace]
|
||||||
|
|
|
@ -29,13 +29,14 @@ case $1 in
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# Verify that there are no undefined symbols to `panic` within our implementations
|
# Verify that there are no undefined symbols to `panic` within our implementations
|
||||||
|
# TODO(#79) fix the undefined references problem for debug-assertions+lto
|
||||||
case $1 in
|
case $1 in
|
||||||
thumb*)
|
thumb*)
|
||||||
xargo rustc --features c --target $1 --bin intrinsics -- -C lto
|
RUSTFLAGS="-C debug-assertions=no" xargo rustc --features c --target $1 --bin intrinsics -- -C lto
|
||||||
xargo rustc --features c --target $1 --bin intrinsics --release -- -C lto
|
xargo rustc --features c --target $1 --bin intrinsics --release -- -C lto
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
cargo rustc --features c --target $1 --bin intrinsics -- -C lto
|
RUSTFLAGS="-C debug-assertions=no" cargo rustc --features c --target $1 --bin intrinsics -- -C lto
|
||||||
cargo rustc --features c --target $1 --bin intrinsics --release -- -C lto
|
cargo rustc --features c --target $1 --bin intrinsics --release -- -C lto
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
|
@ -308,11 +308,9 @@ fn run() {
|
||||||
// We use volatile load/stores to prevent LLVM from optimizing away the intrinsics during LTO
|
// We use volatile load/stores to prevent LLVM from optimizing away the intrinsics during LTO
|
||||||
macro_rules! arg {
|
macro_rules! arg {
|
||||||
() => {
|
() => {
|
||||||
unsafe {
|
|
||||||
ptr::read_volatile(0x0 as *const _)
|
ptr::read_volatile(0x0 as *const _)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
macro_rules! ret {
|
macro_rules! ret {
|
||||||
($e:expr) => {
|
($e:expr) => {
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
use core::mem;
|
use core::mem;
|
||||||
|
#[cfg(test)]
|
||||||
use core::fmt;
|
use core::fmt;
|
||||||
|
|
||||||
pub mod add;
|
pub mod add;
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
use core::intrinsics;
|
|
||||||
|
|
||||||
macro_rules! pow {
|
macro_rules! pow {
|
||||||
($intrinsic:ident: $fty:ty, $ity:ident) => {
|
($intrinsic:ident: $fty:ty, $ity:ident) => {
|
||||||
/// Returns `a` raised to the power `b`
|
/// Returns `a` raised to the power `b`
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
use core::intrinsics;
|
|
||||||
|
|
||||||
use int::Int;
|
use int::Int;
|
||||||
|
|
||||||
macro_rules! div {
|
macro_rules! div {
|
||||||
|
@ -13,7 +11,7 @@ macro_rules! div {
|
||||||
let b = (b ^ s_b) - s_b;
|
let b = (b ^ s_b) - s_b;
|
||||||
let s = s_a ^ s_b;
|
let s = s_a ^ s_b;
|
||||||
|
|
||||||
let r = udiv!((a as $uty), (b as $uty));
|
let r = udiv!(a as $uty, b as $uty);
|
||||||
(r as $ty ^ s) - s
|
(r as $ty ^ s) - s
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,7 +27,7 @@ macro_rules! mod_ {
|
||||||
let s = a >> (<$ty>::bits() - 1);
|
let s = a >> (<$ty>::bits() - 1);
|
||||||
let a = (a ^ s) - s;
|
let a = (a ^ s) - s;
|
||||||
|
|
||||||
let r = urem!((a as $uty), (b as $uty));
|
let r = urem!(a as $uty, b as $uty);
|
||||||
(r as $ty ^ s) - s
|
(r as $ty ^ s) - s
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
17
src/lib.rs
17
src/lib.rs
|
@ -13,6 +13,7 @@
|
||||||
// NOTE cfg(all(feature = "c", ..)) indicate that compiler-rt provides an arch optimized
|
// NOTE cfg(all(feature = "c", ..)) indicate that compiler-rt provides an arch optimized
|
||||||
// implementation of that intrinsic and we'll prefer to use that
|
// implementation of that intrinsic and we'll prefer to use that
|
||||||
|
|
||||||
|
// TODO(rust-lang/rust#37029) use e.g. checked_div(_).unwrap_or_else(|| abort())
|
||||||
macro_rules! udiv {
|
macro_rules! udiv {
|
||||||
($a:expr, $b:expr) => {
|
($a:expr, $b:expr) => {
|
||||||
unsafe {
|
unsafe {
|
||||||
|
@ -20,9 +21,9 @@ macro_rules! udiv {
|
||||||
let b = $b;
|
let b = $b;
|
||||||
|
|
||||||
if b == 0 {
|
if b == 0 {
|
||||||
intrinsics::abort()
|
::core::intrinsics::abort()
|
||||||
} else {
|
} else {
|
||||||
intrinsics::unchecked_div(a, b)
|
::core::intrinsics::unchecked_div(a, b)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -35,9 +36,9 @@ macro_rules! sdiv {
|
||||||
let b = $b;
|
let b = $b;
|
||||||
|
|
||||||
if b == 0 || (b == -1 && a == $sty::min_value()) {
|
if b == 0 || (b == -1 && a == $sty::min_value()) {
|
||||||
intrinsics::abort()
|
::core::intrinsics::abort()
|
||||||
} else {
|
} else {
|
||||||
intrinsics::unchecked_div(a, b)
|
::core::intrinsics::unchecked_div(a, b)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,9 +51,9 @@ macro_rules! urem {
|
||||||
let b = $b;
|
let b = $b;
|
||||||
|
|
||||||
if b == 0 {
|
if b == 0 {
|
||||||
intrinsics::abort()
|
::core::intrinsics::abort()
|
||||||
} else {
|
} else {
|
||||||
intrinsics::unchecked_rem(a, b)
|
::core::intrinsics::unchecked_rem(a, b)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -65,9 +66,9 @@ macro_rules! srem {
|
||||||
let b = $b;
|
let b = $b;
|
||||||
|
|
||||||
if b == 0 || (b == -1 && a == $sty::min_value()) {
|
if b == 0 || (b == -1 && a == $sty::min_value()) {
|
||||||
intrinsics::abort()
|
::core::intrinsics::abort()
|
||||||
} else {
|
} else {
|
||||||
intrinsics::unchecked_rem(a, b)
|
::core::intrinsics::unchecked_rem(a, b)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue