| %include "arm/unopWider.S" {"instr":"bl f2l_doconv"} |
| * Convert the float in r0 to a long in r0/r1. |
| * We have to clip values to long min/max per the specification. The |
| * expected common case is a "reasonable" value that converts directly |
| * to modest integer. The EABI convert function isn't doing this for us. |
| ubfx r2, r0, #23, #8 @ grab the exponent |
| cmp r2, #0xbe @ MININT < x > MAXINT? |
| b __aeabi_f2lz @ tail call to convert float to long |
| cmp r2, #0xff @ NaN or infinity? |
| adds r0, r0, r0 @ sign bit to carry |
| mov r0, #0xffffffff @ assume maxlong for lsw |
| mov r1, #0x7fffffff @ assume maxlong for msw |
| adc r1, r1, #0 @ convert maxlong to minlong if exp negative |
| beq f2l_notNaN @ if fraction is non-zero, it's a NaN |