xref: /titanic_53/usr/src/cmd/zoneadmd/zoneadmd.h (revision 9d5056ea37dd689d393cb1715ae29551bc0eba2e)
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 /*
23*9d5056eaSjv227347  * Copyright 2009 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 
344ac67f02SAnurag S. Maskey #include <libdladm.h>
354ac67f02SAnurag S. Maskey 
367c478bd9Sstevel@tonic-gate /*
377c478bd9Sstevel@tonic-gate  * Multi-threaded programs should avoid MT-unsafe library calls (i.e., any-
387c478bd9Sstevel@tonic-gate  * thing which could try to acquire a user-level lock unprotected by an atfork
397c478bd9Sstevel@tonic-gate  * handler) between fork(2) and exec(2).  See the pthread_atfork(3THR) man
407c478bd9Sstevel@tonic-gate  * page for details.  In particular, we want to avoid calls to zerror() in
417c478bd9Sstevel@tonic-gate  * such situations, as it calls setlocale(3c) which is susceptible to such
427c478bd9Sstevel@tonic-gate  * problems.  So instead we have the child use one of the special exit codes
437c478bd9Sstevel@tonic-gate  * below when needed, and the parent look out for such possibilities and call
447c478bd9Sstevel@tonic-gate  * zerror() there.
457c478bd9Sstevel@tonic-gate  *
467c478bd9Sstevel@tonic-gate  * Since 0, 1 and 2 are generally used for success, general error, and usage,
477c478bd9Sstevel@tonic-gate  * we start with 3.
487c478bd9Sstevel@tonic-gate  */
497c478bd9Sstevel@tonic-gate #define	ZEXIT_FORK		3
507c478bd9Sstevel@tonic-gate #define	ZEXIT_EXEC		4
517c478bd9Sstevel@tonic-gate #define	ZEXIT_ZONE_ENTER	5
527c478bd9Sstevel@tonic-gate 
537c478bd9Sstevel@tonic-gate #define	DEVFSADM	"devfsadm"
547c478bd9Sstevel@tonic-gate #define	DEVFSADM_PATH	"/usr/sbin/devfsadm"
557c478bd9Sstevel@tonic-gate 
569acbbeafSnn35248 #define	EXEC_PREFIX	"exec "
579acbbeafSnn35248 #define	EXEC_LEN	(strlen(EXEC_PREFIX))
589acbbeafSnn35248 
5984561e8cStd153743 #define	CLUSTER_BRAND_NAME	"cluster"
6084561e8cStd153743 
61d314f035Sedp /* 0755 is the default directory mode. */
62d314f035Sedp #define	DEFAULT_DIR_MODE \
63d314f035Sedp 	(S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH)
64d314f035Sedp #define	DEFAULT_DIR_USER -1	/* user ID for chown: -1 means don't change */
65d314f035Sedp #define	DEFAULT_DIR_GROUP -1	/* grp ID for chown: -1 means don't change */
66d314f035Sedp 
67d314f035Sedp 
687c478bd9Sstevel@tonic-gate typedef struct zlog {
697c478bd9Sstevel@tonic-gate 	FILE *logfile;	/* file to log to */
707c478bd9Sstevel@tonic-gate 
717c478bd9Sstevel@tonic-gate 	/*
727c478bd9Sstevel@tonic-gate 	 * The following are used if logging to a buffer.
737c478bd9Sstevel@tonic-gate 	 */
747c478bd9Sstevel@tonic-gate 	char *log;	/* remaining log */
757c478bd9Sstevel@tonic-gate 	size_t loglen;	/* size of remaining log */
767c478bd9Sstevel@tonic-gate 	char *buf;	/* underlying storage */
777c478bd9Sstevel@tonic-gate 	size_t buflen;	/* total len of 'buf' */
787c478bd9Sstevel@tonic-gate 	char *locale;	/* locale to use for gettext() */
797c478bd9Sstevel@tonic-gate } zlog_t;
807c478bd9Sstevel@tonic-gate 
8122321485Svp157776 extern zlog_t logsys;
8222321485Svp157776 
837c478bd9Sstevel@tonic-gate extern mutex_t lock;
847c478bd9Sstevel@tonic-gate extern mutex_t msglock;
857c478bd9Sstevel@tonic-gate extern boolean_t in_death_throes;
867c478bd9Sstevel@tonic-gate extern boolean_t bringup_failure_recovery;
877c478bd9Sstevel@tonic-gate extern char *zone_name;
883f2f09c1Sdp extern char boot_args[BOOTARGS_MAX];
893f2f09c1Sdp extern char bad_boot_arg[BOOTARGS_MAX];
909acbbeafSnn35248 extern boolean_t zone_isnative;
9184561e8cStd153743 extern boolean_t zone_iscluster;
924ac67f02SAnurag S. Maskey extern dladm_handle_t dld_handle;
937c478bd9Sstevel@tonic-gate 
947c478bd9Sstevel@tonic-gate extern void zerror(zlog_t *, boolean_t, const char *, ...);
957c478bd9Sstevel@tonic-gate extern char *localize_msg(char *locale, const char *msg);
967c478bd9Sstevel@tonic-gate 
977c478bd9Sstevel@tonic-gate /*
987c478bd9Sstevel@tonic-gate  * Eventstream interfaces.
997c478bd9Sstevel@tonic-gate  */
1007c478bd9Sstevel@tonic-gate typedef enum {
1017c478bd9Sstevel@tonic-gate 	Z_EVT_NULL = 0,
1027c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_BOOTING,
1037c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_REBOOTING,
1047c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_HALTED,
1057c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_READIED,
106ffbafc53Scomay 	Z_EVT_ZONE_UNINSTALLING,
1073f2f09c1Sdp 	Z_EVT_ZONE_BOOTFAILED,
1083f2f09c1Sdp 	Z_EVT_ZONE_BADARGS
1097c478bd9Sstevel@tonic-gate } zone_evt_t;
1107c478bd9Sstevel@tonic-gate 
1117c478bd9Sstevel@tonic-gate extern int eventstream_init();
1127c478bd9Sstevel@tonic-gate extern void eventstream_write(zone_evt_t evt);
1137c478bd9Sstevel@tonic-gate 
1147c478bd9Sstevel@tonic-gate /*
1156cfd72c6Sgjelinek  * Zone mount styles.  Boot is the standard mount we do when booting the zone,
1166cfd72c6Sgjelinek  * scratch is the standard scratch zone mount for upgrade and update is a
1176cfd72c6Sgjelinek  * variation on the scratch zone where we don't lofs mount the zone's /etc
1186cfd72c6Sgjelinek  * and /var back into the scratch zone so that we can then do an
1196cfd72c6Sgjelinek  * 'update on attach' within the scratch zone.
1206cfd72c6Sgjelinek  */
1216cfd72c6Sgjelinek typedef enum {
1226cfd72c6Sgjelinek 	Z_MNT_BOOT = 0,
1236cfd72c6Sgjelinek 	Z_MNT_SCRATCH,
1246cfd72c6Sgjelinek 	Z_MNT_UPDATE
1256cfd72c6Sgjelinek } zone_mnt_t;
1266cfd72c6Sgjelinek 
1276cfd72c6Sgjelinek /*
1287c478bd9Sstevel@tonic-gate  * Virtual platform interfaces.
1297c478bd9Sstevel@tonic-gate  */
1306cfd72c6Sgjelinek extern zoneid_t vplat_create(zlog_t *, zone_mnt_t);
1316cfd72c6Sgjelinek extern int vplat_bringup(zlog_t *, zone_mnt_t, zoneid_t);
1320209230bSgjelinek extern int vplat_teardown(zlog_t *, boolean_t, boolean_t);
1337c478bd9Sstevel@tonic-gate 
1347c478bd9Sstevel@tonic-gate /*
135d314f035Sedp  * Filesystem mounting interfaces.
136d314f035Sedp  */
137d314f035Sedp extern int valid_mount_path(zlog_t *, const char *, const char *,
138d314f035Sedp     const char *, const char *);
139d314f035Sedp extern int make_one_dir(zlog_t *, const char *, const char *,
140d314f035Sedp     mode_t, uid_t, gid_t);
141910f48daSedp extern void resolve_lofs(zlog_t *zlogp, char *path, size_t pathlen);
142d314f035Sedp 
143d314f035Sedp /*
1447c478bd9Sstevel@tonic-gate  * Console subsystem routines.
1457c478bd9Sstevel@tonic-gate  */
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  */
157c5cd6260S 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