xref: /titanic_50/usr/src/cmd/zonecfg/zonecfg.h (revision 803376f094adaaf2e4d9aa1c1d0efd56b642d838)
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 (the "License").
6  * You may not use this file except in compliance with the License.
7  *
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.
12  *
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]
18  *
19  * CDDL HEADER END
20  */
21 
22 /*
23  * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
24  */
25 
26 #ifndef _ZONECFG_H
27 #define	_ZONECFG_H
28 
29 /*
30  * header file for zonecfg command
31  */
32 
33 #ifdef __cplusplus
34 extern "C" {
35 #endif
36 
37 #include <unistd.h>
38 
39 #define	Z_ERR		1
40 #define	Z_USAGE		2
41 #define	Z_REPEAT	3
42 
43 #define	CMD_ADD		0
44 #define	CMD_CANCEL	1
45 #define	CMD_CLEAR	2
46 #define	CMD_COMMIT	3
47 #define	CMD_CREATE	4
48 #define	CMD_DELETE	5
49 #define	CMD_END		6
50 #define	CMD_EXIT	7
51 #define	CMD_EXPORT	8
52 #define	CMD_HELP	9
53 #define	CMD_INFO	10
54 #define	CMD_REMOVE	11
55 #define	CMD_REVERT	12
56 #define	CMD_SELECT	13
57 #define	CMD_SET		14
58 #define	CMD_VERIFY	15
59 
60 #define	CMD_MIN		CMD_ADD
61 #define	CMD_MAX		CMD_VERIFY
62 
63 /* resource types: increment RT_MAX when expanding this list */
64 #define	RT_UNKNOWN	0
65 #define	RT_ZONENAME	1	/* really a property, but for info ... */
66 #define	RT_ZONEPATH	2	/* really a property, but for info ... */
67 #define	RT_AUTOBOOT	3	/* really a property, but for info ... */
68 #define	RT_POOL		4	/* really a property, but for info ... */
69 #define	RT_FS		5
70 #define	RT_NET		6
71 #define	RT_DEVICE	7
72 #define	RT_RCTL		8
73 #define	RT_ATTR		9
74 #define	RT_DATASET	10
75 #define	RT_LIMITPRIV	11	/* really a property, but for info ... */
76 #define	RT_BOOTARGS	12	/* really a property, but for info ... */
77 #define	RT_BRAND	13	/* really a property, but for info ... */
78 #define	RT_DCPU		14
79 #define	RT_MCAP		15
80 #define	RT_MAXLWPS	16	/* really a rctl alias property, but for info */
81 #define	RT_MAXSHMMEM	17	/* really a rctl alias property, but for info */
82 #define	RT_MAXSHMIDS	18	/* really a rctl alias property, but for info */
83 #define	RT_MAXMSGIDS	19	/* really a rctl alias property, but for info */
84 #define	RT_MAXSEMIDS	20	/* really a rctl alias property, but for info */
85 #define	RT_SHARES	21	/* really a rctl alias property, but for info */
86 #define	RT_SCHED	22	/* really a property, but for info ... */
87 #define	RT_IPTYPE	23	/* really a property, but for info ... */
88 #define	RT_PCAP		24
89 #define	RT_HOSTID	25	/* really a property, but for info ... */
90 #define	RT_ADMIN	26
91 #define	RT_FS_ALLOWED	27
92 #define	RT_MAXPROCS	28	/* really a rctl alias property, but for info */
93 
94 #define	RT_MIN		RT_UNKNOWN
95 #define	RT_MAX		RT_MAXPROCS
96 
97 /* property types: increment PT_MAX when expanding this list */
98 #define	PT_UNKNOWN	0
99 #define	PT_ZONENAME	1
100 #define	PT_ZONEPATH	2
101 #define	PT_AUTOBOOT	3
102 #define	PT_POOL		4
103 #define	PT_DIR		5
104 #define	PT_SPECIAL	6
105 #define	PT_TYPE		7
106 #define	PT_OPTIONS	8
107 #define	PT_ADDRESS	9
108 #define	PT_PHYSICAL	10
109 #define	PT_NAME		11
110 #define	PT_VALUE	12
111 #define	PT_MATCH	13
112 #define	PT_PRIV		14
113 #define	PT_LIMIT	15
114 #define	PT_ACTION	16
115 #define	PT_RAW		17
116 #define	PT_LIMITPRIV	18
117 #define	PT_BOOTARGS	19
118 #define	PT_BRAND	20
119 #define	PT_NCPUS	21
120 #define	PT_IMPORTANCE	22
121 #define	PT_SWAP		23
122 #define	PT_LOCKED	24
123 #define	PT_SHARES	25
124 #define	PT_MAXLWPS	26
125 #define	PT_MAXSHMMEM	27
126 #define	PT_MAXSHMIDS	28
127 #define	PT_MAXMSGIDS	29
128 #define	PT_MAXSEMIDS	30
129 #define	PT_MAXLOCKEDMEM	31
130 #define	PT_MAXSWAP	32
131 #define	PT_SCHED	33
132 #define	PT_IPTYPE	34
133 #define	PT_DEFROUTER	35
134 #define	PT_HOSTID	36
135 #define	PT_USER		37
136 #define	PT_AUTHS	38
137 #define	PT_FS_ALLOWED	39
138 #define	PT_MAXPROCS	40
139 #define	PT_ALLOWED_ADDRESS	41
140 
141 #define	PT_MIN		PT_UNKNOWN
142 #define	PT_MAX		PT_ALLOWED_ADDRESS
143 
144 #define	MAX_EQ_PROP_PAIRS	3
145 
146 #define	PROP_VAL_SIMPLE		0
147 #define	PROP_VAL_COMPLEX	1
148 #define	PROP_VAL_LIST		2
149 
150 #define	PROP_VAL_MIN		PROP_VAL_SIMPLE
151 #define	PROP_VAL_MAX		PROP_VAL_LIST
152 
153 /*
154  * If any subcommand is ever modified to take more than three arguments,
155  * this will need to be incremented.
156  */
157 #define	MAX_SUBCMD_ARGS		3
158 
159 typedef struct complex_property {
160 	int	cp_type;	/* from the PT_* list above */
161 	char	*cp_value;
162 	struct complex_property *cp_next;
163 } complex_property_t, *complex_property_ptr_t;
164 
165 typedef struct list_property {
166 	char	*lp_simple;
167 	complex_property_ptr_t	lp_complex;
168 	struct list_property	*lp_next;
169 } list_property_t, *list_property_ptr_t;
170 
171 typedef struct property_value {
172 	int	pv_type;	/* from the PROP_VAL_* list above */
173 	char	*pv_simple;
174 	complex_property_ptr_t	pv_complex;
175 	list_property_ptr_t	pv_list;
176 } property_value_t, *property_value_ptr_t;
177 
178 typedef struct cmd {
179 	char	*cmd_name;
180 	void	(*cmd_handler)(struct cmd *);
181 	int	cmd_res_type;
182 	int	cmd_prop_nv_pairs;
183 	int	cmd_prop_name[MAX_EQ_PROP_PAIRS];
184 	property_value_ptr_t	cmd_property_ptr[MAX_EQ_PROP_PAIRS];
185 	int	cmd_argc;
186 	char	*cmd_argv[MAX_SUBCMD_ARGS + 1];
187 } cmd_t;
188 
189 #define	HELP_USAGE	0x01
190 #define	HELP_SUBCMDS	0x02
191 #define	HELP_SYNTAX	0x04
192 #define	HELP_RESOURCES	0x08
193 #define	HELP_PROPS	0x10
194 #define	HELP_META	0x20
195 #define	HELP_NETADDR	0x40
196 #define	HELP_RES_SCOPE	0x80
197 
198 #define	HELP_RES_PROPS	(HELP_RESOURCES | HELP_PROPS)
199 
200 extern void add_func(cmd_t *);
201 extern void cancel_func(cmd_t *);
202 extern void commit_func(cmd_t *);
203 extern void create_func(cmd_t *);
204 extern void delete_func(cmd_t *);
205 extern void end_func(cmd_t *);
206 extern void exit_func(cmd_t *);
207 extern void export_func(cmd_t *);
208 extern void help_func(cmd_t *);
209 extern void info_func(cmd_t *);
210 extern void remove_func(cmd_t *);
211 extern void revert_func(cmd_t *);
212 extern void select_func(cmd_t *);
213 extern void set_func(cmd_t *);
214 extern void verify_func(cmd_t *);
215 extern void clear_func(cmd_t *);
216 
217 extern cmd_t *alloc_cmd(void);
218 extern complex_property_ptr_t alloc_complex(void);
219 extern list_property_ptr_t alloc_list(void);
220 extern void free_cmd(cmd_t *cmd);
221 extern void free_complex(complex_property_ptr_t complex);
222 extern void free_list(list_property_ptr_t list);
223 extern void free_outer_list(list_property_ptr_t list);
224 
225 extern void usage(boolean_t verbose, uint_t flags);
226 
227 extern FILE *yyin;
228 extern char *res_types[];
229 extern char *prop_types[];
230 
231 /*
232  * NOTE: Only Lex and YACC should use the following functions.
233  */
234 extern void assert_no_unclaimed_tokens(void);
235 extern char *claim_token(char *);
236 
237 #ifdef __cplusplus
238 }
239 #endif
240 
241 #endif	/* _ZONECFG_H */
242