Page MenuHomeFreeBSD

illums compat: use flsl/flsll for highbit/highbit64
ClosedPublic

Authored by avg on Jun 16 2015, 2:14 PM.
Tags
None
Referenced Files
F133485706: D2839.id6319.diff
Sun, Oct 26, 3:41 AM
Unknown Object (File)
Thu, Oct 23, 9:44 AM
Unknown Object (File)
Tue, Oct 21, 3:50 PM
Unknown Object (File)
Mon, Oct 20, 4:19 AM
Unknown Object (File)
Mon, Oct 20, 1:35 AM
Unknown Object (File)
Fri, Oct 17, 1:41 PM
Unknown Object (File)
Thu, Oct 9, 8:31 AM
Unknown Object (File)
Tue, Oct 7, 8:56 AM
Subscribers
None

Details

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

avg retitled this revision from to illums compat: use flsl/flsll for highbit/highbit64.
avg updated this object.
avg edited the test plan for this revision. (Show Details)
avg added reviewers: smh, mav, will, gibbs, delphij.
delphij edited edge metadata.

Looks good to me.

This revision is now accepted and ready to land.Jun 16 2015, 9:29 PM
mav edited edge metadata.

It would be good to upstream it. I don't know why it was implemented originally, but it seems that at least on user level Illumos has fsll() and co.

This revision was automatically updated to reflect the committed changes.

This was backed out because of build problems on platforms other than amd64.

This revision is now accepted and ready to land.Jun 17 2015, 7:52 PM
avg edited edge metadata.

highbit: use only fast flsl/flsll versions

Currently libkern flsl/flsll are even less optimized than the original
code. The same goes for libc implementations on most platforms.

This revision now requires review to proceed.Jun 18 2015, 8:32 AM

Could you please re-review?
I believe that the latest diff should be safe on all platforms.

delphij edited edge metadata.
This revision is now accepted and ready to land.Jun 18 2015, 6:57 PM
mahrens edited edge metadata.

Looks fine to me. FWIW, illumos appears to have flsll() in userland but not kernel. It's implemented similarly to highbit().

Checking HAVE_INLINE_* define is what I am successfully using in SCHED_ULE for some time now, so it should work. Though I hope somebody implement missing functions on other platforms to reach the parity and avoid this mess.

mav edited edge metadata.
This revision was automatically updated to reflect the committed changes.