Merge pull request #558 from Patryk27/fix_avr_floats_v2.0

This commit is contained in:
Amanieu d'Antras 2023-11-28 07:10:52 +00:00 committed by GitHub
commit 7b57d3855a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 10 additions and 0 deletions

View file

@ -902,11 +902,13 @@ where
}
intrinsics! {
#[avr_skip]
#[arm_aeabi_alias = __aeabi_fdiv]
pub extern "C" fn __divsf3(a: f32, b: f32) -> f32 {
div32(a, b)
}
#[avr_skip]
#[arm_aeabi_alias = __aeabi_ddiv]
pub extern "C" fn __divdf3(a: f64, b: f64) -> f64 {
div64(a, b)

View file

@ -70,6 +70,7 @@ where
}
intrinsics! {
#[avr_skip]
#[aapcs_on_arm]
#[arm_aeabi_alias = __aeabi_f2d]
pub extern "C" fn __extendsfdf2(a: f32) -> f64 {

View file

@ -185,12 +185,14 @@ where
}
intrinsics! {
#[avr_skip]
#[aapcs_on_arm]
#[arm_aeabi_alias = __aeabi_fmul]
pub extern "C" fn __mulsf3(a: f32, b: f32) -> f32 {
mul(a, b)
}
#[avr_skip]
#[aapcs_on_arm]
#[arm_aeabi_alias = __aeabi_dmul]
pub extern "C" fn __muldf3(a: f64, b: f64) -> f64 {

View file

@ -26,10 +26,12 @@ fn pow<F: Float>(a: F, b: i32) -> F {
}
intrinsics! {
#[avr_skip]
pub extern "C" fn __powisf2(a: f32, b: i32) -> f32 {
pow(a, b)
}
#[avr_skip]
pub extern "C" fn __powidf2(a: f64, b: i32) -> f64 {
pow(a, b)
}

View file

@ -3,11 +3,13 @@ use crate::float::add::__addsf3;
use crate::float::Float;
intrinsics! {
#[avr_skip]
#[arm_aeabi_alias = __aeabi_fsub]
pub extern "C" fn __subsf3(a: f32, b: f32) -> f32 {
__addsf3(a, f32::from_repr(b.repr() ^ f32::SIGN_MASK))
}
#[avr_skip]
#[arm_aeabi_alias = __aeabi_dsub]
pub extern "C" fn __subdf3(a: f64, b: f64) -> f64 {
__adddf3(a, f64::from_repr(b.repr() ^ f64::SIGN_MASK))

View file

@ -112,6 +112,7 @@ where
}
intrinsics! {
#[avr_skip]
#[aapcs_on_arm]
#[arm_aeabi_alias = __aeabi_d2f]
pub extern "C" fn __truncdfsf2(a: f64) -> f32 {