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 */