xref: /titanic_53/usr/src/cmd/zoneadmd/zoneadmd.h (revision c5cd6260c3d6c06a9359df595ad9dddbfd00a80e)
17c478bd9Sstevel@tonic-gate /*
27c478bd9Sstevel@tonic-gate  * CDDL HEADER START
37c478bd9Sstevel@tonic-gate  *
47c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
5ffbafc53Scomay  * Common Development and Distribution License (the "License").
6ffbafc53Scomay  * You may not use this file except in compliance with the License.
77c478bd9Sstevel@tonic-gate  *
87c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
97c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
107c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
117c478bd9Sstevel@tonic-gate  * and limitations under the License.
127c478bd9Sstevel@tonic-gate  *
137c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
147c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
157c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
167c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
177c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
187c478bd9Sstevel@tonic-gate  *
197c478bd9Sstevel@tonic-gate  * CDDL HEADER END
207c478bd9Sstevel@tonic-gate  */
21ffbafc53Scomay 
227c478bd9Sstevel@tonic-gate /*
236cfd72c6Sgjelinek  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
247c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
257c478bd9Sstevel@tonic-gate  */
267c478bd9Sstevel@tonic-gate 
277c478bd9Sstevel@tonic-gate #ifndef	_ZONEADMD_H
287c478bd9Sstevel@tonic-gate #define	_ZONEADMD_H
297c478bd9Sstevel@tonic-gate 
307c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
317c478bd9Sstevel@tonic-gate extern "C" {
327c478bd9Sstevel@tonic-gate #endif
337c478bd9Sstevel@tonic-gate 
347c478bd9Sstevel@tonic-gate /*
357c478bd9Sstevel@tonic-gate  * Multi-threaded programs should avoid MT-unsafe library calls (i.e., any-
367c478bd9Sstevel@tonic-gate  * thing which could try to acquire a user-level lock unprotected by an atfork
377c478bd9Sstevel@tonic-gate  * handler) between fork(2) and exec(2).  See the pthread_atfork(3THR) man
387c478bd9Sstevel@tonic-gate  * page for details.  In particular, we want to avoid calls to zerror() in
397c478bd9Sstevel@tonic-gate  * such situations, as it calls setlocale(3c) which is susceptible to such
407c478bd9Sstevel@tonic-gate  * problems.  So instead we have the child use one of the special exit codes
417c478bd9Sstevel@tonic-gate  * below when needed, and the parent look out for such possibilities and call
427c478bd9Sstevel@tonic-gate  * zerror() there.
437c478bd9Sstevel@tonic-gate  *
447c478bd9Sstevel@tonic-gate  * Since 0, 1 and 2 are generally used for success, general error, and usage,
457c478bd9Sstevel@tonic-gate  * we start with 3.
467c478bd9Sstevel@tonic-gate  */
477c478bd9Sstevel@tonic-gate #define	ZEXIT_FORK		3
487c478bd9Sstevel@tonic-gate #define	ZEXIT_EXEC		4
497c478bd9Sstevel@tonic-gate #define	ZEXIT_ZONE_ENTER	5
507c478bd9Sstevel@tonic-gate 
517c478bd9Sstevel@tonic-gate #define	DEVFSADM	"devfsadm"
527c478bd9Sstevel@tonic-gate #define	DEVFSADM_PATH	"/usr/sbin/devfsadm"
537c478bd9Sstevel@tonic-gate 
549acbbeafSnn35248 #define	EXEC_PREFIX	"exec "
559acbbeafSnn35248 #define	EXEC_LEN	(strlen(EXEC_PREFIX))
569acbbeafSnn35248 
5784561e8cStd153743 #define	CLUSTER_BRAND_NAME	"cluster"
5884561e8cStd153743 
59d314f035Sedp /* 0755 is the default directory mode. */
60d314f035Sedp #define	DEFAULT_DIR_MODE \
61d314f035Sedp 	(S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH)
62d314f035Sedp #define	DEFAULT_DIR_USER -1	/* user ID for chown: -1 means don't change */
63d314f035Sedp #define	DEFAULT_DIR_GROUP -1	/* grp ID for chown: -1 means don't change */
64d314f035Sedp 
65d314f035Sedp 
667c478bd9Sstevel@tonic-gate typedef struct zlog {
677c478bd9Sstevel@tonic-gate 	FILE *logfile;	/* file to log to */
687c478bd9Sstevel@tonic-gate 
697c478bd9Sstevel@tonic-gate 	/*
707c478bd9Sstevel@tonic-gate 	 * The following are used if logging to a buffer.
717c478bd9Sstevel@tonic-gate 	 */
727c478bd9Sstevel@tonic-gate 	char *log;	/* remaining log */
737c478bd9Sstevel@tonic-gate 	size_t loglen;	/* size of remaining log */
747c478bd9Sstevel@tonic-gate 	char *buf;	/* underlying storage */
757c478bd9Sstevel@tonic-gate 	size_t buflen;	/* total len of 'buf' */
767c478bd9Sstevel@tonic-gate 	char *locale;	/* locale to use for gettext() */
777c478bd9Sstevel@tonic-gate } zlog_t;
787c478bd9Sstevel@tonic-gate 
7922321485Svp157776 extern zlog_t logsys;
8022321485Svp157776 
817c478bd9Sstevel@tonic-gate extern mutex_t lock;
827c478bd9Sstevel@tonic-gate extern mutex_t msglock;
837c478bd9Sstevel@tonic-gate extern boolean_t in_death_throes;
847c478bd9Sstevel@tonic-gate extern boolean_t bringup_failure_recovery;
857c478bd9Sstevel@tonic-gate extern char *zone_name;
863f2f09c1Sdp extern char boot_args[BOOTARGS_MAX];
873f2f09c1Sdp extern char bad_boot_arg[BOOTARGS_MAX];
889acbbeafSnn35248 extern boolean_t zone_isnative;
8984561e8cStd153743 extern boolean_t zone_iscluster;
907c478bd9Sstevel@tonic-gate 
917c478bd9Sstevel@tonic-gate extern void zerror(zlog_t *, boolean_t, const char *, ...);
927c478bd9Sstevel@tonic-gate extern char *localize_msg(char *locale, const char *msg);
937c478bd9Sstevel@tonic-gate 
947c478bd9Sstevel@tonic-gate /*
957c478bd9Sstevel@tonic-gate  * Eventstream interfaces.
967c478bd9Sstevel@tonic-gate  */
977c478bd9Sstevel@tonic-gate typedef enum {
987c478bd9Sstevel@tonic-gate 	Z_EVT_NULL = 0,
997c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_BOOTING,
1007c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_REBOOTING,
1017c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_HALTED,
1027c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_READIED,
103ffbafc53Scomay 	Z_EVT_ZONE_UNINSTALLING,
1043f2f09c1Sdp 	Z_EVT_ZONE_BOOTFAILED,
1053f2f09c1Sdp 	Z_EVT_ZONE_BADARGS
1067c478bd9Sstevel@tonic-gate } zone_evt_t;
1077c478bd9Sstevel@tonic-gate 
1087c478bd9Sstevel@tonic-gate extern int eventstream_init();
1097c478bd9Sstevel@tonic-gate extern void eventstream_write(zone_evt_t evt);
1107c478bd9Sstevel@tonic-gate 
1117c478bd9Sstevel@tonic-gate /*
1126cfd72c6Sgjelinek  * Zone mount styles.  Boot is the standard mount we do when booting the zone,
1136cfd72c6Sgjelinek  * scratch is the standard scratch zone mount for upgrade and update is a
1146cfd72c6Sgjelinek  * variation on the scratch zone where we don't lofs mount the zone's /etc
1156cfd72c6Sgjelinek  * and /var back into the scratch zone so that we can then do an
1166cfd72c6Sgjelinek  * 'update on attach' within the scratch zone.
1176cfd72c6Sgjelinek  */
1186cfd72c6Sgjelinek typedef enum {
1196cfd72c6Sgjelinek 	Z_MNT_BOOT = 0,
1206cfd72c6Sgjelinek 	Z_MNT_SCRATCH,
1216cfd72c6Sgjelinek 	Z_MNT_UPDATE
1226cfd72c6Sgjelinek } zone_mnt_t;
1236cfd72c6Sgjelinek 
1246cfd72c6Sgjelinek /*
1257c478bd9Sstevel@tonic-gate  * Virtual platform interfaces.
1267c478bd9Sstevel@tonic-gate  */
1276cfd72c6Sgjelinek extern zoneid_t vplat_create(zlog_t *, zone_mnt_t);
1286cfd72c6Sgjelinek extern int vplat_bringup(zlog_t *, zone_mnt_t, zoneid_t);
1290209230bSgjelinek extern int vplat_teardown(zlog_t *, boolean_t, boolean_t);
1307c478bd9Sstevel@tonic-gate 
1317c478bd9Sstevel@tonic-gate /*
132d314f035Sedp  * Filesystem mounting interfaces.
133d314f035Sedp  */
134d314f035Sedp extern int valid_mount_path(zlog_t *, const char *, const char *,
135d314f035Sedp     const char *, const char *);
136d314f035Sedp extern int make_one_dir(zlog_t *, const char *, const char *,
137d314f035Sedp     mode_t, uid_t, gid_t);
138910f48daSedp extern void resolve_lofs(zlog_t *zlogp, char *path, size_t pathlen);
139d314f035Sedp 
140d314f035Sedp /*
1417c478bd9Sstevel@tonic-gate  * Console subsystem routines.
1427c478bd9Sstevel@tonic-gate  */
1437c478bd9Sstevel@tonic-gate extern int init_console_slave(zlog_t *);
1447c478bd9Sstevel@tonic-gate extern void destroy_console_slave(void);
1457c478bd9Sstevel@tonic-gate extern void reset_slave_terminal(zlog_t *);
1467c478bd9Sstevel@tonic-gate extern int init_console(zlog_t *);
1477c478bd9Sstevel@tonic-gate extern void serve_console(zlog_t *);
1487c478bd9Sstevel@tonic-gate 
149555afedfScarlsonj /*
150555afedfScarlsonj  * Contract handling.
151555afedfScarlsonj  */
152555afedfScarlsonj extern int init_template(void);
153555afedfScarlsonj 
1549acbbeafSnn35248 /*
1559acbbeafSnn35248  * Routine to manage child processes.
1569acbbeafSnn35248  */
157*c5cd6260S extern int do_subproc(zlog_t *, char *, char **);
1589acbbeafSnn35248 
1597c478bd9Sstevel@tonic-gate #ifdef __cplusplus
1607c478bd9Sstevel@tonic-gate }
1617c478bd9Sstevel@tonic-gate #endif
1627c478bd9Sstevel@tonic-gate 
1637c478bd9Sstevel@tonic-gate #endif /* _ZONEADMD_H */
164