Merge pull request #2015 from ston1th/openbsd_mem_cache_fix

Fix wrong value for OpenBSD memory buffer cache
This commit is contained in:
Ben Kochie 2021-07-14 13:15:32 +02:00 committed by GitHub
commit 40766fd3cc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 37 additions and 1 deletions

View File

@ -20,18 +20,54 @@ import (
"unsafe" "unsafe"
) )
const (
CTL_VFS = 10
VFS_GENERIC = 0
VFS_BCACHESTAT = 3
)
type bcachestats struct {
Numbufs int64
Numbufpages int64
Numdirtypages int64
Numcleanpages int64
Pendingwrites int64
Pendingreads int64
Numwrites int64
Numreads int64
Cachehits int64
Busymapped int64
Dmapages int64
Highpages int64
Delwribufs int64
Kvaslots int64
Kvaslots_avail int64
Highflips int64
Highflops int64
Dmaflips int64
}
func (c *meminfoCollector) getMemInfo() (map[string]float64, error) { func (c *meminfoCollector) getMemInfo() (map[string]float64, error) {
uvmexpb, err := unix.SysctlRaw("vm.uvmexp") uvmexpb, err := unix.SysctlRaw("vm.uvmexp")
if err != nil { if err != nil {
return nil, err return nil, err
} }
mib := [3]_C_int{CTL_VFS, VFS_GENERIC, VFS_BCACHESTAT}
bcstatsb, err := sysctl(mib[:])
if err != nil {
return nil, err
}
uvmexp := *(*unix.Uvmexp)(unsafe.Pointer(&uvmexpb[0])) uvmexp := *(*unix.Uvmexp)(unsafe.Pointer(&uvmexpb[0]))
ps := float64(uvmexp.Pagesize) ps := float64(uvmexp.Pagesize)
bcstats := *(*bcachestats)(unsafe.Pointer(&bcstatsb[0]))
// see uvm(9) // see uvm(9)
return map[string]float64{ return map[string]float64{
"active_bytes": ps * float64(uvmexp.Active), "active_bytes": ps * float64(uvmexp.Active),
"cache_bytes": ps * float64(uvmexp.Vnodepages), "cache_bytes": ps * float64(bcstats.Numbufpages),
"free_bytes": ps * float64(uvmexp.Free), "free_bytes": ps * float64(uvmexp.Free),
"inactive_bytes": ps * float64(uvmexp.Inactive), "inactive_bytes": ps * float64(uvmexp.Inactive),
"size_bytes": ps * float64(uvmexp.Npages), "size_bytes": ps * float64(uvmexp.Npages),