xref: /titanic_52/usr/src/uts/common/sys/uadmin.h (revision 753a6d457b330b1b29b2d3eefcd0831116ce950d)
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 /*
22*753a6d45SSherry 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 */
52*753a6d45SSherry 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 /*
97*753a6d45SSherry Moore  * Functions of A_CONFIG.  Unstable interface.
98*753a6d45SSherry Moore  */
99*753a6d45SSherry Moore #define	AD_UPDATE_BOOT_CONFIG	1	/* Update boot config variables */
100*753a6d45SSherry Moore 
101*753a6d45SSherry 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 
108*753a6d45SSherry Moore #if !defined(_KERNEL)
109*753a6d45SSherry Moore /*
110*753a6d45SSherry Moore  * FMRI for boot-config service.
111*753a6d45SSherry Moore  */
112*753a6d45SSherry Moore #define	FMRI_BOOT_CONFIG \
113*753a6d45SSherry Moore 	"svc:/system/boot-config:default"
114*753a6d45SSherry Moore 
115*753a6d45SSherry Moore /*
116*753a6d45SSherry Moore  * Property group that contains all Fast Reboot configuration properties.
117*753a6d45SSherry Moore  */
118*753a6d45SSherry Moore #define	BOOT_CONFIG_PG_PARAMS		"config"
119*753a6d45SSherry Moore 
120*753a6d45SSherry Moore /*
121*753a6d45SSherry Moore  * Property group that contains all Fast Reboot blacklisting information.
122*753a6d45SSherry Moore  */
123*753a6d45SSherry Moore #define	BOOT_CONFIG_PG_FBBLACKLIST	"fastreboot_blacklist"
124*753a6d45SSherry Moore 
125*753a6d45SSherry Moore #endif	/* _KERNEL */
126*753a6d45SSherry Moore 
127*753a6d45SSherry Moore /*
128*753a6d45SSherry Moore  * Flag representations of fastboot configuration.
129*753a6d45SSherry Moore  */
130*753a6d45SSherry Moore #define	UA_FASTREBOOT_DEFAULT	0x01
131*753a6d45SSherry Moore #define	UA_FASTREBOOT_ONPANIC	0x02
132*753a6d45SSherry Moore 
133*753a6d45SSherry Moore #define	FASTREBOOT_ONPANIC		"fastreboot_onpanic"
134*753a6d45SSherry Moore #define	FASTREBOOT_ONPANIC_CMDLINE	"fastreboot_onpanic_cmdline"
135*753a6d45SSherry Moore 
136*753a6d45SSherry Moore #define	FASTREBOOT_ONPANIC_NOTSET(p)	\
137*753a6d45SSherry Moore 	(strcmp((p), "false") == 0 ||	\
138*753a6d45SSherry Moore 	strcmp((p), "no") == 0 ||	\
139*753a6d45SSherry Moore 	strcmp((p), "0") == 0)
140*753a6d45SSherry Moore 
141*753a6d45SSherry Moore #define	FASTREBOOT_ONPANIC_ISSET(p)	\
142*753a6d45SSherry Moore 	(strcmp((p), "true") == 0 ||	\
143*753a6d45SSherry Moore 	strcmp((p), "yes") == 0 ||	\
144*753a6d45SSherry Moore 	strcmp((p), "1") == 0)
145*753a6d45SSherry Moore 
1467c478bd9Sstevel@tonic-gate #if !defined(_ASM)
1477c478bd9Sstevel@tonic-gate 
1487c478bd9Sstevel@tonic-gate #if defined(_KERNEL)
1497c478bd9Sstevel@tonic-gate extern kmutex_t ualock;
150edc40228Sachartre extern void mdboot(int, int, char *, boolean_t);
1517c478bd9Sstevel@tonic-gate extern void mdpreboot(int, int, char *);
1527c478bd9Sstevel@tonic-gate extern int kadmin(int, int, void *, cred_t *);
1537c478bd9Sstevel@tonic-gate extern void killall(zoneid_t);
1547c478bd9Sstevel@tonic-gate #endif
1557c478bd9Sstevel@tonic-gate 
1567c478bd9Sstevel@tonic-gate #if defined(__STDC__)
1577c478bd9Sstevel@tonic-gate extern int uadmin(int, int, uintptr_t);
1587c478bd9Sstevel@tonic-gate #else
1597c478bd9Sstevel@tonic-gate extern int uadmin();
1607c478bd9Sstevel@tonic-gate #endif
1617c478bd9Sstevel@tonic-gate 
1627c478bd9Sstevel@tonic-gate #endif	/* _ASM */
1637c478bd9Sstevel@tonic-gate 
1647c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
1657c478bd9Sstevel@tonic-gate }
1667c478bd9Sstevel@tonic-gate #endif
1677c478bd9Sstevel@tonic-gate 
1687c478bd9Sstevel@tonic-gate #endif	/* _SYS_UADMIN_H */
169