committed by
Chih-Min Chao
8 changed files with 266 additions and 0 deletions
@ -0,0 +1,36 @@ |
|||
|
|||
#include <stdbool.h> |
|||
#include <stdint.h> |
|||
#include "platform.h" |
|||
#include "internals.h" |
|||
#include "specialize.h" |
|||
#include "softfloat.h" |
|||
|
|||
uint_fast16_t f16_classify( float16_t a ) |
|||
{ |
|||
union ui16_f16 uA; |
|||
uint_fast16_t uiA; |
|||
|
|||
uA.f = a; |
|||
uiA = uA.ui; |
|||
|
|||
uint_fast16_t infOrNaN = expF16UI( uiA ) == 0x1F; |
|||
uint_fast16_t subnormalOrZero = expF16UI( uiA ) == 0; |
|||
bool sign = signF16UI( uiA ); |
|||
bool fracZero = fracF16UI( uiA ) == 0; |
|||
bool isNaN = isNaNF16UI( uiA ); |
|||
bool isSNaN = softfloat_isSigNaNF16UI( uiA ); |
|||
|
|||
return |
|||
( sign && infOrNaN && fracZero ) << 0 | |
|||
( sign && !infOrNaN && !subnormalOrZero ) << 1 | |
|||
( sign && subnormalOrZero && !fracZero ) << 2 | |
|||
( sign && subnormalOrZero && fracZero ) << 3 | |
|||
( !sign && infOrNaN && fracZero ) << 7 | |
|||
( !sign && !infOrNaN && !subnormalOrZero ) << 6 | |
|||
( !sign && subnormalOrZero && !fracZero ) << 5 | |
|||
( !sign && subnormalOrZero && fracZero ) << 4 | |
|||
( isNaN && isSNaN ) << 8 | |
|||
( isNaN && !isSNaN ) << 9; |
|||
} |
|||
|
|||
@ -0,0 +1,55 @@ |
|||
|
|||
/*============================================================================
|
|||
|
|||
This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic |
|||
Package, Release 3d, by John R. Hauser. |
|||
|
|||
Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the |
|||
University of California. All rights reserved. |
|||
|
|||
Redistribution and use in source and binary forms, with or without |
|||
modification, are permitted provided that the following conditions are met: |
|||
|
|||
1. Redistributions of source code must retain the above copyright notice, |
|||
this list of conditions, and the following disclaimer. |
|||
|
|||
2. Redistributions in binary form must reproduce the above copyright notice, |
|||
this list of conditions, and the following disclaimer in the documentation |
|||
and/or other materials provided with the distribution. |
|||
|
|||
3. Neither the name of the University nor the names of its contributors may |
|||
be used to endorse or promote products derived from this software without |
|||
specific prior written permission. |
|||
|
|||
THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY |
|||
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
|||
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE |
|||
DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY |
|||
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
|||
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
|||
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
|||
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
|||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
|||
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|||
|
|||
=============================================================================*/ |
|||
|
|||
#include <stdint.h> |
|||
#include "specialize.h" |
|||
#include "softfloat.h" |
|||
|
|||
int_fast16_t f16_to_i16( float16_t a, uint_fast8_t roundingMode, bool exact ) |
|||
{ |
|||
int_fast32_t sig32 = f16_to_i32(a, roundingMode, exact); |
|||
|
|||
if (sig32 > INT16_MAX) { |
|||
softfloat_exceptionFlags |= softfloat_flag_invalid; |
|||
return i16_fromPosOverflow; |
|||
} else if (sig32 < INT16_MIN) { |
|||
softfloat_exceptionFlags |= softfloat_flag_invalid; |
|||
return i16_fromNegOverflow; |
|||
} else { |
|||
return sig32; |
|||
} |
|||
} |
|||
|
|||
@ -0,0 +1,52 @@ |
|||
|
|||
/*============================================================================
|
|||
|
|||
This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic |
|||
Package, Release 3d, by John R. Hauser. |
|||
|
|||
Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the |
|||
University of California. All rights reserved. |
|||
|
|||
Redistribution and use in source and binary forms, with or without |
|||
modification, are permitted provided that the following conditions are met: |
|||
|
|||
1. Redistributions of source code must retain the above copyright notice, |
|||
this list of conditions, and the following disclaimer. |
|||
|
|||
2. Redistributions in binary form must reproduce the above copyright notice, |
|||
this list of conditions, and the following disclaimer in the documentation |
|||
and/or other materials provided with the distribution. |
|||
|
|||
3. Neither the name of the University nor the names of its contributors may |
|||
be used to endorse or promote products derived from this software without |
|||
specific prior written permission. |
|||
|
|||
THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY |
|||
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
|||
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE |
|||
DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY |
|||
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
|||
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
|||
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
|||
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
|||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
|||
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|||
|
|||
=============================================================================*/ |
|||
|
|||
#include <stdint.h> |
|||
#include "specialize.h" |
|||
#include "softfloat.h" |
|||
|
|||
uint_fast16_t f16_to_ui16( float16_t a, uint_fast8_t roundingMode, bool exact ) |
|||
{ |
|||
uint_fast32_t sig32 = f16_to_ui32(a, roundingMode, exact); |
|||
|
|||
if (sig32 > UINT16_MAX) { |
|||
softfloat_exceptionFlags |= softfloat_flag_invalid; |
|||
return ui16_fromPosOverflow; |
|||
} else { |
|||
return sig32; |
|||
} |
|||
} |
|||
|
|||
@ -0,0 +1,55 @@ |
|||
|
|||
/*============================================================================
|
|||
|
|||
This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic |
|||
Package, Release 3d, by John R. Hauser. |
|||
|
|||
Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the |
|||
University of California. All rights reserved. |
|||
|
|||
Redistribution and use in source and binary forms, with or without |
|||
modification, are permitted provided that the following conditions are met: |
|||
|
|||
1. Redistributions of source code must retain the above copyright notice, |
|||
this list of conditions, and the following disclaimer. |
|||
|
|||
2. Redistributions in binary form must reproduce the above copyright notice, |
|||
this list of conditions, and the following disclaimer in the documentation |
|||
and/or other materials provided with the distribution. |
|||
|
|||
3. Neither the name of the University nor the names of its contributors may |
|||
be used to endorse or promote products derived from this software without |
|||
specific prior written permission. |
|||
|
|||
THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY |
|||
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
|||
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE |
|||
DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY |
|||
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
|||
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
|||
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
|||
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
|||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
|||
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|||
|
|||
=============================================================================*/ |
|||
|
|||
#include <stdint.h> |
|||
#include "specialize.h" |
|||
#include "softfloat.h" |
|||
|
|||
int_fast16_t f32_to_i16( float32_t a, uint_fast8_t roundingMode, bool exact ) |
|||
{ |
|||
int_fast32_t sig32 = f32_to_i32(a, roundingMode, exact); |
|||
|
|||
if (sig32 > INT16_MAX) { |
|||
softfloat_exceptionFlags |= softfloat_flag_invalid; |
|||
return i16_fromPosOverflow; |
|||
} else if (sig32 < INT16_MIN) { |
|||
softfloat_exceptionFlags |= softfloat_flag_invalid; |
|||
return i16_fromNegOverflow; |
|||
} else { |
|||
return sig32; |
|||
} |
|||
} |
|||
|
|||
@ -0,0 +1,51 @@ |
|||
|
|||
/*============================================================================
|
|||
|
|||
This C source file is part of the SoftFloat IEEE Floating-Point Arithmetic |
|||
Package, Release 3d, by John R. Hauser. |
|||
|
|||
Copyright 2011, 2012, 2013, 2014, 2015, 2016, 2017 The Regents of the |
|||
University of California. All rights reserved. |
|||
|
|||
Redistribution and use in source and binary forms, with or without |
|||
modification, are permitted provided that the following conditions are met: |
|||
|
|||
1. Redistributions of source code must retain the above copyright notice, |
|||
this list of conditions, and the following disclaimer. |
|||
|
|||
2. Redistributions in binary form must reproduce the above copyright notice, |
|||
this list of conditions, and the following disclaimer in the documentation |
|||
and/or other materials provided with the distribution. |
|||
|
|||
3. Neither the name of the University nor the names of its contributors may |
|||
be used to endorse or promote products derived from this software without |
|||
specific prior written permission. |
|||
|
|||
THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS "AS IS", AND ANY |
|||
EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
|||
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE |
|||
DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY |
|||
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
|||
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
|||
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND |
|||
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
|||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
|||
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
|||
|
|||
=============================================================================*/ |
|||
|
|||
#include <stdint.h> |
|||
#include "specialize.h" |
|||
#include "softfloat.h" |
|||
|
|||
uint_fast16_t f32_to_ui16( float32_t a, uint_fast8_t roundingMode, bool exact ) |
|||
{ |
|||
uint_fast32_t sig32 = f32_to_ui32(a, roundingMode, exact); |
|||
|
|||
if (sig32 > UINT16_MAX) { |
|||
softfloat_exceptionFlags |= softfloat_flag_invalid; |
|||
return ui16_fromPosOverflow; |
|||
} else { |
|||
return sig32; |
|||
} |
|||
} |
|||
Loading…
Reference in new issue