]>
git.saurik.com Git - apple/xnu.git/blob - bsd/kern/kern_subr.c
2 * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * The contents of this file constitute Original Code as defined in and
7 * are subject to the Apple Public Source License Version 1.1 (the
8 * "License"). You may not use this file except in compliance with the
9 * License. Please obtain a copy of the License at
10 * http://www.apple.com/publicsource and read it before using this file.
12 * This Original Code and all software distributed under the License are
13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17 * License for the specific language governing rights and limitations
20 * @APPLE_LICENSE_HEADER_END@
22 /* Copyright (c) 1995 NeXT Computer, Inc. All Rights Reserved */
24 * Copyright (c) 1982, 1986, 1991, 1993
25 * The Regents of the University of California. All rights reserved.
26 * (c) UNIX System Laboratories, Inc.
27 * All or some portions of this file are derived from material licensed
28 * to the University of California by American Telephone and Telegraph
29 * Co. or Unix System Laboratories, Inc. and are reproduced herein with
30 * the permission of UNIX System Laboratories, Inc.
32 * Redistribution and use in source and binary forms, with or without
33 * modification, are permitted provided that the following conditions
35 * 1. Redistributions of source code must retain the above copyright
36 * notice, this list of conditions and the following disclaimer.
37 * 2. Redistributions in binary form must reproduce the above copyright
38 * notice, this list of conditions and the following disclaimer in the
39 * documentation and/or other materials provided with the distribution.
40 * 3. All advertising materials mentioning features or use of this software
41 * must display the following acknowledgement:
42 * This product includes software developed by the University of
43 * California, Berkeley and its contributors.
44 * 4. Neither the name of the University nor the names of its contributors
45 * may be used to endorse or promote products derived from this software
46 * without specific prior written permission.
48 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
49 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
50 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
51 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
52 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
53 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
54 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
55 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
56 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
57 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
60 * @(#)kern_subr.c 8.3 (Berkeley) 1/21/94
63 #include <sys/param.h>
64 #include <sys/systm.h>
66 #include <sys/malloc.h>
67 #include <sys/queue.h>
71 #include <sys/kdebug.h>
72 #define DBG_UIO_COPYOUT 16
73 #define DBG_UIO_COPYIN 17
80 register struct uio
*uio
;
82 register struct iovec
*iov
;
87 if (uio
->uio_rw
!= UIO_READ
&& uio
->uio_rw
!= UIO_WRITE
)
88 panic("uiomove: mode");
89 if (uio
->uio_segflg
== UIO_USERSPACE
&& uio
->uio_procp
!= current_proc())
90 panic("uiomove proc");
93 while (n
> 0 && uio
->uio_resid
) {
103 switch (uio
->uio_segflg
) {
107 if (uio
->uio_rw
== UIO_READ
)
109 KERNEL_DEBUG((FSDBG_CODE(DBG_FSRW
, DBG_UIO_COPYOUT
)) | DBG_FUNC_START
,
110 cp
, iov
->iov_base
, cnt
, 0,0);
112 error
= copyout(cp
, iov
->iov_base
, cnt
);
114 KERNEL_DEBUG((FSDBG_CODE(DBG_FSRW
, DBG_UIO_COPYOUT
)) | DBG_FUNC_END
,
115 cp
, iov
->iov_base
, cnt
, 0,0);
119 KERNEL_DEBUG((FSDBG_CODE(DBG_FSRW
, DBG_UIO_COPYIN
)) | DBG_FUNC_START
,
120 iov
->iov_base
, cp
, cnt
, 0,0);
122 error
= copyin(iov
->iov_base
, cp
, cnt
);
124 KERNEL_DEBUG((FSDBG_CODE(DBG_FSRW
, DBG_UIO_COPYIN
)) | DBG_FUNC_END
,
125 iov
->iov_base
, cp
, cnt
, 0,0);
132 if (uio
->uio_rw
== UIO_READ
)
133 error
= copywithin((caddr_t
)cp
, iov
->iov_base
,
136 error
= copywithin(iov
->iov_base
, (caddr_t
)cp
,
140 case UIO_PHYS_USERSPACE
:
141 if (uio
->uio_rw
== UIO_READ
)
143 KERNEL_DEBUG((FSDBG_CODE(DBG_FSRW
, DBG_UIO_COPYOUT
)) | DBG_FUNC_START
,
144 cp
, iov
->iov_base
, cnt
, 1,0);
146 error
= copyp2v(cp
, iov
->iov_base
, cnt
);
149 KERNEL_DEBUG((FSDBG_CODE(DBG_FSRW
, DBG_UIO_COPYOUT
)) | DBG_FUNC_END
,
150 cp
, iov
->iov_base
, cnt
, 1,0);
154 KERNEL_DEBUG((FSDBG_CODE(DBG_FSRW
, DBG_UIO_COPYIN
)) | DBG_FUNC_START
,
155 iov
->iov_base
, cp
, cnt
, 1,0);
157 panic("copyv2p not implemented yet\n");
159 KERNEL_DEBUG((FSDBG_CODE(DBG_FSRW
, DBG_UIO_COPYIN
)) | DBG_FUNC_END
,
160 iov
->iov_base
, cp
, cnt
, 1,0);
167 iov
->iov_base
+= cnt
;
169 uio
->uio_resid
-= cnt
;
170 uio
->uio_offset
+= cnt
;
178 * Give next character to user as result of read.
183 register struct uio
*uio
;
185 register struct iovec
*iov
;
187 if (uio
->uio_resid
<= 0)
188 panic("ureadc: non-positive resid");
190 if (uio
->uio_iovcnt
== 0)
191 panic("ureadc: non-positive iovcnt");
193 if (iov
->iov_len
<= 0) {
198 switch (uio
->uio_segflg
) {
201 if (subyte(iov
->iov_base
, c
) < 0)
210 if (suibyte(iov
->iov_base
, c
) < 0)
221 #if defined(vax) || defined(ppc)
222 /* unused except by ct.c, other oddities XXX */
224 * Get next character written in by user from uio.
229 register struct iovec
*iov
;
232 if (uio
->uio_resid
<= 0)
235 if (uio
->uio_iovcnt
<= 0)
236 panic("uwritec: non-positive iovcnt");
238 if (iov
->iov_len
== 0) {
240 if (--uio
->uio_iovcnt
== 0)
244 switch (uio
->uio_segflg
) {
247 c
= fubyte(iov
->iov_base
);
251 c
= *iov
->iov_base
& 0377;
255 c
= fuibyte(iov
->iov_base
);
259 c
= 0; /* avoid uninitialized variable warning */
260 panic("uwritec: bogus uio_segflg");
271 #endif /* vax || ppc */
274 * General routine to allocate a hash table.
277 hashinit(elements
, type
, hashmask
)
282 LIST_HEAD(generic
, generic
) *hashtbl
;
286 panic("hashinit: bad cnt");
287 for (hashsize
= 1; hashsize
<= elements
; hashsize
<<= 1)
290 MALLOC(hashtbl
, struct generic
*,
291 (u_long
)hashsize
* sizeof(*hashtbl
), type
, M_WAITOK
);
292 bzero(hashtbl
, (u_long
)hashsize
* sizeof(*hashtbl
));
293 for (i
= 0; i
< hashsize
; i
++)
294 LIST_INIT(&hashtbl
[i
]);
295 *hashmask
= hashsize
- 1;