Page MenuHomeFreeBSD

memstat_kvm_uma: fix reading of uma_zone_domain structures
ClosedPublic

Authored by vangyzen on Aug 27 2020, 3:14 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, May 9, 7:44 AM
Unknown Object (File)
Fri, May 8, 7:50 PM
Unknown Object (File)
Fri, May 1, 11:23 PM
Unknown Object (File)
Tue, Apr 21, 11:37 AM
Unknown Object (File)
Apr 6 2026, 10:24 AM
Unknown Object (File)
Apr 3 2026, 8:35 AM
Unknown Object (File)
Mar 31 2026, 1:05 AM
Unknown Object (File)
Mar 30 2026, 2:23 AM
Subscribers

Details

Summary

Coverity flagged the scaling by sizeof(uzd). That is the type
of the pointer, so the scaling was already done by pointer arithmetic.
However, this was also passing a stack frame pointer to kvm_read,
so it was doubly wrong.

Move ZDOM_GET into the !_KERNEL section and use it in libmemstat.

Reported by: Coverity

Test Plan

I ran this against a vmcore file and it still printed some garbage
stats, but the printf I added for debugging no longer complained.

Diff Detail

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

Event Timeline

markj added inline comments.
sys/vm/uma_int.h
531 ↗(On Diff #76284)

Fix the indent to be consistent while you're here?

This revision is now accepted and ready to land.Aug 27 2020, 3:39 PM