Page MenuHomeFreeBSD

LinuxKPI: change BUILD_BUG_ON()
ClosedPublic

Authored by bz on May 24 2021, 6:42 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 28 2024, 7:27 AM
Unknown Object (File)
Dec 12 2024, 5:40 AM
Unknown Object (File)
Nov 27 2024, 11:51 AM
Unknown Object (File)
Nov 27 2024, 8:31 AM
Unknown Object (File)
Nov 23 2024, 11:22 AM
Unknown Object (File)
Nov 23 2024, 11:13 AM
Unknown Object (File)
Nov 22 2024, 12:29 PM
Unknown Object (File)
Nov 14 2024, 1:50 PM

Details

Summary

BUILD_BUG_ON() can be used inside functions where the definition to
CTASSERT() (_Static_assert()) seems to not work.
Go back to an old-style CTASSERT() implementation but also add a
variable dclaration to avoid "unsued typedef" errors and dummy-use
the variable to avoid "unusued variable" errors. Given it is all
self-contained in a block and not used outside this should be
optimised away.

Sponsored by: The FreeBSD Foundation
MFC after: 2 weeks
Reviewed by:
Differential Revision:

Diff Detail

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

Event Timeline

bz requested review of this revision.May 24 2021, 6:42 PM
hselasky added inline comments.
sys/compat/linuxkpi/common/include/linux/kernel.h
100

Should this be enclosed with while (0) and not "do { } while (0) "?

sys/compat/linuxkpi/common/include/linux/kernel.h
100

Would a while (0) { } be optimized out without ever entering the block because it can never happen?

sys/compat/linuxkpi/common/include/linux/kernel.h
100

Yes, with -O2, but after parsing the code. So I believe any asserts will trigger.

Switch to while (0) { } as suggested by @hselasky

This revision is now accepted and ready to land.May 25 2021, 9:42 AM
This revision was automatically updated to reflect the committed changes.