xref: /illumos-gate/usr/src/cmd/zoneadmd/zoneadmd.h (revision 2b24ab6b3865caeede9eeb9db6b83e1d89dcd1ea)
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 /*
239d5056eaSjv  * 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 
569acbbeafSnn #define	EXEC_PREFIX	"exec "
579acbbeafSnn #define	EXEC_LEN	(strlen(EXEC_PREFIX))
589acbbeafSnn 
5984561e8cStd #define	CLUSTER_BRAND_NAME	"cluster"
609a5d73e0SRic Aleshire #define	LABELED_BRAND_NAME	"labeled"
6184561e8cStd 
62d314f035Sedp /* 0755 is the default directory mode. */
63d314f035Sedp #define	DEFAULT_DIR_MODE \
64d314f035Sedp 	(S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH)
65d314f035Sedp #define	DEFAULT_DIR_USER -1	/* user ID for chown: -1 means don't change */
66d314f035Sedp #define	DEFAULT_DIR_GROUP -1	/* grp ID for chown: -1 means don't change */
67d314f035Sedp 
68d314f035Sedp 
697c478bd9Sstevel@tonic-gate typedef struct zlog {
707c478bd9Sstevel@tonic-gate 	FILE *logfile;	/* file to log to */
717c478bd9Sstevel@tonic-gate 
727c478bd9Sstevel@tonic-gate 	/*
737c478bd9Sstevel@tonic-gate 	 * The following are used if logging to a buffer.
747c478bd9Sstevel@tonic-gate 	 */
757c478bd9Sstevel@tonic-gate 	char *log;	/* remaining log */
767c478bd9Sstevel@tonic-gate 	size_t loglen;	/* size of remaining log */
777c478bd9Sstevel@tonic-gate 	char *buf;	/* underlying storage */
787c478bd9Sstevel@tonic-gate 	size_t buflen;	/* total len of 'buf' */
797c478bd9Sstevel@tonic-gate 	char *locale;	/* locale to use for gettext() */
807c478bd9Sstevel@tonic-gate } zlog_t;
817c478bd9Sstevel@tonic-gate 
8222321485Svp extern zlog_t logsys;
8322321485Svp 
847c478bd9Sstevel@tonic-gate extern mutex_t lock;
857c478bd9Sstevel@tonic-gate extern mutex_t msglock;
867c478bd9Sstevel@tonic-gate extern boolean_t in_death_throes;
877c478bd9Sstevel@tonic-gate extern boolean_t bringup_failure_recovery;
887c478bd9Sstevel@tonic-gate extern char *zone_name;
893f2f09c1Sdp extern char boot_args[BOOTARGS_MAX];
903f2f09c1Sdp extern char bad_boot_arg[BOOTARGS_MAX];
919acbbeafSnn extern boolean_t zone_isnative;
9284561e8cStd extern boolean_t zone_iscluster;
934ac67f02SAnurag S. Maskey extern dladm_handle_t dld_handle;
947c478bd9Sstevel@tonic-gate 
957c478bd9Sstevel@tonic-gate extern void zerror(zlog_t *, boolean_t, const char *, ...);
967c478bd9Sstevel@tonic-gate extern char *localize_msg(char *locale, const char *msg);
977c478bd9Sstevel@tonic-gate 
987c478bd9Sstevel@tonic-gate /*
997c478bd9Sstevel@tonic-gate  * Eventstream interfaces.
1007c478bd9Sstevel@tonic-gate  */
1017c478bd9Sstevel@tonic-gate typedef enum {
1027c478bd9Sstevel@tonic-gate 	Z_EVT_NULL = 0,
1037c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_BOOTING,
1047c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_REBOOTING,
1057c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_HALTED,
1067c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_READIED,
107ffbafc53Scomay 	Z_EVT_ZONE_UNINSTALLING,
1083f2f09c1Sdp 	Z_EVT_ZONE_BOOTFAILED,
1093f2f09c1Sdp 	Z_EVT_ZONE_BADARGS
1107c478bd9Sstevel@tonic-gate } zone_evt_t;
1117c478bd9Sstevel@tonic-gate 
1127c478bd9Sstevel@tonic-gate extern int eventstream_init();
1137c478bd9Sstevel@tonic-gate extern void eventstream_write(zone_evt_t evt);
1147c478bd9Sstevel@tonic-gate 
1156cfd72c6Sgjelinek /*
1166cfd72c6Sgjelinek  * Zone mount styles.  Boot is the standard mount we do when booting the zone,
1176cfd72c6Sgjelinek  * scratch is the standard scratch zone mount for upgrade and update is a
1186cfd72c6Sgjelinek  * variation on the scratch zone where we don't lofs mount the zone's /etc
1196cfd72c6Sgjelinek  * and /var back into the scratch zone so that we can then do an
1206cfd72c6Sgjelinek  * 'update on attach' within the scratch zone.
1216cfd72c6Sgjelinek  */
1226cfd72c6Sgjelinek typedef enum {
1236cfd72c6Sgjelinek 	Z_MNT_BOOT = 0,
1246cfd72c6Sgjelinek 	Z_MNT_SCRATCH,
1256cfd72c6Sgjelinek 	Z_MNT_UPDATE
1266cfd72c6Sgjelinek } zone_mnt_t;
1276cfd72c6Sgjelinek 
1287c478bd9Sstevel@tonic-gate /*
1297c478bd9Sstevel@tonic-gate  * Virtual platform interfaces.
1307c478bd9Sstevel@tonic-gate  */
1316cfd72c6Sgjelinek extern zoneid_t vplat_create(zlog_t *, zone_mnt_t);
1326cfd72c6Sgjelinek extern int vplat_bringup(zlog_t *, zone_mnt_t, zoneid_t);
1330209230bSgjelinek extern int vplat_teardown(zlog_t *, boolean_t, boolean_t);
134*2b24ab6bSSebastien Roy extern int vplat_get_iptype(zlog_t *, zone_iptype_t *);
1357c478bd9Sstevel@tonic-gate 
136d314f035Sedp /*
137d314f035Sedp  * Filesystem mounting interfaces.
138d314f035Sedp  */
139d314f035Sedp extern int valid_mount_path(zlog_t *, const char *, const char *,
140d314f035Sedp     const char *, const char *);
141d314f035Sedp extern int make_one_dir(zlog_t *, const char *, const char *,
142d314f035Sedp     mode_t, uid_t, gid_t);
143910f48daSedp extern void resolve_lofs(zlog_t *zlogp, char *path, size_t pathlen);
144d314f035Sedp 
1457c478bd9Sstevel@tonic-gate /*
1467c478bd9Sstevel@tonic-gate  * Console subsystem routines.
1477c478bd9Sstevel@tonic-gate  */
1487c478bd9Sstevel@tonic-gate extern int init_console(zlog_t *);
1497c478bd9Sstevel@tonic-gate extern void serve_console(zlog_t *);
1507c478bd9Sstevel@tonic-gate 
151555afedfScarlsonj /*
152555afedfScarlsonj  * Contract handling.
153555afedfScarlsonj  */
154555afedfScarlsonj extern int init_template(void);
155555afedfScarlsonj 
1569acbbeafSnn /*
1579acbbeafSnn  * Routine to manage child processes.
1589acbbeafSnn  */
159c5cd6260S extern int do_subproc(zlog_t *, char *, char **);
1609acbbeafSnn 
1617c478bd9Sstevel@tonic-gate #ifdef __cplusplus
1627c478bd9Sstevel@tonic-gate }
1637c478bd9Sstevel@tonic-gate #endif
1647c478bd9Sstevel@tonic-gate 
1657c478bd9Sstevel@tonic-gate #endif /* _ZONEADMD_H */
166