xref: /titanic_52/usr/src/uts/common/sys/uadmin.h (revision 4196e26398ab7019943a8f276006fa66937b4425)
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
53f2f09c1Sdp  * Common Development and Distribution License (the "License").
63f2f09c1Sdp  * 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  */
217c478bd9Sstevel@tonic-gate /*
22753a6d45SSherry Moore  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
237c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
247c478bd9Sstevel@tonic-gate  */
257c478bd9Sstevel@tonic-gate 
267c478bd9Sstevel@tonic-gate /*	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	*/
277c478bd9Sstevel@tonic-gate /*	  All Rights Reserved  	*/
287c478bd9Sstevel@tonic-gate 
297c478bd9Sstevel@tonic-gate 
307c478bd9Sstevel@tonic-gate #ifndef _SYS_UADMIN_H
317c478bd9Sstevel@tonic-gate #define	_SYS_UADMIN_H
327c478bd9Sstevel@tonic-gate 
337c478bd9Sstevel@tonic-gate 
347c478bd9Sstevel@tonic-gate #if !defined(_ASM)
357c478bd9Sstevel@tonic-gate #include <sys/types.h>
367c478bd9Sstevel@tonic-gate #include <sys/cred.h>
377c478bd9Sstevel@tonic-gate #endif
387c478bd9Sstevel@tonic-gate 
397c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
407c478bd9Sstevel@tonic-gate extern "C" {
417c478bd9Sstevel@tonic-gate #endif
427c478bd9Sstevel@tonic-gate 
437c478bd9Sstevel@tonic-gate #define	A_REBOOT	1
447c478bd9Sstevel@tonic-gate #define	A_SHUTDOWN	2
457c478bd9Sstevel@tonic-gate #define	A_FREEZE	3	/* For freeze and thaw */
467c478bd9Sstevel@tonic-gate #define	A_REMOUNT	4
477c478bd9Sstevel@tonic-gate #define	A_DUMP		5
487c478bd9Sstevel@tonic-gate #define	A_FTRACE	15
497c478bd9Sstevel@tonic-gate #define	A_SWAPCTL	16
507c478bd9Sstevel@tonic-gate /*			17-21	   reserved for obsolete interface */
5110e6dadfSbrendan #define	A_SDTTEST	22	/* DTrace sdt:::test */
52753a6d45SSherry Moore #define	A_CONFIG	23	/* For system configuration */
537c478bd9Sstevel@tonic-gate 
54c48ac12eSjohnlev #define	AD_UNKNOWN	-1	/* no method */
557c478bd9Sstevel@tonic-gate #define	AD_HALT		0	/* halt the processor */
567c478bd9Sstevel@tonic-gate #define	AD_BOOT		1	/* multi-user reboot */
577c478bd9Sstevel@tonic-gate #define	AD_IBOOT	2	/* multi-user reboot, ask for name of file */
587c478bd9Sstevel@tonic-gate #define	AD_SBOOT	3	/* single-user reboot */
597c478bd9Sstevel@tonic-gate #define	AD_SIBOOT	4	/* single-user reboot, ask for name of file */
607c478bd9Sstevel@tonic-gate #define	AD_POWEROFF	6	/* software poweroff */
617c478bd9Sstevel@tonic-gate #define	AD_NOSYNC	7	/* do not sync filesystems on next A_DUMP */
6219397407SSherry Moore #define	AD_FASTREBOOT	8	/* bypass firmware and boot loader */
6319397407SSherry Moore #define	AD_FASTREBOOT_DRYRUN	9	/* Fast reboot Dry run */
647c478bd9Sstevel@tonic-gate 
657c478bd9Sstevel@tonic-gate /*
667c478bd9Sstevel@tonic-gate  * Functions reserved for A_FREEZE (may not be available on all platforms)
672df1fe9cSrandyf  * Note:  AD_COMPRESS, AD_CHECK and AD_FORCE are now obsolete
682df1fe9cSrandyf  *	The first two are succeeded by AD_SUSPEND_TO_DISK and
692df1fe9cSrandyf  *		AD_CHECK_SUSPEND_TO_DISK respectively.
702df1fe9cSrandyf  *	AD_FORCE should not be used by any new application
712df1fe9cSrandyf  *
722df1fe9cSrandyf  *	We maintain compatibility with the earlier interfaces:
732df1fe9cSrandyf  *	AD_COMPRESS and AD_CHECK, by preserving those values
742df1fe9cSrandyf  *	in the corresponding new interfaces
757c478bd9Sstevel@tonic-gate  */
762df1fe9cSrandyf 
777c478bd9Sstevel@tonic-gate #define	AD_COMPRESS	0	/* store state file compressed during CPR */
787c478bd9Sstevel@tonic-gate #define	AD_FORCE	1	/* force to do AD_COMPRESS */
797c478bd9Sstevel@tonic-gate #define	AD_CHECK	2	/* test if CPR module is available */
802df1fe9cSrandyf #define	AD_SUSPEND_TO_DISK	   AD_COMPRESS	/* A_FREEZE, CPR or ACPI S4 */
812df1fe9cSrandyf #define	AD_CHECK_SUSPEND_TO_DISK   AD_CHECK	/* A_FREEZE, CPR/S4 capable? */
822df1fe9cSrandyf #define	AD_SUSPEND_TO_RAM	   20		/* A_FREEZE, S3 */
832df1fe9cSrandyf #define	AD_CHECK_SUSPEND_TO_RAM	   21		/* A_FREEZE, S3 capable? */
842df1fe9cSrandyf 
857c478bd9Sstevel@tonic-gate /*
867c478bd9Sstevel@tonic-gate  * NOTE: the following defines comprise an Unstable interface.  Their semantics
877c478bd9Sstevel@tonic-gate  * may change or they may be removed completely in a later release
887c478bd9Sstevel@tonic-gate  */
897c478bd9Sstevel@tonic-gate #define	AD_REUSEINIT	3	/* prepare for AD_REUSABLE */
907c478bd9Sstevel@tonic-gate #define	AD_REUSABLE	4	/* create reusable statefile */
917c478bd9Sstevel@tonic-gate #define	AD_REUSEFINI	5	/* revert to normal CPR mode (not reusable) */
927c478bd9Sstevel@tonic-gate 
937c478bd9Sstevel@tonic-gate #define	AD_FTRACE_START	1
947c478bd9Sstevel@tonic-gate #define	AD_FTRACE_STOP	2
957c478bd9Sstevel@tonic-gate 
963f2f09c1Sdp /*
97753a6d45SSherry Moore  * Functions of A_CONFIG.  Unstable interface.
98753a6d45SSherry Moore  */
99753a6d45SSherry Moore #define	AD_UPDATE_BOOT_CONFIG	1	/* Update boot config variables */
100753a6d45SSherry Moore 
101753a6d45SSherry Moore /*
1023f2f09c1Sdp  * When 'mdep' (the second argument to uadmin(2)) is initialized for A_REBOOT,
1033f2f09c1Sdp  * A_SHUTDOWN or A_DUMP, it represents the boot arguments string of at most
1043f2f09c1Sdp  * 256 characters.
1053f2f09c1Sdp  */
1063f2f09c1Sdp #define	BOOTARGS_MAX	256
1073f2f09c1Sdp 
108753a6d45SSherry Moore #if !defined(_KERNEL)
109753a6d45SSherry Moore /*
110753a6d45SSherry Moore  * FMRI for boot-config service.
111753a6d45SSherry Moore  */
112753a6d45SSherry Moore #define	FMRI_BOOT_CONFIG \
113753a6d45SSherry Moore 	"svc:/system/boot-config:default"
114753a6d45SSherry Moore 
115753a6d45SSherry Moore /*
116753a6d45SSherry Moore  * Property group that contains all Fast Reboot configuration properties.
117753a6d45SSherry Moore  */
118753a6d45SSherry Moore #define	BOOT_CONFIG_PG_PARAMS		"config"
119753a6d45SSherry Moore 
120753a6d45SSherry Moore /*
121753a6d45SSherry Moore  * Property group that contains all Fast Reboot blacklisting information.
122753a6d45SSherry Moore  */
123753a6d45SSherry Moore #define	BOOT_CONFIG_PG_FBBLACKLIST	"fastreboot_blacklist"
124753a6d45SSherry Moore 
125*4196e263SSherry Moore /*
126*4196e263SSherry Moore  * Non-persistent property group which contains all the properties that
127*4196e263SSherry Moore  * will override settings in the BOOT_CONFIG_PG_PARAMS property group.
128*4196e263SSherry Moore  */
129*4196e263SSherry Moore #define	BOOT_CONFIG_PG_OVR		"config_ovr"
130*4196e263SSherry Moore 
131753a6d45SSherry Moore #endif	/* _KERNEL */
132753a6d45SSherry Moore 
133753a6d45SSherry Moore /*
134753a6d45SSherry Moore  * Flag representations of fastboot configuration.
135753a6d45SSherry Moore  */
136753a6d45SSherry Moore #define	UA_FASTREBOOT_DEFAULT	0x01
137753a6d45SSherry Moore #define	UA_FASTREBOOT_ONPANIC	0x02
138753a6d45SSherry Moore 
139*4196e263SSherry Moore #define	FASTREBOOT_DEFAULT		"fastreboot_default"
140753a6d45SSherry Moore #define	FASTREBOOT_ONPANIC		"fastreboot_onpanic"
141753a6d45SSherry Moore #define	FASTREBOOT_ONPANIC_CMDLINE	"fastreboot_onpanic_cmdline"
142753a6d45SSherry Moore 
143753a6d45SSherry Moore #define	FASTREBOOT_ONPANIC_NOTSET(p)	\
144753a6d45SSherry Moore 	(strcmp((p), "false") == 0 ||	\
145753a6d45SSherry Moore 	strcmp((p), "no") == 0 ||	\
146753a6d45SSherry Moore 	strcmp((p), "0") == 0)
147753a6d45SSherry Moore 
148753a6d45SSherry Moore #define	FASTREBOOT_ONPANIC_ISSET(p)	\
149753a6d45SSherry Moore 	(strcmp((p), "true") == 0 ||	\
150753a6d45SSherry Moore 	strcmp((p), "yes") == 0 ||	\
151753a6d45SSherry Moore 	strcmp((p), "1") == 0)
152753a6d45SSherry Moore 
1537c478bd9Sstevel@tonic-gate #if !defined(_ASM)
1547c478bd9Sstevel@tonic-gate 
1557c478bd9Sstevel@tonic-gate #if defined(_KERNEL)
1567c478bd9Sstevel@tonic-gate extern kmutex_t ualock;
157edc40228Sachartre extern void mdboot(int, int, char *, boolean_t);
1587c478bd9Sstevel@tonic-gate extern void mdpreboot(int, int, char *);
1597c478bd9Sstevel@tonic-gate extern int kadmin(int, int, void *, cred_t *);
1607c478bd9Sstevel@tonic-gate extern void killall(zoneid_t);
1617c478bd9Sstevel@tonic-gate #endif
1627c478bd9Sstevel@tonic-gate 
1637c478bd9Sstevel@tonic-gate #if defined(__STDC__)
1647c478bd9Sstevel@tonic-gate extern int uadmin(int, int, uintptr_t);
1657c478bd9Sstevel@tonic-gate #else
1667c478bd9Sstevel@tonic-gate extern int uadmin();
1677c478bd9Sstevel@tonic-gate #endif
1687c478bd9Sstevel@tonic-gate 
1697c478bd9Sstevel@tonic-gate #endif	/* _ASM */
1707c478bd9Sstevel@tonic-gate 
1717c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
1727c478bd9Sstevel@tonic-gate }
1737c478bd9Sstevel@tonic-gate #endif
1747c478bd9Sstevel@tonic-gate 
1757c478bd9Sstevel@tonic-gate #endif	/* _SYS_UADMIN_H */
176