diff options
| author | Steven Fuerst <svfuerst@gmail.com> | 2012-08-15 15:07:15 -0700 |
|---|---|---|
| committer | Alex Deucher <alexander.deucher@amd.com> | 2012-09-20 13:10:34 -0400 |
| commit | 747f49ba67b8895a5831ab539de551b916f3738c (patch) | |
| tree | b1b1561ae97f9f7fdab8ae44e019bd5dca0e62e4 /net/lapb/lapb_in.c | |
| parent | 7ff64fcaa7b7ba62d12758e49643f31dd9e90ece (diff) | |
Replace int2float() with an optimized version.
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: Steven Fuerst <svfuerst@gmail.com>
Diffstat (limited to 'net/lapb/lapb_in.c')
0 files changed, 0 insertions, 0 deletions
