4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License, Version 1.0 only
6 * (the "License"). You may not use this file except in compliance
9 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10 * or http://www.opensolaris.org/os/licensing.
11 * See the License for the specific language governing permissions
12 * and limitations under the License.
14 * When distributing Covered Code, include this CDDL HEADER in each
15 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16 * If applicable, add the following below this CDDL HEADER, with the
17 * fields enclosed by brackets "[]" replaced with your own identifying
18 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright (c) 2001 by Sun Microsystems, Inc.
24 * All rights reserved.
27 #include <sys/syscall.h>
34 projlist(id_t
*idbuf
, size_t idbufsz
)
36 return (syscall(SYS_tasksys
, 3, 0, 0, idbuf
, idbufsz
));
40 project_walk(int (*callback
)(projid_t
, void *), void *init_data
)
43 projid_t
*projids
= NULL
;
44 projid_t
*curr_projid
;
48 while ((sz
= projlist(projids
, osz
* sizeof (projid_t
))) != osz
) {
50 curr_projid
= projids
;
51 if ((projids
= reallocarray(projids
, sz
, sizeof (projid_t
)))
54 * If realloc() fails, we return ENOMEM.
63 for (curr_projid
= projids
; curr_projid
< projids
+ sz
; curr_projid
++) {
64 if (ret
= callback(*curr_projid
, init_data
))