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