Sync usage with man page.
[netbsd-mini2440.git] / dist / ipf / lib / kmem.c
blob119abf88fa3a65679ceaf251132ef788157e00f5
1 /* $NetBSD$ */
3 /*
4 * Copyright (C) 2000-2005 by Darren Reed.
6 * See the IPFILTER.LICENCE file for details on licencing.
7 */
8 /*
9 * kmemcpy() - copies n bytes from kernel memory into user buffer.
10 * returns 0 on success, -1 on error.
13 #include <stdio.h>
14 #include <sys/param.h>
15 #include <sys/types.h>
16 #include <sys/uio.h>
17 #include <unistd.h>
18 #include <string.h>
19 #include <fcntl.h>
20 #include <sys/file.h>
21 #if !defined(__sgi) && !defined(__hpux) && !defined(__osf__) && !defined(linux) && !defined(_AIX51)
22 #include <kvm.h>
23 #endif
24 #include <fcntl.h>
25 #include <sys/socket.h>
26 #include <sys/ioctl.h>
27 #include <netinet/in.h>
28 #include <arpa/inet.h>
29 #include <netinet/in_systm.h>
30 #include <netinet/ip.h>
31 #include <net/if.h>
32 #if __FreeBSD_version >= 300000
33 # include <net/if_var.h>
34 #endif
35 #if defined(linux) || defined(__osf__) || defined(__sgi) || defined(__hpux)
36 # include <stdlib.h>
37 #endif
39 #include "kmem.h"
41 #ifndef __STDC__
42 # define const
43 #endif
45 #if !defined(lint)
46 static const char sccsid[] = "@(#)kmem.c 1.4 1/12/96 (C) 1992 Darren Reed";
47 static const char rcsid[] = "@(#)Id: kmem.c,v 1.16.2.3 2006/06/16 17:21:04 darrenr Exp";
48 #endif
52 #if !defined(__sgi) && !defined(__hpux) && !defined(__osf__) && \
53 !defined(linux) && !defined(_AIX51)
55 * For all platforms where there is a libkvm and a kvm_t, we use that...
57 static kvm_t *kvm_f = NULL;
59 #else
61 *...and for the others (HP-UX, IRIX, Tru64), we have to provide our own.
64 typedef int * kvm_t;
66 static kvm_t kvm_f = NULL;
67 static char *kvm_errstr = NULL;
69 kvm_t kvm_open __P((char *, char *, char *, int, char *));
70 int kvm_read __P((kvm_t, u_long, char *, size_t));
72 kvm_t kvm_open(kernel, core, swap, mode, errstr)
73 char *kernel, *core, *swap;
74 int mode;
75 char *errstr;
77 kvm_t k;
78 int fd;
80 kvm_errstr = errstr;
82 if (core == NULL)
83 core = "/dev/kmem";
85 fd = open(core, mode);
86 if (fd == -1)
87 return NULL;
88 k = malloc(sizeof(*k));
89 if (k == NULL)
90 return NULL;
91 *k = fd;
92 return k;
95 int kvm_read(kvm, pos, buffer, size)
96 kvm_t kvm;
97 u_long pos;
98 char *buffer;
99 size_t size;
101 int r = 0, left;
102 char *bufp;
104 if (lseek(*kvm, pos, 0) == -1) {
105 if (kvm_errstr != NULL) {
106 fprintf(stderr, "%s", kvm_errstr);
107 perror("lseek");
109 return -1;
112 for (bufp = buffer, left = size; left > 0; bufp += r, left -= r) {
113 r = read(*kvm, bufp, left);
114 #ifdef __osf__
116 * Tru64 returns "0" for successful operation, not the number
117 * of bytes read.
119 if (r == 0)
120 r = left;
121 #endif
122 if (r <= 0)
123 return -1;
125 return r;
127 #endif /* !defined(__sgi) && !defined(__hpux) && !defined(__osf__) */
129 int openkmem(kern, core)
130 char *kern, *core;
132 kvm_f = kvm_open(kern, core, NULL, O_RDONLY, NULL);
133 if (kvm_f == NULL)
135 perror("openkmem:open");
136 return -1;
138 return kvm_f != NULL;
141 int kmemcpy(buf, pos, n)
142 register char *buf;
143 long pos;
144 register int n;
146 register int r;
148 if (!n)
149 return 0;
151 if (kvm_f == NULL)
152 if (openkmem(NULL, NULL) == -1)
153 return -1;
155 while ((r = kvm_read(kvm_f, pos, buf, n)) < n)
156 if (r <= 0)
158 fprintf(stderr, "pos=0x%lx ", (u_long)pos);
159 perror("kmemcpy:read");
160 return -1;
162 else
164 buf += r;
165 pos += r;
166 n -= r;
168 return 0;
171 int kstrncpy(buf, pos, n)
172 register char *buf;
173 long pos;
174 register int n;
176 register int r;
178 if (!n)
179 return 0;
181 if (kvm_f == NULL)
182 if (openkmem(NULL, NULL) == -1)
183 return -1;
185 while (n > 0)
187 r = kvm_read(kvm_f, pos, buf, 1);
188 if (r <= 0)
190 fprintf(stderr, "pos=0x%lx ", (u_long)pos);
191 perror("kmemcpy:read");
192 return -1;
194 else
196 if (*buf == '\0')
197 break;
198 buf++;
199 pos++;
200 n--;
203 return 0;