Page MenuHomeFreeBSD

byteswap.h: Add a glibc/linux compatible byteswap.h
ClosedPublic

Authored by imp on Sep 21 2021, 1:08 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Oct 19, 7:22 PM
Unknown Object (File)
Sun, Oct 19, 7:11 PM
Unknown Object (File)
Fri, Oct 17, 3:17 PM
Unknown Object (File)
Fri, Oct 10, 11:29 AM
Unknown Object (File)
Wed, Oct 8, 8:04 PM
Unknown Object (File)
Tue, Oct 7, 8:45 PM
Unknown Object (File)
Sep 17 2025, 12:54 PM
Unknown Object (File)
Sep 17 2025, 12:42 PM
Subscribers
None

Details

Summary

For endian.h to work instead of sys/endian.h, some software needs
byteswap.h available. It must define {,}byteswap_{16,32,64}.
Included sys/_endian.h to get an appropriate
byteswap16, etc
and defines the new macros in terms of them. Enhance _endian.h
to allow it to be included from here too.

Sponsored by: Netflix

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 41683
Build 38572: arc lint + arc unit

Event Timeline

imp requested review of this revision.Sep 21 2021, 1:08 PM
imp created this revision.

regen after sys/_endian.h update

(PR258544 endian.h exp-run)

Yes, this is paired with the endian.h changes because you need both to not @#^#@& some ports.

include/byteswap.h
17
18
20

Used? Or present under /usr/include?

include/byteswap.h
18

(I included @markj's helpful comma as well)

20

I suspect used. I would perhaps say "included" instead of used?

Update comments from review suggestiosn, and hopefully some additional verbosity
to disambiguate other possible readings not flagged in earlier reviews.

markj added inline comments.
include/byteswap.h
20

Not 100% sure this is what you meant.

This revision is now accepted and ready to land.May 4 2022, 2:25 PM
include/byteswap.h
20

Yes. <sys/_endian.h> provides all the traditional BSD/FreeBSD <sys/endian.h> interfaces, except the ones that interfere or are incompatible with glibc <endian.h>. Those bits are in either <endian.h>/<byteswap.h> or <sys/endian.h>. I struggled with how to convey that 'top level description' and would love any feedback you have. I like your change though.