xref: /illumos-gate/usr/src/cmd/zonecfg/zonecfg.h (revision 753d2d2e8e7fd0c9bcf736d9bf2f2faf4d6234cc)
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 2006 Sun Microsystems, Inc.  All rights reserved.
24  * Use is subject to license terms.
25  */
26 
27 #ifndef _ZONECFG_H
28 #define	_ZONECFG_H
29 
30 #pragma ident	"%Z%%M%	%I%	%E% SMI"
31 
32 /*
33  * header file for zonecfg command
34  */
35 
36 #ifdef __cplusplus
37 extern "C" {
38 #endif
39 
40 #include <unistd.h>
41 
42 #define	FALSE	0
43 #define	TRUE	1
44 
45 typedef int bool;
46 
47 #define	Z_ERR		1
48 #define	Z_USAGE		2
49 #define	Z_REPEAT	3
50 
51 #define	CMD_ADD		0
52 #define	CMD_CANCEL	1
53 #define	CMD_COMMIT	2
54 #define	CMD_CREATE	3
55 #define	CMD_DELETE	4
56 #define	CMD_END		5
57 #define	CMD_EXIT	6
58 #define	CMD_EXPORT	7
59 #define	CMD_HELP	8
60 #define	CMD_INFO	9
61 #define	CMD_REMOVE	10
62 #define	CMD_REVERT	11
63 #define	CMD_SELECT	12
64 #define	CMD_SET		13
65 #define	CMD_VERIFY	14
66 
67 #define	CMD_MIN		CMD_ADD
68 #define	CMD_MAX		CMD_VERIFY
69 
70 /* resource types: increment RT_MAX when expanding this list */
71 #define	RT_UNKNOWN	0
72 #define	RT_ZONENAME	1	/* really a property, but for info ... */
73 #define	RT_ZONEPATH	2	/* really a property, but for info ... */
74 #define	RT_AUTOBOOT	3	/* really a property, but for info ... */
75 #define	RT_POOL		4	/* really a property, but for info ... */
76 #define	RT_FS		5
77 #define	RT_IPD		6
78 #define	RT_NET		7
79 #define	RT_DEVICE	8
80 #define	RT_RCTL		9
81 #define	RT_ATTR		10
82 #define	RT_DATASET	11
83 #define	RT_LIMITPRIV	12	/* really a property, but for info ... */
84 #define	RT_BOOTARGS	13	/* really a property, but for info ... */
85 #define	RT_BRAND	14	/* really a property, but for info ... */
86 
87 #define	RT_MIN		RT_UNKNOWN
88 #define	RT_MAX		RT_BRAND
89 
90 /* property types: increment PT_MAX when expanding this list */
91 #define	PT_UNKNOWN	0
92 #define	PT_ZONENAME	1
93 #define	PT_ZONEPATH	2
94 #define	PT_AUTOBOOT	3
95 #define	PT_POOL		4
96 #define	PT_DIR		5
97 #define	PT_SPECIAL	6
98 #define	PT_TYPE		7
99 #define	PT_OPTIONS	8
100 #define	PT_ADDRESS	9
101 #define	PT_PHYSICAL	10
102 #define	PT_NAME		11
103 #define	PT_VALUE	12
104 #define	PT_MATCH	13
105 #define	PT_PRIV		14
106 #define	PT_LIMIT	15
107 #define	PT_ACTION	16
108 #define	PT_RAW		17
109 #define	PT_LIMITPRIV	18
110 #define	PT_BOOTARGS	19
111 #define	PT_BRAND	20
112 
113 #define	PT_MIN		PT_UNKNOWN
114 #define	PT_MAX		PT_BRAND
115 
116 #define	MAX_EQ_PROP_PAIRS	3
117 
118 #define	PROP_VAL_SIMPLE		0
119 #define	PROP_VAL_COMPLEX	1
120 #define	PROP_VAL_LIST		2
121 
122 #define	PROP_VAL_MIN		PROP_VAL_SIMPLE
123 #define	PROP_VAL_MAX		PROP_VAL_LIST
124 
125 /*
126  * If any subcommand is ever modified to take more than three arguments,
127  * this will need to be incremented.
128  */
129 #define	MAX_SUBCMD_ARGS		3
130 
131 typedef struct complex_property {
132 	int	cp_type;	/* from the PT_* list above */
133 	char	*cp_value;
134 	struct complex_property *cp_next;
135 } complex_property_t, *complex_property_ptr_t;
136 
137 typedef struct list_property {
138 	char	*lp_simple;
139 	complex_property_ptr_t	lp_complex;
140 	struct list_property	*lp_next;
141 } list_property_t, *list_property_ptr_t;
142 
143 typedef struct property_value {
144 	int	pv_type;	/* from the PROP_VAL_* list above */
145 	char	*pv_simple;
146 	complex_property_ptr_t	pv_complex;
147 	list_property_ptr_t	pv_list;
148 } property_value_t, *property_value_ptr_t;
149 
150 typedef struct cmd {
151 	char	*cmd_name;
152 	void	(*cmd_handler)(struct cmd *);
153 	int	cmd_res_type;
154 	int	cmd_prop_nv_pairs;
155 	int	cmd_prop_name[MAX_EQ_PROP_PAIRS];
156 	property_value_ptr_t	cmd_property_ptr[MAX_EQ_PROP_PAIRS];
157 	int	cmd_argc;
158 	char	*cmd_argv[MAX_SUBCMD_ARGS + 1];
159 } cmd_t;
160 
161 #define	HELP_USAGE	0x01
162 #define	HELP_SUBCMDS	0x02
163 #define	HELP_SYNTAX	0x04
164 #define	HELP_RESOURCES	0x08
165 #define	HELP_PROPS	0x10
166 #define	HELP_META	0x20
167 #define	HELP_NETADDR	0x40
168 #define	HELP_RES_SCOPE	0x80
169 
170 #define	HELP_RES_PROPS	(HELP_RESOURCES | HELP_PROPS)
171 
172 extern void add_func(cmd_t *);
173 extern void cancel_func(cmd_t *);
174 extern void commit_func(cmd_t *);
175 extern void create_func(cmd_t *);
176 extern void delete_func(cmd_t *);
177 extern void end_func(cmd_t *);
178 extern void exit_func(cmd_t *);
179 extern void export_func(cmd_t *);
180 extern void help_func(cmd_t *);
181 extern void info_func(cmd_t *);
182 extern void remove_func(cmd_t *);
183 extern void revert_func(cmd_t *);
184 extern void select_func(cmd_t *);
185 extern void set_func(cmd_t *);
186 extern void verify_func(cmd_t *);
187 
188 extern cmd_t *alloc_cmd(void);
189 extern complex_property_ptr_t alloc_complex(void);
190 extern list_property_ptr_t alloc_list(void);
191 extern void free_cmd(cmd_t *cmd);
192 extern void free_complex(complex_property_ptr_t complex);
193 extern void free_list(list_property_ptr_t list);
194 extern void free_outer_list(list_property_ptr_t list);
195 
196 extern void usage(bool verbose, uint_t flags);
197 
198 extern FILE *yyin;
199 
200 #ifdef __cplusplus
201 }
202 #endif
203 
204 #endif	/* _ZONECFG_H */
205