Add __floatdisf and __floatundisf intrinsics

This commit is contained in:
Thomas Winwood 2017-12-09 18:40:36 +00:00
parent 0633d73c55
commit 92b259c3ad
2 changed files with 22 additions and 2 deletions

View File

@ -150,11 +150,11 @@ features = ["c"]
- [x] fixunssfdi.c - [x] fixunssfdi.c
- [x] fixunssfsi.c - [x] fixunssfsi.c
- [x] floatdidf.c - [x] floatdidf.c
- [ ] floatdisf.c - [x] floatdisf.c
- [x] floatsidf.c - [x] floatsidf.c
- [x] floatsisf.c - [x] floatsisf.c
- [x] floatundidf.c - [x] floatundidf.c
- [ ] floatundisf.c - [x] floatundisf.c
- [x] floatunsidf.c - [x] floatunsidf.c
- [x] floatunsisf.c - [x] floatunsisf.c
- [ ] i386/ashldi3.S - [ ] i386/ashldi3.S

View File

@ -80,6 +80,18 @@ intrinsics! {
int_to_float!(i, i32, f64) int_to_float!(i, i32, f64)
} }
#[use_c_shim_if(all(target_arch = "x86", not(target_env = "msvc")))]
#[arm_aeabi_alias = __aeabi_l2f]
pub extern "C" fn __floatdisf(i: i64) -> f32 {
// On x86_64 LLVM will use native instructions for this conversion, we
// can just do it directly
if cfg!(target_arch = "x86_64") {
i as f32
} else {
int_to_float!(i, i64, f32)
}
}
#[use_c_shim_if(all(target_arch = "x86", not(target_env = "msvc")))] #[use_c_shim_if(all(target_arch = "x86", not(target_env = "msvc")))]
#[arm_aeabi_alias = __aeabi_l2d] #[arm_aeabi_alias = __aeabi_l2d]
pub extern "C" fn __floatdidf(i: i64) -> f64 { pub extern "C" fn __floatdidf(i: i64) -> f64 {
@ -112,6 +124,14 @@ intrinsics! {
int_to_float!(i, u32, f64) int_to_float!(i, u32, f64)
} }
#[use_c_shim_if(all(not(target_env = "msvc"),
any(target_arch = "x86",
all(not(windows), target_arch = "x86_64"))))]
#[arm_aeabi_alias = __aeabi_ul2f]
pub extern "C" fn __floatundisf(i: u64) -> f32 {
int_to_float!(i, u64, f32)
}
#[use_c_shim_if(all(not(target_env = "msvc"), #[use_c_shim_if(all(not(target_env = "msvc"),
any(target_arch = "x86", any(target_arch = "x86",
all(not(windows), target_arch = "x86_64"))))] all(not(windows), target_arch = "x86_64"))))]