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 #pragma ident "%Z%%M% %I% %E% SMI"
29 #include <sys/syscall.h>
36 projlist(id_t
*idbuf
, size_t idbufsz
)
38 return (syscall(SYS_tasksys
, 3, 0, 0, idbuf
, idbufsz
));
42 project_walk(int (*callback
)(projid_t
, void *), void *init_data
)
45 projid_t
*projids
= NULL
;
46 projid_t
*curr_projid
;
50 while ((sz
= projlist(projids
, osz
* sizeof (projid_t
))) != osz
) {
52 curr_projid
= projids
;
53 if ((projids
= realloc(projids
, sz
* sizeof (projid_t
)))
56 * If realloc() fails, we return ENOMEM.
60 if (curr_projid
!= NULL
)
66 for (curr_projid
= projids
; curr_projid
< projids
+ sz
; curr_projid
++) {
67 if (ret
= callback(*curr_projid
, init_data
))