Page MenuHomeFreeBSD

Use REFCOUNT_COUNT() to obtain refcount where appropriate
ClosedPublic

Authored by hselasky on Sep 12 2019, 3:46 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Nov 2, 10:05 AM
Unknown Object (File)
Sun, Oct 26, 8:00 PM
Unknown Object (File)
Sat, Oct 25, 3:54 PM
Unknown Object (File)
Sat, Oct 25, 3:54 PM
Unknown Object (File)
Sat, Oct 25, 3:54 PM
Unknown Object (File)
Sat, Oct 25, 3:54 PM
Unknown Object (File)
Sat, Oct 25, 9:20 AM
Unknown Object (File)
Oct 3 2025, 1:45 AM
Subscribers

Details

Summary

Refcount waiting will set some flag bits in the refcount value. Make sure these bits get cleared by using the REFCOUNT_COUNT() macro to obtain the actual refcount.

Diff Detail

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

Event Timeline

kib added inline comments.
sys/vm/vm_object.c
398 ↗(On Diff #61982)

Fix the style, ... > 0. There and several places below as well.

This revision is now accepted and ready to land.Sep 12 2019, 3:48 PM
hselasky marked an inline comment as done.

Fix style.

This revision now requires review to proceed.Sep 12 2019, 4:06 PM

Does this fix an observed bug? The waiter bit should only be set if the counter value is non-zero, so the comparisons with 0 should work correctly regardless. I agree with the change though.

This revision is now accepted and ready to land.Sep 12 2019, 4:08 PM