Page MenuHomeFreeBSD

Add counters to smr.
ClosedPublic

Authored by jeff on Feb 2 2020, 12:25 AM.
Tags
None
Referenced Files
F108553761: D23463.id67646.diff
Sun, Jan 26, 7:07 AM
F108549336: D23463.id67646.diff
Sun, Jan 26, 5:38 AM
Unknown Object (File)
Sat, Jan 18, 10:20 PM
Unknown Object (File)
Tue, Jan 14, 5:40 PM
Unknown Object (File)
Sun, Jan 12, 10:26 PM
Unknown Object (File)
Sun, Jan 12, 10:20 PM
Unknown Object (File)
Sun, Jan 12, 5:19 PM
Unknown Object (File)
Sun, Jan 12, 4:32 AM
Subscribers

Details

Summary

These should eventually be per-smr I suspect but for now this is helpful.

Diff Detail

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

Event Timeline

jeff added reviewers: rlibby, markj.
jeff set the repository for this revision to rS FreeBSD src repository - subversion.

Logic looks fine. I trust you've checked any performance effects.

In advance you count on entry, and then also on the slow path, whereas in poll you count either fast or slow. Did you mean to approach those differently?

sys/kern/subr_smr.c
168 ↗(On Diff #67646)

Should they be initialized with EARLY_COUNTER? Since it seems that UMA SMR is available after SI_SUB_VM.

This revision is now accepted and ready to land.Feb 2 2020, 8:23 PM
sys/kern/subr_smr.c
39 ↗(On Diff #67646)

Sort includes while here?

316 ↗(On Diff #67646)

This and the call below can be counter_u64_add_protected() since you're in a critical section.

Logic looks fine. I trust you've checked any performance effects.

In advance you count on entry, and then also on the slow path, whereas in poll you count either fast or slow. Did you mean to approach those differently?

It might make more sense to count all polls and then number of polls that scan. I will look at that.