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 /* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */
28 /* All Rights Reserved */
30 #ifndef _SYS_PRIOCNTL_H
31 #define _SYS_PRIOCNTL_H
33 #pragma ident "%Z%%M% %I% %E% SMI" /* from SVR4 1.6 */
35 #include <sys/types.h>
36 #include <sys/procset.h>
42 #define PC_VERSION 1 /* First version of priocntl */
45 extern long priocntl(idtype_t
, id_t
, int, ...);
46 extern long priocntlset(procset_t
*, int, ...);
48 extern long priocntl(), priocntlset();
52 * The following are the possible values of the command
53 * argument for the priocntl system call.
56 #define PC_GETCID 0 /* Get class ID */
57 #define PC_GETCLINFO 1 /* Get info about a configured class */
58 #define PC_SETPARMS 2 /* Set scheduling parameters */
59 #define PC_GETPARMS 3 /* Get scheduling parameters */
60 #define PC_ADMIN 4 /* Scheduler administration (used by */
61 /* dispadmin(1M), not for general use) */
62 #define PC_GETPRIRANGE 5 /* Get priority range for a class */
63 /* posix.4 scheduling, not for general use */
64 #define PC_DONICE 6 /* Set or get nice value */
65 #define PC_SETXPARMS 7 /* Set extended scheduling parameters */
66 #define PC_GETXPARMS 8 /* Get extended scheduling parameters */
67 #define PC_SETDFLCL 9 /* Set default class, not for general use */
68 #define PC_GETDFLCL 10 /* Get default class, not for general use */
69 #define PC_DOPRIO 11 /* Set or get priority, not for general use */
74 #define PC_CLINFOSZ (32 / sizeof (int))
75 #define PC_CLPARMSZ (32 / sizeof (int))
83 typedef struct pcinfo
{
84 id_t pc_cid
; /* class id */
85 char pc_clname
[PC_CLNMSZ
]; /* class name */
86 int pc_clinfo
[PC_CLINFOSZ
]; /* class information */
89 typedef struct pcparms
{
90 id_t pc_cid
; /* process class */
91 int pc_clparms
[PC_CLPARMSZ
]; /* class specific parameters */
94 typedef struct pcnice
{
95 int pc_val
; /* nice value */
96 int pc_op
; /* type of operation, set or get */
99 typedef struct pcprio
{
100 int pc_op
; /* type of operation, set or get */
101 id_t pc_cid
; /* class id */
102 int pc_val
; /* priority value */
106 * The following is used by the priocntl(2) varargs interface (command
107 * codes: PC_SETXPARMS and PC_GETXPARMS).
110 #define PC_VAPARMCNT 8 /* maximal number of (key, value) pairs */
111 #define PC_KY_NULL 0 /* terminates the (key, value) pair chain */
112 #define PC_KY_CLNAME 1 /* get the class name of a process or LWP. */
114 typedef struct pc_vaparm
{
115 int pc_key
; /* describing key */
116 u_longlong_t pc_parm
; /* associated parameter */
119 typedef struct pc_vaparms
{
120 uint_t pc_vaparmscnt
; /* # of (key, value) pairs */
121 pc_vaparm_t pc_parms
[PC_VAPARMCNT
]; /* parameter buffer */
124 #if defined(_SYSCALL32) && \
125 _LONG_LONG_ALIGNMENT == 8 && _LONG_LONG_ALIGNMENT_32 == 4
128 * These structures are needed by the 64-bit kernel on certain architectures
129 * to translate pc_vaparms_t/pc_vaparm_t data structures from 32-bit userland.
134 int32_t pc_key
; /* describing key */
135 uint64_t pc_parm
; /* associated parameter */
141 uint32_t pc_vaparmscnt
; /* # of (key, value) pairs */
142 pc_vaparm32_t pc_parms
[PC_VAPARMCNT
]; /* parameter buffer */
145 #endif /* _SYSCALL32 && ... */
148 * The following is used by libc for posix.4
149 * scheduler interfaces and is not for general use.
152 typedef struct pcpri
{
153 id_t pc_cid
; /* process class */
154 pri_t pc_clpmax
; /* class priority max */
155 pri_t pc_clpmin
; /* class priority min */
159 * The following is used by the dispadmin(1M) command for
160 * scheduler administration and is not for general use.
164 /* Data structure for ILP32 clients */
165 typedef struct pcadmin32
{
167 caddr32_t pc_cladmin
;
169 #endif /* _SYSCALL32 */
171 typedef struct pcadmin
{
180 #endif /* _SYS_PRIOCNTL_H */