Page MenuHomeFreeBSD

Add parens to radix_to_skip for reader clarity
ClosedPublic

Authored by dougm on Aug 2 2017, 3:14 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Dec 23, 7:10 AM
Unknown Object (File)
Thu, Dec 5, 9:49 PM
Unknown Object (File)
Tue, Dec 3, 3:10 PM
Unknown Object (File)
Nov 27 2024, 2:57 AM
Unknown Object (File)
Nov 12 2024, 5:49 AM
Unknown Object (File)
Nov 12 2024, 2:47 AM
Unknown Object (File)
Oct 5 2024, 4:10 PM
Unknown Object (File)
Sep 29 2024, 8:07 PM
Subscribers
None

Details

Summary

In case readers are misled by expressions that combine multiplication and division, add parentheses to make the precedence explicit. Add similar changes to accompanying comments.

Diff Detail

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

Event Timeline

Thanks! This helps the readability of the code a little and won't trigger people's "this might be a bug" reflex. I made a couple of minor suggested tweaks to the comments for your consideration.

And thanks for the larger work that preceded this.

sys/kern/subr_blist.c
155 ↗(On Diff #31457)

s/if/since/ because m must divide BLIST_BMAP_RADIX for this code to work.

158 ↗(On Diff #31457)

"so simple integer division by a constant can safely be used for the calculation" might better convey what's going on here.

165 ↗(On Diff #31457)

so this is radix / ( ( 64 / 16 ) * 63 )

which works because BLIST_BMAP_RADIX % BLIST_META_RADIX == 0. OK.

This revision is now accepted and ready to land.Aug 2 2017, 4:43 PM
dougm edited edge metadata.
This revision now requires review to proceed.Aug 2 2017, 5:33 PM
sys/kern/subr_blist.c
165 ↗(On Diff #31457)

Actually, it is radix/((64/16)*15), but it's still okay.

Add a CTASSERT for the divisibilty condition.

Excellent! Thanks! this looks perfect now.

This revision is now accepted and ready to land.Aug 2 2017, 6:36 PM
dougm edited edge metadata.

#define a null CTASSERT macro for the self-testing compile.

This revision now requires review to proceed.Aug 2 2017, 6:46 PM
This revision is now accepted and ready to land.Aug 2 2017, 8:13 PM
This revision was automatically updated to reflect the committed changes.