Add __floatdisf and __floatundisf intrinsics
This commit is contained in:
parent
0633d73c55
commit
92b259c3ad
|
@ -150,11 +150,11 @@ features = ["c"]
|
|||
- [x] fixunssfdi.c
|
||||
- [x] fixunssfsi.c
|
||||
- [x] floatdidf.c
|
||||
- [ ] floatdisf.c
|
||||
- [x] floatdisf.c
|
||||
- [x] floatsidf.c
|
||||
- [x] floatsisf.c
|
||||
- [x] floatundidf.c
|
||||
- [ ] floatundisf.c
|
||||
- [x] floatundisf.c
|
||||
- [x] floatunsidf.c
|
||||
- [x] floatunsisf.c
|
||||
- [ ] i386/ashldi3.S
|
||||
|
|
|
@ -80,6 +80,18 @@ intrinsics! {
|
|||
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")))]
|
||||
#[arm_aeabi_alias = __aeabi_l2d]
|
||||
pub extern "C" fn __floatdidf(i: i64) -> f64 {
|
||||
|
@ -112,6 +124,14 @@ intrinsics! {
|
|||
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"),
|
||||
any(target_arch = "x86",
|
||||
all(not(windows), target_arch = "x86_64"))))]
|
||||
|
|
Loading…
Reference in New Issue