xref: /illumos-gate/usr/src/cmd/zoneadmd/zoneadmd.h (revision 3c7284bd3243d42a710edac3a15f6019b4c849be)
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 /*
23efd4c9b6SSteve Lawrence  * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
24*3c7284bdSAlexander Eremin  * Copyright 2014 Nexenta Systems, Inc. All rights reserved.
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 
62*3c7284bdSAlexander Eremin #define	SHUTDOWN_WAIT		60
63*3c7284bdSAlexander Eremin #define	SHUTDOWN_DEFAULT	"/sbin/init 0"
64*3c7284bdSAlexander Eremin #define	SHUTDOWN_FMRI	"svc:/system/zones:default"
65*3c7284bdSAlexander Eremin 
66d314f035Sedp /* 0755 is the default directory mode. */
67d314f035Sedp #define	DEFAULT_DIR_MODE \
68d314f035Sedp 	(S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH)
69d314f035Sedp #define	DEFAULT_DIR_USER -1	/* user ID for chown: -1 means don't change */
70d314f035Sedp #define	DEFAULT_DIR_GROUP -1	/* grp ID for chown: -1 means don't change */
71d314f035Sedp 
72d314f035Sedp 
737c478bd9Sstevel@tonic-gate typedef struct zlog {
747c478bd9Sstevel@tonic-gate 	FILE *logfile;	/* file to log to */
757c478bd9Sstevel@tonic-gate 
767c478bd9Sstevel@tonic-gate 	/*
777c478bd9Sstevel@tonic-gate 	 * The following are used if logging to a buffer.
787c478bd9Sstevel@tonic-gate 	 */
797c478bd9Sstevel@tonic-gate 	char *log;	/* remaining log */
807c478bd9Sstevel@tonic-gate 	size_t loglen;	/* size of remaining log */
817c478bd9Sstevel@tonic-gate 	char *buf;	/* underlying storage */
827c478bd9Sstevel@tonic-gate 	size_t buflen;	/* total len of 'buf' */
837c478bd9Sstevel@tonic-gate 	char *locale;	/* locale to use for gettext() */
847c478bd9Sstevel@tonic-gate } zlog_t;
857c478bd9Sstevel@tonic-gate 
8622321485Svp extern zlog_t logsys;
8722321485Svp 
887c478bd9Sstevel@tonic-gate extern mutex_t lock;
897c478bd9Sstevel@tonic-gate extern mutex_t msglock;
907c478bd9Sstevel@tonic-gate extern boolean_t in_death_throes;
917c478bd9Sstevel@tonic-gate extern boolean_t bringup_failure_recovery;
927c478bd9Sstevel@tonic-gate extern char *zone_name;
93efd4c9b6SSteve Lawrence extern char pool_name[MAXNAMELEN];
9462868012SSteve Lawrence extern char brand_name[MAXNAMELEN];
95e5816e35SEdward Pilatowicz extern char default_brand[MAXNAMELEN];
963f2f09c1Sdp extern char boot_args[BOOTARGS_MAX];
973f2f09c1Sdp extern char bad_boot_arg[BOOTARGS_MAX];
989acbbeafSnn extern boolean_t zone_isnative;
9984561e8cStd extern boolean_t zone_iscluster;
1004ac67f02SAnurag S. Maskey extern dladm_handle_t dld_handle;
1017c478bd9Sstevel@tonic-gate 
1027c478bd9Sstevel@tonic-gate extern void zerror(zlog_t *, boolean_t, const char *, ...);
1037c478bd9Sstevel@tonic-gate extern char *localize_msg(char *locale, const char *msg);
1047c478bd9Sstevel@tonic-gate 
1057c478bd9Sstevel@tonic-gate /*
1067c478bd9Sstevel@tonic-gate  * Eventstream interfaces.
1077c478bd9Sstevel@tonic-gate  */
1087c478bd9Sstevel@tonic-gate typedef enum {
1097c478bd9Sstevel@tonic-gate 	Z_EVT_NULL = 0,
1107c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_BOOTING,
1117c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_REBOOTING,
1127c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_HALTED,
1137c478bd9Sstevel@tonic-gate 	Z_EVT_ZONE_READIED,
114ffbafc53Scomay 	Z_EVT_ZONE_UNINSTALLING,
1153f2f09c1Sdp 	Z_EVT_ZONE_BOOTFAILED,
1163f2f09c1Sdp 	Z_EVT_ZONE_BADARGS
1177c478bd9Sstevel@tonic-gate } zone_evt_t;
1187c478bd9Sstevel@tonic-gate 
1197c478bd9Sstevel@tonic-gate extern int eventstream_init();
1207c478bd9Sstevel@tonic-gate extern void eventstream_write(zone_evt_t evt);
1217c478bd9Sstevel@tonic-gate 
1226cfd72c6Sgjelinek /*
1236cfd72c6Sgjelinek  * Zone mount styles.  Boot is the standard mount we do when booting the zone,
1246cfd72c6Sgjelinek  * scratch is the standard scratch zone mount for upgrade and update is a
1256cfd72c6Sgjelinek  * variation on the scratch zone where we don't lofs mount the zone's /etc
1266cfd72c6Sgjelinek  * and /var back into the scratch zone so that we can then do an
1276cfd72c6Sgjelinek  * 'update on attach' within the scratch zone.
1286cfd72c6Sgjelinek  */
1296cfd72c6Sgjelinek typedef enum {
1306cfd72c6Sgjelinek 	Z_MNT_BOOT = 0,
1316cfd72c6Sgjelinek 	Z_MNT_SCRATCH,
1326cfd72c6Sgjelinek 	Z_MNT_UPDATE
1336cfd72c6Sgjelinek } zone_mnt_t;
1346cfd72c6Sgjelinek 
1357c478bd9Sstevel@tonic-gate /*
1367c478bd9Sstevel@tonic-gate  * Virtual platform interfaces.
1377c478bd9Sstevel@tonic-gate  */
1386cfd72c6Sgjelinek extern zoneid_t vplat_create(zlog_t *, zone_mnt_t);
1396cfd72c6Sgjelinek extern int vplat_bringup(zlog_t *, zone_mnt_t, zoneid_t);
1400209230bSgjelinek extern int vplat_teardown(zlog_t *, boolean_t, boolean_t);
1412b24ab6bSSebastien Roy extern int vplat_get_iptype(zlog_t *, zone_iptype_t *);
1427c478bd9Sstevel@tonic-gate 
143d314f035Sedp /*
144d314f035Sedp  * Filesystem mounting interfaces.
145d314f035Sedp  */
146d314f035Sedp extern int valid_mount_path(zlog_t *, const char *, const char *,
147d314f035Sedp     const char *, const char *);
148d314f035Sedp extern int make_one_dir(zlog_t *, const char *, const char *,
149d314f035Sedp     mode_t, uid_t, gid_t);
150910f48daSedp extern void resolve_lofs(zlog_t *zlogp, char *path, size_t pathlen);
151d314f035Sedp 
1527c478bd9Sstevel@tonic-gate /*
1537c478bd9Sstevel@tonic-gate  * Console subsystem routines.
1547c478bd9Sstevel@tonic-gate  */
1557c478bd9Sstevel@tonic-gate extern int init_console(zlog_t *);
1567c478bd9Sstevel@tonic-gate extern void serve_console(zlog_t *);
1577c478bd9Sstevel@tonic-gate 
158555afedfScarlsonj /*
159555afedfScarlsonj  * Contract handling.
160555afedfScarlsonj  */
161555afedfScarlsonj extern int init_template(void);
162555afedfScarlsonj 
1639acbbeafSnn /*
1649acbbeafSnn  * Routine to manage child processes.
1659acbbeafSnn  */
166c5cd6260S extern int do_subproc(zlog_t *, char *, char **);
1679acbbeafSnn 
1687c478bd9Sstevel@tonic-gate #ifdef __cplusplus
1697c478bd9Sstevel@tonic-gate }
1707c478bd9Sstevel@tonic-gate #endif
1717c478bd9Sstevel@tonic-gate 
1727c478bd9Sstevel@tonic-gate #endif /* _ZONEADMD_H */
173