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)
Wed, Dec 17, 9:08 AM
Unknown Object (File)
Mon, Dec 15, 10:38 PM
Unknown Object (File)
Fri, Dec 12, 11:04 PM
Unknown Object (File)
Thu, Nov 27, 3:26 AM
Unknown Object (File)
Wed, Nov 26, 1:03 AM
Unknown Object (File)
Nov 20 2025, 6:23 AM
Unknown Object (File)
Nov 20 2025, 6:23 AM
Unknown Object (File)
Nov 20 2025, 6:22 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