xref: /illumos-gate/usr/src/cmd/rcm_daemon/common/rcm_script_impl.h (revision 613a2f6ba31e891e3d947a356daf5e563d43c1ce)
1 /*
2  * CDDL HEADER START
3  *
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
7  * with the License.
8  *
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.
13  *
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]
19  *
20  * CDDL HEADER END
21  */
22 /*
23  * Copyright (c) 2000-2001 by Sun Microsystems, Inc.
24  * All rights reserved.
25  */
26 
27 #ifndef _RCM_SCRIPT_IMPL_H
28 #define	_RCM_SCRIPT_IMPL_H
29 
30 #pragma ident	"%Z%%M%	%I%	%E% SMI"
31 
32 #ifdef	__cplusplus
33 extern "C" {
34 #endif
35 
36 #define	TRUE	1
37 #define	FALSE	0
38 
39 /* Minimum and maximum rcm scripting API version supported. */
40 #define	SCRIPT_API_MIN_VER		1
41 #define	SCRIPT_API_MAX_VER		1
42 
43 /*
44  * Default maximum time (in seconds) allocated for an rcm command
45  * before SIGABRT is sent.
46  */
47 #define	SCRIPT_CMD_TIMEOUT		60
48 
49 /*
50  * Maximum time (in seconds) allocated after sending SIGABRT before
51  * the script is killed.
52  */
53 #define	SCRIPT_ABORT_TIMEOUT		10
54 
55 /*
56  * Maximum time (in seconds) for which the rcm daemon checks whether
57  * a script is killed or not after the rcm daemon kills the script.
58  */
59 #define	SCRIPT_KILL_TIMEOUT		3
60 
61 /* Maximum number of command line parameters passed to a script */
62 #define	MAX_ARGS			16
63 
64 /* Maximum number of environment parameters passed to a script */
65 #define	MAX_ENV_PARAMS			64
66 
67 #define	MAX_LINE_LEN			(4*1024)
68 #define	MAX_FLAGS_NAME_LEN		64
69 
70 /* exit codes */
71 typedef enum {
72 	E_SUCCESS,
73 	E_FAILURE,
74 	E_UNSUPPORTED_CMD,
75 	E_REFUSE
76 } script_exit_codes_t;
77 
78 /* This structure is used to maintain a list of current dr'ed resources */
79 typedef struct {
80 	rcm_queue_t queue;
81 	char *resource_name;
82 } drreq_t;
83 
84 /*
85  * Main data structure for rcm scripting. There will be one instance of
86  * this structure for every rcm script. A pointer to this structure is
87  * kept in module structure.
88  */
89 typedef struct script_info {
90 	/*
91 	 * Used to maintain a queue of script_info structures
92 	 * Global variable script_info_q is the head of the queue.
93 	 */
94 	rcm_queue_t queue;
95 
96 	rcm_queue_t drreq_q;	/* queue head for current dr'ed resources */
97 
98 	module_t *module;
99 	rcm_handle_t *hdl;
100 
101 	char *script_full_name;	/* name of the script including path */
102 	char *script_name;	/* name of the script without path component */
103 
104 	/*
105 	 * file descriptors used to communicate with the script
106 	 * pipe1 is used to capture script's stdout
107 	 * pipe2 is used to capture script's stderr
108 	 */
109 	int pipe1[2];
110 	int pipe2[2];
111 
112 	pid_t pid;		/* process id of the script process */
113 	thread_t tid;		/* thread id of the stderr reader thread */
114 
115 	/*
116 	 * Lock to protect the fileds in this structure and also to protect
117 	 * the communication channel to the script.
118 	 */
119 	mutex_t channel_lock;
120 
121 	int ver;		/* scripting api version of the script */
122 	int cmd;		/* current rcm scripting command */
123 	int cmd_timeout;	/* timeout value in seconds */
124 	int exit_status;	/* exit status of the script */
125 
126 	/* time stamp of the script when it was last run */
127 	time_t lastrun;
128 
129 	char *func_info_buf;
130 	char *func_info_buf_curptr;
131 	int func_info_buf_len;
132 
133 	char *resource_usage_info_buf;
134 	char *resource_usage_info_buf_curptr;
135 	int resource_usage_info_buf_len;
136 
137 	char *failure_reason_buf;
138 	char *failure_reason_buf_curptr;
139 	int failure_reason_buf_len;
140 	uint_t flags;
141 } script_info_t;
142 
143 /*
144  * script_info_t:flags
145  */
146 #define	STDERR_THREAD_CREATED	1
147 
148 #define	PARENT_END_OF_PIPE	0
149 #define	CHILD_END_OF_PIPE	1
150 
151 #define	PS_STATE_FILE_VER	1
152 
153 typedef struct state_element {
154 	uint32_t flags;
155 	uint32_t reserved;	/* for 64 bit alignment */
156 	/* followed by actual state element */
157 } state_element_t;
158 
159 /*
160  * state_element_t:flags
161  * The following flag when set indicates that the state element is
162  * currently in use. When not set indicates that the state element is free.
163  */
164 #define	STATE_ELEMENT_IN_USE	0x1
165 
166 /*
167  * This structure defines the layout of state file used by rcm scripting
168  */
169 typedef struct state_file {
170 	uint32_t version;
171 	uint32_t max_elements;	/* number of state elements */
172 	/* followed by an array of state elements of type state_element_t */
173 } state_file_t;
174 
175 typedef struct state_file_descr {
176 	uint32_t version;
177 	int fd;			/* file descriptor to the state file */
178 	size_t element_size;	/* size of one state element */
179 
180 	/*
181 	 * number of state elements to allocate at a time when the state file
182 	 * grows.
183 	 */
184 	int chunk_size;
185 
186 	/*
187 	 * index into the state element array where the next search will
188 	 * begin for an empty slot.
189 	 */
190 	int index;
191 
192 	/* pointer to mmapped state file */
193 	state_file_t *state_file;
194 } state_file_descr_t;
195 
196 /* round up to n byte boundary. n must be power of 2 for this macro to work */
197 #define	RSCR_ROUNDUP(x, n)	(((x) + ((n) - 1)) & (~((n) - 1)))
198 
199 typedef struct ps_state_element {
200 	pid_t pid;
201 	char script_name[MAXNAMELEN];
202 } ps_state_element_t;
203 
204 /* maximum number of additional env variables for capacity specific stuff */
205 #define	MAX_CAPACITY_PARAMS	10
206 
207 typedef struct capacity_descr {
208 	char *resource_name;
209 	int match_type;
210 	struct {
211 		char *nvname;
212 		char *envname;
213 	} param[MAX_CAPACITY_PARAMS];
214 } capacity_descr_t;
215 
216 /* capacity_descr_t:match_type */
217 #define	MATCH_INVALID		0
218 #define	MATCH_EXACT		1
219 #define	MATCH_PREFIX		2
220 
221 #ifdef	__cplusplus
222 }
223 #endif
224 
225 #endif /* _RCM_SCRIPT_IMPL_H */
226