xref: /titanic_52/usr/src/boot/sys/sys/exec.h (revision 4a5d661a82b942b6538acd26209d959ce98b593a)
1*4a5d661aSToomas Soome /*-
2*4a5d661aSToomas Soome  * Copyright (c) 1992, 1993
3*4a5d661aSToomas Soome  *	The Regents of the University of California.  All rights reserved.
4*4a5d661aSToomas Soome  * (c) UNIX System Laboratories, Inc.
5*4a5d661aSToomas Soome  * All or some portions of this file are derived from material licensed
6*4a5d661aSToomas Soome  * to the University of California by American Telephone and Telegraph
7*4a5d661aSToomas Soome  * Co. or Unix System Laboratories, Inc. and are reproduced herein with
8*4a5d661aSToomas Soome  * the permission of UNIX System Laboratories, Inc.
9*4a5d661aSToomas Soome  *
10*4a5d661aSToomas Soome  * Redistribution and use in source and binary forms, with or without
11*4a5d661aSToomas Soome  * modification, are permitted provided that the following conditions
12*4a5d661aSToomas Soome  * are met:
13*4a5d661aSToomas Soome  * 1. Redistributions of source code must retain the above copyright
14*4a5d661aSToomas Soome  *    notice, this list of conditions and the following disclaimer.
15*4a5d661aSToomas Soome  * 2. Redistributions in binary form must reproduce the above copyright
16*4a5d661aSToomas Soome  *    notice, this list of conditions and the following disclaimer in the
17*4a5d661aSToomas Soome  *    documentation and/or other materials provided with the distribution.
18*4a5d661aSToomas Soome  * 4. Neither the name of the University nor the names of its contributors
19*4a5d661aSToomas Soome  *    may be used to endorse or promote products derived from this software
20*4a5d661aSToomas Soome  *    without specific prior written permission.
21*4a5d661aSToomas Soome  *
22*4a5d661aSToomas Soome  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23*4a5d661aSToomas Soome  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24*4a5d661aSToomas Soome  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25*4a5d661aSToomas Soome  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26*4a5d661aSToomas Soome  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27*4a5d661aSToomas Soome  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28*4a5d661aSToomas Soome  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29*4a5d661aSToomas Soome  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30*4a5d661aSToomas Soome  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31*4a5d661aSToomas Soome  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32*4a5d661aSToomas Soome  * SUCH DAMAGE.
33*4a5d661aSToomas Soome  *
34*4a5d661aSToomas Soome  *	@(#)exec.h	8.3 (Berkeley) 1/21/94
35*4a5d661aSToomas Soome  * $FreeBSD$
36*4a5d661aSToomas Soome  */
37*4a5d661aSToomas Soome 
38*4a5d661aSToomas Soome #ifndef _SYS_EXEC_H_
39*4a5d661aSToomas Soome #define _SYS_EXEC_H_
40*4a5d661aSToomas Soome 
41*4a5d661aSToomas Soome /*
42*4a5d661aSToomas Soome  * Before ps_args existed, the following structure, found at the top of
43*4a5d661aSToomas Soome  * the user stack of each user process, was used by ps(1) to locate
44*4a5d661aSToomas Soome  * environment and argv strings.  Normally ps_argvstr points to the
45*4a5d661aSToomas Soome  * argv vector, and ps_nargvstr is the same as the program's argc. The
46*4a5d661aSToomas Soome  * fields ps_envstr and ps_nenvstr are the equivalent for the environment.
47*4a5d661aSToomas Soome  *
48*4a5d661aSToomas Soome  * Programs should now use setproctitle(3) to change ps output.
49*4a5d661aSToomas Soome  * setproctitle() always informs the kernel with sysctl and sets the
50*4a5d661aSToomas Soome  * pointers in ps_strings.  The kern.proc.args sysctl first tries p_args.
51*4a5d661aSToomas Soome  * If p_args is NULL, it then falls back to reading ps_strings and following
52*4a5d661aSToomas Soome  * the pointers.
53*4a5d661aSToomas Soome  */
54*4a5d661aSToomas Soome struct ps_strings {
55*4a5d661aSToomas Soome 	char	**ps_argvstr;	/* first of 0 or more argument strings */
56*4a5d661aSToomas Soome 	unsigned int ps_nargvstr; /* the number of argument strings */
57*4a5d661aSToomas Soome 	char	**ps_envstr;	/* first of 0 or more environment strings */
58*4a5d661aSToomas Soome 	unsigned int ps_nenvstr; /* the number of environment strings */
59*4a5d661aSToomas Soome };
60*4a5d661aSToomas Soome 
61*4a5d661aSToomas Soome /*
62*4a5d661aSToomas Soome  * Address of ps_strings structure (in user space).
63*4a5d661aSToomas Soome  * Prefer the kern.ps_strings or kern.proc.ps_strings sysctls to this constant.
64*4a5d661aSToomas Soome  */
65*4a5d661aSToomas Soome #define	PS_STRINGS	(USRSTACK - sizeof(struct ps_strings))
66*4a5d661aSToomas Soome #define SPARE_USRSPACE	4096
67*4a5d661aSToomas Soome 
68*4a5d661aSToomas Soome struct image_params;
69*4a5d661aSToomas Soome 
70*4a5d661aSToomas Soome struct execsw {
71*4a5d661aSToomas Soome 	int (*ex_imgact)(struct image_params *);
72*4a5d661aSToomas Soome 	const char *ex_name;
73*4a5d661aSToomas Soome };
74*4a5d661aSToomas Soome 
75*4a5d661aSToomas Soome #include <machine/exec.h>
76*4a5d661aSToomas Soome 
77*4a5d661aSToomas Soome #ifdef _KERNEL
78*4a5d661aSToomas Soome #include <sys/cdefs.h>
79*4a5d661aSToomas Soome 
80*4a5d661aSToomas Soome int exec_map_first_page(struct image_params *);
81*4a5d661aSToomas Soome void exec_unmap_first_page(struct image_params *);
82*4a5d661aSToomas Soome 
83*4a5d661aSToomas Soome int exec_register(const struct execsw *);
84*4a5d661aSToomas Soome int exec_unregister(const struct execsw *);
85*4a5d661aSToomas Soome 
86*4a5d661aSToomas Soome extern int coredump_pack_fileinfo;
87*4a5d661aSToomas Soome extern int coredump_pack_vmmapinfo;
88*4a5d661aSToomas Soome 
89*4a5d661aSToomas Soome /*
90*4a5d661aSToomas Soome  * note: name##_mod cannot be const storage because the
91*4a5d661aSToomas Soome  * linker_file_sysinit() function modifies _file in the
92*4a5d661aSToomas Soome  * moduledata_t.
93*4a5d661aSToomas Soome  */
94*4a5d661aSToomas Soome 
95*4a5d661aSToomas Soome #include <sys/module.h>
96*4a5d661aSToomas Soome 
97*4a5d661aSToomas Soome #define EXEC_SET(name, execsw_arg) \
98*4a5d661aSToomas Soome 	static int __CONCAT(name,_modevent)(module_t mod, int type, \
99*4a5d661aSToomas Soome 	    void *data) \
100*4a5d661aSToomas Soome 	{ \
101*4a5d661aSToomas Soome 		struct execsw *exec = (struct execsw *)data; \
102*4a5d661aSToomas Soome 		int error = 0; \
103*4a5d661aSToomas Soome 		switch (type) { \
104*4a5d661aSToomas Soome 		case MOD_LOAD: \
105*4a5d661aSToomas Soome 			/* printf(#name " module loaded\n"); */ \
106*4a5d661aSToomas Soome 			error = exec_register(exec); \
107*4a5d661aSToomas Soome 			if (error) \
108*4a5d661aSToomas Soome 				printf(__XSTRING(name) "register failed\n"); \
109*4a5d661aSToomas Soome 			break; \
110*4a5d661aSToomas Soome 		case MOD_UNLOAD: \
111*4a5d661aSToomas Soome 			/* printf(#name " module unloaded\n"); */ \
112*4a5d661aSToomas Soome 			error = exec_unregister(exec); \
113*4a5d661aSToomas Soome 			if (error) \
114*4a5d661aSToomas Soome 				printf(__XSTRING(name) " unregister failed\n");\
115*4a5d661aSToomas Soome 			break; \
116*4a5d661aSToomas Soome 		default: \
117*4a5d661aSToomas Soome 			error = EOPNOTSUPP; \
118*4a5d661aSToomas Soome 			break; \
119*4a5d661aSToomas Soome 		} \
120*4a5d661aSToomas Soome 		return error; \
121*4a5d661aSToomas Soome 	} \
122*4a5d661aSToomas Soome 	static moduledata_t __CONCAT(name,_mod) = { \
123*4a5d661aSToomas Soome 		__XSTRING(name), \
124*4a5d661aSToomas Soome 		__CONCAT(name,_modevent), \
125*4a5d661aSToomas Soome 		(void *)& execsw_arg \
126*4a5d661aSToomas Soome 	}; \
127*4a5d661aSToomas Soome 	DECLARE_MODULE_TIED(name, __CONCAT(name,_mod), SI_SUB_EXEC, \
128*4a5d661aSToomas Soome 	    SI_ORDER_ANY)
129*4a5d661aSToomas Soome #endif
130*4a5d661aSToomas Soome 
131*4a5d661aSToomas Soome #endif
132