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.
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.
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]
23 * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
24 * Copyright 2014 Nexenta Systems, Inc. All rights reserved.
37 * Multi-threaded programs should avoid MT-unsafe library calls (i.e., any-
38 * thing which could try to acquire a user-level lock unprotected by an atfork
39 * handler) between fork(2) and exec(2). See the pthread_atfork(3THR) man
40 * page for details. In particular, we want to avoid calls to zerror() in
41 * such situations, as it calls setlocale(3c) which is susceptible to such
42 * problems. So instead we have the child use one of the special exit codes
43 * below when needed, and the parent look out for such possibilities and call
46 * Since 0, 1 and 2 are generally used for success, general error, and usage,
51 #define ZEXIT_ZONE_ENTER 5
53 #define DEVFSADM "devfsadm"
54 #define DEVFSADM_PATH "/usr/sbin/devfsadm"
56 #define EXEC_PREFIX "exec "
57 #define EXEC_LEN (strlen(EXEC_PREFIX))
59 #define CLUSTER_BRAND_NAME "cluster"
60 #define LABELED_BRAND_NAME "labeled"
62 #define SHUTDOWN_WAIT 60
63 #define SHUTDOWN_DEFAULT "/sbin/init 0"
64 #define SHUTDOWN_FMRI "svc:/system/zones:default"
66 /* 0755 is the default directory mode. */
67 #define DEFAULT_DIR_MODE \
68 (S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH)
69 #define DEFAULT_DIR_USER -1 /* user ID for chown: -1 means don't change */
70 #define DEFAULT_DIR_GROUP -1 /* grp ID for chown: -1 means don't change */
74 FILE *logfile
; /* file to log to */
77 * The following are used if logging to a buffer.
79 char *log
; /* remaining log */
80 size_t loglen
; /* size of remaining log */
81 char *buf
; /* underlying storage */
82 size_t buflen
; /* total len of 'buf' */
83 char *locale
; /* locale to use for gettext() */
89 extern mutex_t msglock
;
90 extern boolean_t in_death_throes
;
91 extern boolean_t bringup_failure_recovery
;
92 extern char *zone_name
;
93 extern char pool_name
[MAXNAMELEN
];
94 extern char brand_name
[MAXNAMELEN
];
95 extern char default_brand
[MAXNAMELEN
];
96 extern char boot_args
[BOOTARGS_MAX
];
97 extern char bad_boot_arg
[BOOTARGS_MAX
];
98 extern boolean_t zone_isnative
;
99 extern boolean_t zone_iscluster
;
100 extern dladm_handle_t dld_handle
;
102 extern void zerror(zlog_t
*, boolean_t
, const char *, ...);
103 extern char *localize_msg(char *locale
, const char *msg
);
106 * Eventstream interfaces.
111 Z_EVT_ZONE_REBOOTING
,
114 Z_EVT_ZONE_UNINSTALLING
,
115 Z_EVT_ZONE_BOOTFAILED
,
119 extern int eventstream_init();
120 extern void eventstream_write(zone_evt_t evt
);
123 * Zone mount styles. Boot is the standard mount we do when booting the zone,
124 * scratch is the standard scratch zone mount for upgrade and update is a
125 * variation on the scratch zone where we don't lofs mount the zone's /etc
126 * and /var back into the scratch zone so that we can then do an
127 * 'update on attach' within the scratch zone.
136 * Virtual platform interfaces.
138 extern zoneid_t
vplat_create(zlog_t
*, zone_mnt_t
);
139 extern int vplat_bringup(zlog_t
*, zone_mnt_t
, zoneid_t
);
140 extern int vplat_teardown(zlog_t
*, boolean_t
, boolean_t
);
141 extern int vplat_get_iptype(zlog_t
*, zone_iptype_t
*);
144 * Filesystem mounting interfaces.
146 extern int valid_mount_path(zlog_t
*, const char *, const char *,
147 const char *, const char *);
148 extern int make_one_dir(zlog_t
*, const char *, const char *,
149 mode_t
, uid_t
, gid_t
);
150 extern void resolve_lofs(zlog_t
*zlogp
, char *path
, size_t pathlen
);
153 * Console subsystem routines.
155 extern int init_console(zlog_t
*);
156 extern void serve_console(zlog_t
*);
161 extern int init_template(void);
164 * Routine to manage child processes.
166 extern int do_subproc(zlog_t
*, char *, char **);
172 #endif /* _ZONEADMD_H */