linprocfs.c revision 60860
1/*
2 * Copyright (c) 1993 Jan-Simon Pendry
3 * Copyright (c) 1993
4 *	The Regents of the University of California.  All rights reserved.
5 *
6 * This code is derived from software contributed to Berkeley by
7 * Jan-Simon Pendry.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 * 1. Redistributions of source code must retain the above copyright
13 *    notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 *    notice, this list of conditions and the following disclaimer in the
16 *    documentation and/or other materials provided with the distribution.
17 * 3. All advertising materials mentioning features or use of this software
18 *    must display the following acknowledgement:
19 *	This product includes software developed by the University of
20 *	California, Berkeley and its contributors.
21 * 4. Neither the name of the University nor the names of its contributors
22 *    may be used to endorse or promote products derived from this software
23 *    without specific prior written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
26 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
29 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
31 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
32 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
34 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 * SUCH DAMAGE.
36 *
37 *	@(#)procfs_status.c	8.4 (Berkeley) 6/15/94
38 *
39 * $FreeBSD: head/sys/compat/linprocfs/linprocfs.c 60860 2000-05-24 07:37:02Z des $
40 */
41
42#include <sys/param.h>
43#include <sys/systm.h>
44#include <sys/proc.h>
45#include <sys/jail.h>
46#include <sys/vnode.h>
47#include <sys/blist.h>
48#include <sys/tty.h>
49#include <sys/resourcevar.h>
50#include <i386/linux/linprocfs/linprocfs.h>
51
52#include <vm/vm.h>
53#include <vm/pmap.h>
54#include <vm/vm_param.h>
55#include <vm/vm_object.h>
56#include <vm/swap_pager.h>
57#include <sys/vmmeter.h>
58#include <sys/exec.h>
59
60#include <machine/md_var.h>
61#include <machine/cputypes.h>
62
63struct proc;
64
65int
66linprocfs_domeminfo(curp, p, pfs, uio)
67	struct proc *curp;
68	struct proc *p;
69	struct pfsnode *pfs;
70	struct uio *uio;
71{
72	char *ps;
73	int xlen;
74	int error;
75	char psbuf[512];		/* XXX - conservative */
76	unsigned long memtotal;		/* total memory in bytes */
77	unsigned long memused;		/* used memory in bytes */
78	unsigned long memfree;		/* free memory in bytes */
79	unsigned long memshared;	/* shared memory ??? */
80	unsigned long buffers, cached;	/* buffer / cache memory ??? */
81	unsigned long swaptotal;	/* total swap space in bytes */
82	unsigned long swapused;		/* used swap space in bytes */
83	unsigned long swapfree;		/* free swap space in bytes */
84	vm_object_t object;
85
86	if (uio->uio_rw != UIO_READ)
87		return (EOPNOTSUPP);
88
89	memtotal = physmem * PAGE_SIZE;
90	/*
91	 * The correct thing here would be:
92	 *
93	memfree = cnt.v_free_count * PAGE_SIZE;
94	memused = memtotal - memfree;
95	 *
96	 * but it might mislead linux binaries into thinking there
97	 * is very little memory left, so we cheat and tell them that
98	 * all memory that isn't wired down is free.
99	 */
100	memused = cnt.v_wire_count * PAGE_SIZE;
101	memfree = memtotal - memused;
102	swaptotal = swapblist->bl_blocks * 1024; /* XXX why 1024? */
103	swapfree = swapblist->bl_root->u.bmu_avail * PAGE_SIZE;
104	swapused = swaptotal - swapfree;
105	memshared = 0;
106	for (object = TAILQ_FIRST(&vm_object_list); object != NULL;
107	    object = TAILQ_NEXT(object, object_list))
108		if (object->shadow_count > 1)
109			memshared += object->resident_page_count;
110	memshared *= PAGE_SIZE;
111	/*
112	 * We'd love to be able to write:
113	 *
114	buffers = bufspace;
115	 *
116	 * but bufspace is internal to vfs_bio.c and we don't feel
117	 * like unstaticizing it just for linprocfs's sake.
118	 */
119	buffers = 0;
120	cached = cnt.v_cache_count * PAGE_SIZE;
121
122	ps = psbuf;
123	ps += sprintf(ps,
124		"        total:    used:    free:  shared: buffers:  cached:\n"
125		"Mem:  %lu %lu %lu %lu %lu %lu\n"
126		"Swap: %lu %lu %lu\n"
127		"MemTotal: %9lu kB\n"
128		"MemFree:  %9lu kB\n"
129		"MemShared:%9lu kB\n"
130		"Buffers:  %9lu kB\n"
131		"Cached:   %9lu kB\n"
132		"SwapTotal:%9lu kB\n"
133		"SwapFree: %9lu kB\n",
134		memtotal, memused, memfree, memshared, buffers, cached,
135		swaptotal, swapused, swapfree,
136		memtotal >> 10, memfree >> 10,
137		memshared >> 10, buffers >> 10, cached >> 10,
138		swaptotal >> 10, swapfree >> 10);
139
140	xlen = ps - psbuf;
141	xlen -= uio->uio_offset;
142	ps = psbuf + uio->uio_offset;
143	xlen = imin(xlen, uio->uio_resid);
144	if (xlen <= 0)
145		error = 0;
146	else
147		error = uiomove(ps, xlen, uio);
148	return (error);
149}
150
151int
152linprocfs_docpuinfo(curp, p, pfs, uio)
153	struct proc *curp;
154	struct proc *p;
155	struct pfsnode *pfs;
156	struct uio *uio;
157{
158	char *ps;
159	int xlen;
160	int error;
161	char psbuf[512];		/* XXX - conservative */
162	char *class;
163#if 0
164	extern char *cpu_model;		/* Yuck */
165#endif
166
167	if (uio->uio_rw != UIO_READ)
168		return (EOPNOTSUPP);
169
170	switch (cpu_class) {
171	case CPUCLASS_286:
172		class = "286";
173		break;
174	case CPUCLASS_386:
175		class = "386";
176		break;
177	case CPUCLASS_486:
178		class = "486";
179		break;
180	case CPUCLASS_586:
181		class = "586";
182		break;
183	case CPUCLASS_686:
184		class = "686";
185		break;
186	default:
187		class = "unknown";
188		break;
189	}
190
191	ps = psbuf;
192	ps += sprintf(ps,
193			"processor       : %d\n"
194			"cpu             : %.3s\n"
195			"model           : %.20s\n"
196			"vendor_id       : %.20s\n"
197			"stepping        : %d\n",
198			0, class, "unknown", cpu_vendor, cpu_id);
199
200	xlen = ps - psbuf;
201	xlen -= uio->uio_offset;
202	ps = psbuf + uio->uio_offset;
203	xlen = imin(xlen, uio->uio_resid);
204	if (xlen <= 0)
205		error = 0;
206	else
207		error = uiomove(ps, xlen, uio);
208	return (error);
209}
210