Page MenuHomeFreeBSD

LinuxKPI: fix WRITE_ONCE()
ClosedPublic

Authored by bz on May 13 2023, 3:37 PM.
Tags
None
Referenced Files
F106942389: D40084.id122196.diff
Tue, Jan 7, 7:53 PM
Unknown Object (File)
Mon, Jan 6, 8:49 AM
Unknown Object (File)
Nov 27 2024, 10:48 PM
Unknown Object (File)
Nov 20 2024, 9:38 PM
Unknown Object (File)
Nov 17 2024, 4:03 PM
Unknown Object (File)
Nov 11 2024, 10:09 PM
Unknown Object (File)
Nov 11 2024, 10:06 PM
Unknown Object (File)
Nov 11 2024, 10:01 PM

Details

Summary

Fix a gcc warning: to be safe all intermediate pointers in cast from
'...' to '...' must be 'const' qualified [-Wcast-qual].
Doing what is essentially a __DECONST() adding the uintptr_t gets
rid of the massive amount of warnings we get in LinuxKPI and lets
us see the actual problems a lot better.
This is a follow-up to 74e908b3c63b28de1d590dc42502fbe959a6da2e which
fixed READ_ONCE().

Suggested by: jhb
MFC after: 10 days

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 51479
Build 48370: arc lint + arc unit

Event Timeline

bz requested review of this revision.May 13 2023, 3:37 PM
hselasky added a subscriber: hselasky.
hselasky added inline comments.
sys/compat/linuxkpi/common/include/linux/compiler.h
91

Hi,

ACCESS_ONCE() used to be a valid Linux API:

Documentation/RCU/RTFP.txt: ACCESS_ONCE().

But I think it is obsolete. Maybe say something about that in the commit message!

--HPS

93

This also works for CheriBSD and capability pointers?

sys/compat/linuxkpi/common/include/linux/compiler.h
93

Yes.

This revision is now accepted and ready to land.May 21 2023, 4:38 PM
This revision was automatically updated to reflect the committed changes.