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