Page MenuHomeFreeBSD

KASSERT(9): add assertion message guidelines
ClosedPublic

Authored by mhorne on Mar 19 2024, 5:44 PM.
Tags
None
Referenced Files
F106963328: D44434.diff
Wed, Jan 8, 4:10 AM
Unknown Object (File)
Sat, Dec 28, 10:47 PM
Unknown Object (File)
Sat, Dec 28, 9:41 PM
Unknown Object (File)
Sat, Dec 28, 9:29 PM
Unknown Object (File)
Dec 5 2024, 9:19 PM
Unknown Object (File)
Nov 25 2024, 4:25 AM
Unknown Object (File)
Nov 18 2024, 2:22 AM
Unknown Object (File)
Oct 19 2024, 7:00 AM
Subscribers

Details

Summary

Add some text describing how to create useful assertion messages.

Improve and add to the EXAMPLES.

Diff Detail

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

Event Timeline

emaste added subscribers: jhb, emaste.

This looks good to me

share/man/man9/KASSERT.9
93

I think retconning MPASS to "must pass" is fine, but I assume it originated as multiprocessor assert -- @jhb?

This revision is now accepted and ready to land.Mar 19 2024, 6:09 PM
share/man/man9/KASSERT.9
93

For reference MPASS originated in rG:0384fff8c5b09

I really wish we could transition KASSERT gracefully to using __VA_ARGS__ and away from the nested ()'s, but I'm not sure of a good way to permit both syntaxes concurrently.

share/man/man9/KASSERT.9
93

Yes, it came from BSD/OS as "multi-processor assert".

In D44434#1013310, @jhb wrote:

I really wish we could transition KASSERT gracefully to using __VA_ARGS__ and away from the nested ()'s, but I'm not sure of a good way to permit both syntaxes concurrently.

I had a student use an interesting mix of _Generic and VA_ARGS to accomplish similar things, but you'd have to make some assumption... I'll see if I can tweak something...

share/man/man9/KASSERT.9
5

2023-2024 please.

81

I wish we had a variation that would always be on, for tests that are super cheap... We have NASSERT at work, but the N I think is for Netflix not something clever.

93

I read it as Must Pass, even though I know its some MP thing... Maybe just note its BSD/OS + Multi-processor history with a ret-con to must pass :)

107

Do we want to add explicitly they should be useful without the result core file?

Thank you!
Can we also adjust the comment above MPASS() in the header file?

share/man/man9/KASSERT.9
184

\n

mhorne marked 3 inline comments as done.

Handle minor review feedback.

This revision now requires review to proceed.Mar 20 2024, 2:42 PM
In D44434#1013418, @bz wrote:

Thank you!
Can we also adjust the comment above MPASS() in the header file?

Great point, handled in D44438.

share/man/man9/KASSERT.9
93

Now captured in D44439.

107

Good suggestion, I have incorporated this.

184

Not required for KASSERT.

This revision is now accepted and ready to land.Mar 20 2024, 2:59 PM
This revision was automatically updated to reflect the committed changes.