4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
23 * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
27 #pragma ident "%Z%%M% %I% %E% SMI"
29 #pragma weak _getrctl = getrctl
30 #pragma weak _setrctl = setrctl
33 #include <sys/types.h>
34 #include <sys/syscall.h>
38 getrctl(const char *name
, rctlblk_t
*old_rblk
, rctlblk_t
*new_rblk
,
41 return (syscall(SYS_rctlsys
,
42 0, name
, old_rblk
, new_rblk
, 0, flags
));
46 setrctl(const char *name
, rctlblk_t
*old_rblk
, rctlblk_t
*new_rblk
,
49 return (syscall(SYS_rctlsys
,
50 1, name
, old_rblk
, new_rblk
, 0, flags
));
54 rctllist(char *list_buf
, size_t list_bufsz
)
59 error
= __systemcall(&rval
, SYS_rctlsys
, 2, NULL
, list_buf
, NULL
,
63 (void) __set_errno(error
);
64 return ((size_t)rval
.sys_rval1
);
68 rctlctl(const char *name
, rctlblk_t
*rblk
, int flags
)
70 return (syscall(SYS_rctlsys
, 3, name
, rblk
, NULL
, 0, flags
));
74 setprojrctl(const char *name
, rctlblk_t
*new_rblk
, size_t size
, int flags
)
76 return (syscall(SYS_rctlsys
,
77 4, name
, NULL
, new_rblk
, size
, flags
));