• Steven Fuerst's avatar
    Replace int2float() with an optimized version. · 747f49ba
    Steven Fuerst authored
    We use __fls() to find the most significant bit.  Using that, the
    loop can be avoided.  A second trick is to use the behaviour of the
    rotate instructions to expand the range of the unsigned int to float
    conversion to the full 32 bits in a branchless way.
    
    The routine is now exact up to 2^24.  Above that, we truncate which
    is equivalent to rounding towards zero.
    Signed-off-by: default avatarSteven Fuerst <svfuerst@gmail.com>
    747f49ba
r600_blit.c 22.4 KB