summaryrefslogtreecommitdiff
path: root/sysutils/libgtop/patches/patch-ai
blob: b38a28c51f03f3200a7aa97c72a7730650749d46 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
$NetBSD: patch-ai,v 1.1.1.1 1998/10/07 13:11:35 agc Exp $

--- sysdeps/bsd/procmem.c	1998/10/07 11:22:59	1.1
+++ sysdeps/bsd/procmem.c	1998/10/07 11:39:30
@@ -31,6 +31,9 @@
 #include <sys/resource.h>
 #include <vm/vm_object.h>
 #include <vm/vm_map.h>
+#ifdef __NetBSD__
+#include <vm/vnode_pager.h>
+#endif
 
 #include <sys/vnode.h>
 #include <ufs/ufs/quota.h>
@@ -96,6 +99,9 @@
 	struct vnode vnode;
 	struct inode inode;
 	int count;
+#ifdef __NetBSD__
+	vn_pager_t	vnpage;
+#endif
 
 	glibtop_init_p (server, (1 << GLIBTOP_SYSDEPS_PROC_MEM), 0);
 	
@@ -150,8 +156,16 @@
 			      &entry, sizeof (entry)) != sizeof (entry))
 			glibtop_error_io_r (server, "kvm_read (entry)");
 
+#ifdef __FreeBSD__
 		if (entry.eflags & (MAP_ENTRY_IS_A_MAP|MAP_ENTRY_IS_SUB_MAP))
 			continue;
+#elseif defined(UVM)
+		if (entry.eflags & (MAP_ENTRY_IS_A_MAP|MAP_ENTRY_IS_SUB_MAP))
+			continue;
+#else
+		if (entry.is_a_map || entry.is_sub_map)
+			continue;
+#endif
 
 		if (!entry.object.vm_object)
 			continue;
@@ -165,10 +179,17 @@
 
 		/* If the object is of type vnode, add its size */
 
+#ifdef __FreeBSD__
 		if (object.type != OBJT_VNODE)
 			continue;
-
 		buf->share += object.un_pager.vnp.vnp_size;
+#else
+		if (object.pager->pg_type != PG_VNODE)
+			continue;
+		vnpage = (vn_pager_t) object.pager->pg_handle;
+		buf->share += vnpage->vnp_size;
+#endif
+
 	}
 
 	glibtop_suid_leave (server);