xref: /titanic_51/usr/src/uts/common/sys/modctl.h (revision c702eacaf4d917acee909844383924df2accf8f5)
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
5facf4a8dSllai1  * Common Development and Distribution License (the "License").
6facf4a8dSllai1  * 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 /*
22c8742f64SJerry Gilliam  * Copyright (c) 1990, 2010, Oracle and/or its affiliates. All rights reserved.
237c478bd9Sstevel@tonic-gate  */
247c478bd9Sstevel@tonic-gate 
257c478bd9Sstevel@tonic-gate #ifndef	_SYS_MODCTL_H
267c478bd9Sstevel@tonic-gate #define	_SYS_MODCTL_H
277c478bd9Sstevel@tonic-gate 
287c478bd9Sstevel@tonic-gate /*
297c478bd9Sstevel@tonic-gate  * loadable module support.
307c478bd9Sstevel@tonic-gate  */
317c478bd9Sstevel@tonic-gate 
327c478bd9Sstevel@tonic-gate #include <sys/types.h>
337c478bd9Sstevel@tonic-gate #include <sys/ioccom.h>
347c478bd9Sstevel@tonic-gate #include <sys/nexusdefs.h>
357c478bd9Sstevel@tonic-gate #include <sys/thread.h>
367c478bd9Sstevel@tonic-gate #include <sys/t_lock.h>
377c478bd9Sstevel@tonic-gate #include <sys/dditypes.h>
387c478bd9Sstevel@tonic-gate #include <sys/hwconf.h>
397c478bd9Sstevel@tonic-gate 
407c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
417c478bd9Sstevel@tonic-gate extern "C" {
427c478bd9Sstevel@tonic-gate #endif
437c478bd9Sstevel@tonic-gate 
447c478bd9Sstevel@tonic-gate /*
457c478bd9Sstevel@tonic-gate  * The following structure defines the operations used by modctl
467c478bd9Sstevel@tonic-gate  * to load and unload modules.  Each supported loadable module type
477c478bd9Sstevel@tonic-gate  * requires a set of mod_ops.
487c478bd9Sstevel@tonic-gate  */
497c478bd9Sstevel@tonic-gate struct mod_ops {
507c478bd9Sstevel@tonic-gate 	int		(*modm_install)();	/* install module in kernel */
517c478bd9Sstevel@tonic-gate 	int		(*modm_remove)();	/* remove from kernel */
527c478bd9Sstevel@tonic-gate 	int		(*modm_info)();		/* module info */
537c478bd9Sstevel@tonic-gate };
547c478bd9Sstevel@tonic-gate 
557c478bd9Sstevel@tonic-gate #ifdef _KERNEL
567c478bd9Sstevel@tonic-gate 
577c478bd9Sstevel@tonic-gate /*
587c478bd9Sstevel@tonic-gate  * The defined set of mod_ops structures for each loadable module type
597c478bd9Sstevel@tonic-gate  * Defined in modctl.c
607c478bd9Sstevel@tonic-gate  */
619acbbeafSnn35248 extern struct mod_ops mod_brandops;
627aec1d6eScindi #if defined(__i386) || defined(__amd64)
637aec1d6eScindi extern struct mod_ops mod_cpuops;
647aec1d6eScindi #endif
657c478bd9Sstevel@tonic-gate extern struct mod_ops mod_cryptoops;
667c478bd9Sstevel@tonic-gate extern struct mod_ops mod_driverops;
677c478bd9Sstevel@tonic-gate extern struct mod_ops mod_execops;
687c478bd9Sstevel@tonic-gate extern struct mod_ops mod_fsops;
697c478bd9Sstevel@tonic-gate extern struct mod_ops mod_miscops;
707c478bd9Sstevel@tonic-gate extern struct mod_ops mod_schedops;
717c478bd9Sstevel@tonic-gate extern struct mod_ops mod_strmodops;
727c478bd9Sstevel@tonic-gate extern struct mod_ops mod_syscallops;
730f1702c5SYu Xiangning extern struct mod_ops mod_sockmodops;
747c478bd9Sstevel@tonic-gate #ifdef _SYSCALL32_IMPL
757c478bd9Sstevel@tonic-gate extern struct mod_ops mod_syscallops32;
767c478bd9Sstevel@tonic-gate #endif
777c478bd9Sstevel@tonic-gate extern struct mod_ops mod_dacfops;
787c478bd9Sstevel@tonic-gate extern struct mod_ops mod_ippops;
797c478bd9Sstevel@tonic-gate extern struct mod_ops mod_pcbeops;
80d14d7d31Sis extern struct mod_ops mod_kiconvops;
817c478bd9Sstevel@tonic-gate 
827c478bd9Sstevel@tonic-gate #endif /* _KERNEL */
837c478bd9Sstevel@tonic-gate 
847c478bd9Sstevel@tonic-gate /*
857c478bd9Sstevel@tonic-gate  * Definitions for the module specific linkage structures.
867c478bd9Sstevel@tonic-gate  * The first two fields are the same in all of the structures.
877c478bd9Sstevel@tonic-gate  * The linkinfo is for informational purposes only and is returned by
887c478bd9Sstevel@tonic-gate  * modctl with the MODINFO cmd.
897c478bd9Sstevel@tonic-gate  */
907c478bd9Sstevel@tonic-gate 
917c478bd9Sstevel@tonic-gate /* For drivers */
927c478bd9Sstevel@tonic-gate struct modldrv {
937c478bd9Sstevel@tonic-gate 	struct mod_ops		*drv_modops;
947c478bd9Sstevel@tonic-gate 	char			*drv_linkinfo;
957c478bd9Sstevel@tonic-gate 	struct dev_ops		*drv_dev_ops;
967c478bd9Sstevel@tonic-gate };
977c478bd9Sstevel@tonic-gate 
987c478bd9Sstevel@tonic-gate /* For system calls */
997c478bd9Sstevel@tonic-gate struct modlsys {
1007c478bd9Sstevel@tonic-gate 	struct mod_ops		*sys_modops;
1017c478bd9Sstevel@tonic-gate 	char			*sys_linkinfo;
1027c478bd9Sstevel@tonic-gate 	struct sysent		*sys_sysent;
1037c478bd9Sstevel@tonic-gate };
1047c478bd9Sstevel@tonic-gate 
1057c478bd9Sstevel@tonic-gate /* For filesystems */
1067c478bd9Sstevel@tonic-gate struct modlfs {
1077c478bd9Sstevel@tonic-gate 	struct mod_ops		*fs_modops;
1087c478bd9Sstevel@tonic-gate 	char			*fs_linkinfo;
109d7334e51Srm15945 	struct vfsdef_v5	*fs_vfsdef;	/* version may actually vary */
1107c478bd9Sstevel@tonic-gate };
1117c478bd9Sstevel@tonic-gate 
1127aec1d6eScindi #if defined(__i386) || defined(__amd64)
1137aec1d6eScindi struct cmi_ops;
1147aec1d6eScindi 
1157aec1d6eScindi /* For CPU modules */
1167aec1d6eScindi struct modlcpu {
1177aec1d6eScindi 	struct mod_ops		*cpu_modops;
1187aec1d6eScindi 	char			*cpu_linkinfo;
1197aec1d6eScindi 	struct cmi_ops		*cpu_cmiops;
1207aec1d6eScindi };
1217aec1d6eScindi #endif
1227aec1d6eScindi 
1237c478bd9Sstevel@tonic-gate /* For cryptographic providers */
1247c478bd9Sstevel@tonic-gate struct modlcrypto {
1257c478bd9Sstevel@tonic-gate 	struct mod_ops		*crypto_modops;
1267c478bd9Sstevel@tonic-gate 	char			*crypto_linkinfo;
1277c478bd9Sstevel@tonic-gate };
1287c478bd9Sstevel@tonic-gate 
1297c478bd9Sstevel@tonic-gate /* For misc */
1307c478bd9Sstevel@tonic-gate struct modlmisc {
1317c478bd9Sstevel@tonic-gate 	struct mod_ops		*misc_modops;
1327c478bd9Sstevel@tonic-gate 	char			*misc_linkinfo;
1337c478bd9Sstevel@tonic-gate };
1347c478bd9Sstevel@tonic-gate 
1357c478bd9Sstevel@tonic-gate /* For IP Modules */
1367c478bd9Sstevel@tonic-gate struct modlipp {
1377c478bd9Sstevel@tonic-gate 	struct mod_ops		*ipp_modops;
1387c478bd9Sstevel@tonic-gate 	char			*ipp_linkinfo;
1397c478bd9Sstevel@tonic-gate 	struct ipp_ops		*ipp_ops;
1407c478bd9Sstevel@tonic-gate };
1417c478bd9Sstevel@tonic-gate 
1427c478bd9Sstevel@tonic-gate /* For Streams Modules. */
1437c478bd9Sstevel@tonic-gate struct modlstrmod {
1447c478bd9Sstevel@tonic-gate 	struct mod_ops		*strmod_modops;
1457c478bd9Sstevel@tonic-gate 	char			*strmod_linkinfo;
1467c478bd9Sstevel@tonic-gate 	struct fmodsw		*strmod_fmodsw;
1477c478bd9Sstevel@tonic-gate };
1487c478bd9Sstevel@tonic-gate 
1497c478bd9Sstevel@tonic-gate /* For Scheduling classes */
1507c478bd9Sstevel@tonic-gate struct modlsched {
1517c478bd9Sstevel@tonic-gate 	struct mod_ops		*sched_modops;
1527c478bd9Sstevel@tonic-gate 	char			*sched_linkinfo;
1537c478bd9Sstevel@tonic-gate 	struct sclass		*sched_class;
1547c478bd9Sstevel@tonic-gate };
1557c478bd9Sstevel@tonic-gate 
1567c478bd9Sstevel@tonic-gate /* For Exec file type (like ELF, ...) */
1577c478bd9Sstevel@tonic-gate struct modlexec {
1587c478bd9Sstevel@tonic-gate 	struct mod_ops		*exec_modops;
1597c478bd9Sstevel@tonic-gate 	char			*exec_linkinfo;
1607c478bd9Sstevel@tonic-gate 	struct execsw		*exec_execsw;
1617c478bd9Sstevel@tonic-gate };
1627c478bd9Sstevel@tonic-gate 
1637c478bd9Sstevel@tonic-gate /* For dacf modules */
1647c478bd9Sstevel@tonic-gate struct modldacf {
1657c478bd9Sstevel@tonic-gate 	struct mod_ops		*dacf_modops;
1667c478bd9Sstevel@tonic-gate 	char			*dacf_linkinfo;
1677c478bd9Sstevel@tonic-gate 	struct dacfsw		*dacf_dacfsw;
1687c478bd9Sstevel@tonic-gate };
1697c478bd9Sstevel@tonic-gate 
1707c478bd9Sstevel@tonic-gate /* For PCBE modules */
1717c478bd9Sstevel@tonic-gate struct modlpcbe {
1727c478bd9Sstevel@tonic-gate 	struct mod_ops		*pcbe_modops;
1737c478bd9Sstevel@tonic-gate 	char			*pcbe_linkinfo;
1747c478bd9Sstevel@tonic-gate 	struct __pcbe_ops	*pcbe_ops;
1757c478bd9Sstevel@tonic-gate };
1767c478bd9Sstevel@tonic-gate 
1779acbbeafSnn35248 /* For Brand modules */
1789acbbeafSnn35248 struct modlbrand {
1799acbbeafSnn35248 	struct mod_ops		*brand_modops;
1809acbbeafSnn35248 	char			*brand_linkinfo;
1819acbbeafSnn35248 	struct brand		*brand_branddef;
1829acbbeafSnn35248 };
1839acbbeafSnn35248 
1840f1702c5SYu Xiangning /* For socket Modules. */
1850f1702c5SYu Xiangning struct modlsockmod {
1860f1702c5SYu Xiangning 	struct mod_ops		*sockmod_modops;
1870f1702c5SYu Xiangning 	char			*sockmod_linkinfo;
1880f1702c5SYu Xiangning 	struct smod_reg_s	*sockmod_reg_info;
1890f1702c5SYu Xiangning };
1900f1702c5SYu Xiangning 
191d14d7d31Sis /* For kiconv modules */
192d14d7d31Sis struct modlkiconv {
193d14d7d31Sis 	struct mod_ops		*kiconv_modops;
194d14d7d31Sis 	char			*kiconv_linkinfo;
195d14d7d31Sis 	struct kiconv_mod_info	*kiconv_moddef;
196d14d7d31Sis };
197d14d7d31Sis 
1987c478bd9Sstevel@tonic-gate /*
1997c478bd9Sstevel@tonic-gate  * Revision number of loadable modules support.  This is the value
2007c478bd9Sstevel@tonic-gate  * that must be used in the modlinkage structure.
2017c478bd9Sstevel@tonic-gate  */
2027c478bd9Sstevel@tonic-gate #define	MODREV_1		1
2037c478bd9Sstevel@tonic-gate 
2047c478bd9Sstevel@tonic-gate /*
2057c478bd9Sstevel@tonic-gate  * The modlinkage structure is the structure that the module writer
2067c478bd9Sstevel@tonic-gate  * provides to the routines to install, remove, and stat a module.
2077c478bd9Sstevel@tonic-gate  * The ml_linkage element is an array of pointers to linkage structures.
2087c478bd9Sstevel@tonic-gate  * For most modules there is only one linkage structure.  We allocate
2097c478bd9Sstevel@tonic-gate  * enough space for 3 linkage structures which happens to be the most
2107c478bd9Sstevel@tonic-gate  * we have in any sun supplied module.  For those modules with more
2117c478bd9Sstevel@tonic-gate  * than 3 linkage structures (which is very unlikely), a modlinkage
2127c478bd9Sstevel@tonic-gate  * structure must be kmem_alloc'd in the module wrapper to be big enough
2137c478bd9Sstevel@tonic-gate  * for all of the linkage structures.
2147c478bd9Sstevel@tonic-gate  */
2157c478bd9Sstevel@tonic-gate struct modlinkage {
2167c478bd9Sstevel@tonic-gate 	int		ml_rev;		/* rev of loadable modules system */
2177c478bd9Sstevel@tonic-gate #ifdef _LP64
2187c478bd9Sstevel@tonic-gate 	void		*ml_linkage[7];	/* more space in 64-bit OS */
2197c478bd9Sstevel@tonic-gate #else
2207c478bd9Sstevel@tonic-gate 	void		*ml_linkage[4];	/* NULL terminated list of */
2217c478bd9Sstevel@tonic-gate 					/* linkage structures */
2227c478bd9Sstevel@tonic-gate #endif
2237c478bd9Sstevel@tonic-gate };
2247c478bd9Sstevel@tonic-gate 
2257c478bd9Sstevel@tonic-gate /*
2267c478bd9Sstevel@tonic-gate  * commands.  These are the commands supported by the modctl system call.
2277c478bd9Sstevel@tonic-gate  */
2287c478bd9Sstevel@tonic-gate #define	MODLOAD			0
2297c478bd9Sstevel@tonic-gate #define	MODUNLOAD		1
2307c478bd9Sstevel@tonic-gate #define	MODINFO			2
2317c478bd9Sstevel@tonic-gate #define	MODRESERVED		3
2327c478bd9Sstevel@tonic-gate #define	MODSETMINIROOT		4
2337c478bd9Sstevel@tonic-gate #define	MODADDMAJBIND		5
2347c478bd9Sstevel@tonic-gate #define	MODGETPATH		6
2357c478bd9Sstevel@tonic-gate #define	MODREADSYSBIND		7
2367c478bd9Sstevel@tonic-gate #define	MODGETMAJBIND		8
2377c478bd9Sstevel@tonic-gate #define	MODGETNAME		9
2387c478bd9Sstevel@tonic-gate #define	MODSIZEOF_DEVID		10
2397c478bd9Sstevel@tonic-gate #define	MODGETDEVID		11
2407c478bd9Sstevel@tonic-gate #define	MODSIZEOF_MINORNAME	12
2417c478bd9Sstevel@tonic-gate #define	MODGETMINORNAME		13
2427c478bd9Sstevel@tonic-gate #define	MODGETPATHLEN		14
2437c478bd9Sstevel@tonic-gate #define	MODEVENTS		15
2447c478bd9Sstevel@tonic-gate #define	MODGETFBNAME		16
2457c478bd9Sstevel@tonic-gate #define	MODREREADDACF		17
2467c478bd9Sstevel@tonic-gate #define	MODLOADDRVCONF		18
2477c478bd9Sstevel@tonic-gate #define	MODUNLOADDRVCONF	19
2487c478bd9Sstevel@tonic-gate #define	MODREMMAJBIND		20
2497c478bd9Sstevel@tonic-gate #define	MODDEVT2INSTANCE	21
2507c478bd9Sstevel@tonic-gate #define	MODGETDEVFSPATH_LEN	22
2517c478bd9Sstevel@tonic-gate #define	MODGETDEVFSPATH		23
2527c478bd9Sstevel@tonic-gate #define	MODDEVID2PATHS		24
2537c478bd9Sstevel@tonic-gate #define	MODSETDEVPOLICY		26
2547c478bd9Sstevel@tonic-gate #define	MODGETDEVPOLICY		27
2557c478bd9Sstevel@tonic-gate #define	MODALLOCPRIV		28
2567c478bd9Sstevel@tonic-gate #define	MODGETDEVPOLICYBYNAME	29
2577c478bd9Sstevel@tonic-gate #define	MODLOADMINORPERM	31
2587c478bd9Sstevel@tonic-gate #define	MODADDMINORPERM		32
2597c478bd9Sstevel@tonic-gate #define	MODREMMINORPERM		33
2607c478bd9Sstevel@tonic-gate #define	MODREMDRVCLEANUP	34
261facf4a8dSllai1 #define	MODDEVEXISTS		35
262facf4a8dSllai1 #define	MODDEVREADDIR		36
263facf4a8dSllai1 #define	MODDEVNAME		37
264a08731ecScth #define	MODGETDEVFSPATH_MI_LEN	38
265a08731ecScth #define	MODGETDEVFSPATH_MI	39
26625e8c5aaSvikram #define	MODRETIRE		40
26725e8c5aaSvikram #define	MODUNRETIRE		41
26825e8c5aaSvikram #define	MODISRETIRED		42
269e37c6c37Scth #define	MODDEVEMPTYDIR		43
2706532b960SJerry Gilliam #define	MODREMDRVALIAS		44
27126947304SEvan Yan #define	MODHPOPS		45
2727c478bd9Sstevel@tonic-gate 
2737c478bd9Sstevel@tonic-gate /*
2747c478bd9Sstevel@tonic-gate  * sub cmds for MODEVENTS
2757c478bd9Sstevel@tonic-gate  */
2767c478bd9Sstevel@tonic-gate #define	MODEVENTS_FLUSH				0
2777c478bd9Sstevel@tonic-gate #define	MODEVENTS_FLUSH_DUMP			1
2787c478bd9Sstevel@tonic-gate #define	MODEVENTS_SET_DOOR_UPCALL_FILENAME	2
2797c478bd9Sstevel@tonic-gate #define	MODEVENTS_GETDATA			3
2807c478bd9Sstevel@tonic-gate #define	MODEVENTS_FREEDATA			4
2817c478bd9Sstevel@tonic-gate #define	MODEVENTS_POST_EVENT			5
2827c478bd9Sstevel@tonic-gate #define	MODEVENTS_REGISTER_EVENT		6
2837c478bd9Sstevel@tonic-gate 
2847c478bd9Sstevel@tonic-gate /*
285facf4a8dSllai1  * devname subcmds for MODDEVNAME
286facf4a8dSllai1  */
287facf4a8dSllai1 #define	MODDEVNAME_LOOKUPDOOR	0
288facf4a8dSllai1 #define	MODDEVNAME_PROFILE	3
289facf4a8dSllai1 #define	MODDEVNAME_RECONFIG	4
290facf4a8dSllai1 #define	MODDEVNAME_SYSAVAIL	5
291facf4a8dSllai1 
29226947304SEvan Yan /*
29326947304SEvan Yan  * subcmds for MODHPOPS
29426947304SEvan Yan  */
29526947304SEvan Yan #define	MODHPOPS_CHANGE_STATE	0
29626947304SEvan Yan #define	MODHPOPS_CREATE_PORT	1
29726947304SEvan Yan #define	MODHPOPS_REMOVE_PORT	2
29826947304SEvan Yan #define	MODHPOPS_BUS_GET	3
29926947304SEvan Yan #define	MODHPOPS_BUS_SET	4
30026947304SEvan Yan 
301facf4a8dSllai1 
302facf4a8dSllai1 /*
3037c478bd9Sstevel@tonic-gate  * Data structure passed to modconfig command in kernel to build devfs tree
3047c478bd9Sstevel@tonic-gate  */
3057c478bd9Sstevel@tonic-gate 
3067c478bd9Sstevel@tonic-gate struct aliases {
3077c478bd9Sstevel@tonic-gate 	struct aliases *a_next;
3087c478bd9Sstevel@tonic-gate 	char *a_name;
3097c478bd9Sstevel@tonic-gate 	int a_len;
3107c478bd9Sstevel@tonic-gate };
3117c478bd9Sstevel@tonic-gate 
3127c478bd9Sstevel@tonic-gate #define	MAXMODCONFNAME	256
3137c478bd9Sstevel@tonic-gate 
3147c478bd9Sstevel@tonic-gate struct modconfig {
3157c478bd9Sstevel@tonic-gate 	char drvname[MAXMODCONFNAME];
3167c478bd9Sstevel@tonic-gate 	char drvclass[MAXMODCONFNAME];
3177c478bd9Sstevel@tonic-gate 	int major;
3186532b960SJerry Gilliam 	int flags;
3197c478bd9Sstevel@tonic-gate 	int num_aliases;
3207c478bd9Sstevel@tonic-gate 	struct aliases *ap;
3217c478bd9Sstevel@tonic-gate };
3227c478bd9Sstevel@tonic-gate 
3237c478bd9Sstevel@tonic-gate #if defined(_SYSCALL32)
3247c478bd9Sstevel@tonic-gate 
3257c478bd9Sstevel@tonic-gate struct aliases32 {
3267c478bd9Sstevel@tonic-gate 	caddr32_t a_next;
3277c478bd9Sstevel@tonic-gate 	caddr32_t a_name;
3287c478bd9Sstevel@tonic-gate 	int32_t a_len;
3297c478bd9Sstevel@tonic-gate };
3307c478bd9Sstevel@tonic-gate 
3317c478bd9Sstevel@tonic-gate struct modconfig32 {
3327c478bd9Sstevel@tonic-gate 	char drvname[MAXMODCONFNAME];
3337c478bd9Sstevel@tonic-gate 	char drvclass[MAXMODCONFNAME];
3347c478bd9Sstevel@tonic-gate 	int32_t major;
3356532b960SJerry Gilliam 	int32_t flags;
3367c478bd9Sstevel@tonic-gate 	int32_t num_aliases;
3377c478bd9Sstevel@tonic-gate 	caddr32_t ap;
3387c478bd9Sstevel@tonic-gate };
3397c478bd9Sstevel@tonic-gate 
3407c478bd9Sstevel@tonic-gate #endif /* _SYSCALL32 */
3417c478bd9Sstevel@tonic-gate 
3426532b960SJerry Gilliam /* flags for modconfig */
3436532b960SJerry Gilliam #define	MOD_UNBIND_OVERRIDE	0x01		/* fail unbind if in use */
344c9cc1492SJerry Gilliam #define	MOD_ADDMAJBIND_UPDATE	0x02		/* update only, do not load */
345c9cc1492SJerry Gilliam 
346c9cc1492SJerry Gilliam /* flags for MODLOADDRVCONF - modctl_load_drvconf() */
347c9cc1492SJerry Gilliam #define	MOD_LOADDRVCONF_RECONF	0x01		/* complete configuration */
348c9cc1492SJerry Gilliam 						/* after update-only */
3496532b960SJerry Gilliam 
3507c478bd9Sstevel@tonic-gate /*
3517c478bd9Sstevel@tonic-gate  * Max module path length
3527c478bd9Sstevel@tonic-gate  */
3537c478bd9Sstevel@tonic-gate #define	MOD_MAXPATH	256
3547c478bd9Sstevel@tonic-gate 
3557c478bd9Sstevel@tonic-gate /*
3567c478bd9Sstevel@tonic-gate  * Default search path for modules ADDITIONAL to the directory
3577c478bd9Sstevel@tonic-gate  * where the kernel components we booted from are.
3587c478bd9Sstevel@tonic-gate  *
3597c478bd9Sstevel@tonic-gate  * Most often, this will be "/platform/{platform}/kernel /kernel /usr/kernel",
3607c478bd9Sstevel@tonic-gate  * but we don't wire it down here.
3617c478bd9Sstevel@tonic-gate  */
3627c478bd9Sstevel@tonic-gate #define	MOD_DEFPATH	"/kernel /usr/kernel"
3637c478bd9Sstevel@tonic-gate 
3647c478bd9Sstevel@tonic-gate /*
3657c478bd9Sstevel@tonic-gate  * Default file name extension for autoloading modules.
3667c478bd9Sstevel@tonic-gate  */
3677c478bd9Sstevel@tonic-gate #define	MOD_DEFEXT	""
3687c478bd9Sstevel@tonic-gate 
3697c478bd9Sstevel@tonic-gate /*
3707c478bd9Sstevel@tonic-gate  * Parameters for modinfo
3717c478bd9Sstevel@tonic-gate  */
3727c478bd9Sstevel@tonic-gate #define	MODMAXNAMELEN 32		/* max module name length */
3737c478bd9Sstevel@tonic-gate #define	MODMAXLINKINFOLEN 32		/* max link info length */
3747c478bd9Sstevel@tonic-gate 
3757c478bd9Sstevel@tonic-gate /*
3767c478bd9Sstevel@tonic-gate  * Module specific information.
3777c478bd9Sstevel@tonic-gate  */
3787c478bd9Sstevel@tonic-gate struct modspecific_info {
3797c478bd9Sstevel@tonic-gate 	char	msi_linkinfo[MODMAXLINKINFOLEN]; /* name in linkage struct */
3807c478bd9Sstevel@tonic-gate 	int	msi_p0;			/* module specific information */
3817c478bd9Sstevel@tonic-gate };
3827c478bd9Sstevel@tonic-gate 
3837c478bd9Sstevel@tonic-gate /*
3847c478bd9Sstevel@tonic-gate  * Structure returned by modctl with MODINFO command.
3857c478bd9Sstevel@tonic-gate  */
3867c478bd9Sstevel@tonic-gate #define	MODMAXLINK 10			/* max linkages modinfo can handle */
3877c478bd9Sstevel@tonic-gate 
3887c478bd9Sstevel@tonic-gate struct modinfo {
3897c478bd9Sstevel@tonic-gate 	int		   mi_info;		/* Flags for info wanted */
3907c478bd9Sstevel@tonic-gate 	int		   mi_state;		/* Flags for module state */
3917c478bd9Sstevel@tonic-gate 	int		   mi_id;		/* id of this loaded module */
3927c478bd9Sstevel@tonic-gate 	int		   mi_nextid;		/* id of next module or -1 */
3937c478bd9Sstevel@tonic-gate 	caddr_t		   mi_base;		/* virtual addr of text */
3947c478bd9Sstevel@tonic-gate 	size_t		   mi_size;		/* size of module in bytes */
3957c478bd9Sstevel@tonic-gate 	int		   mi_rev;		/* loadable modules rev */
3967c478bd9Sstevel@tonic-gate 	int		   mi_loadcnt;		/* # of times loaded */
3977c478bd9Sstevel@tonic-gate 	char		   mi_name[MODMAXNAMELEN]; /* name of module */
3987c478bd9Sstevel@tonic-gate 	struct modspecific_info mi_msinfo[MODMAXLINK];
3997c478bd9Sstevel@tonic-gate 						/* mod specific info */
4007c478bd9Sstevel@tonic-gate };
4017c478bd9Sstevel@tonic-gate 
4027c478bd9Sstevel@tonic-gate 
4037c478bd9Sstevel@tonic-gate #if defined(_SYSCALL32)
4047c478bd9Sstevel@tonic-gate 
4057c478bd9Sstevel@tonic-gate #define	MODMAXNAMELEN32 32		/* max module name length */
4067c478bd9Sstevel@tonic-gate #define	MODMAXLINKINFOLEN32 32		/* max link info length */
4077c478bd9Sstevel@tonic-gate #define	MODMAXLINK32 10			/* max linkages modinfo can handle */
4087c478bd9Sstevel@tonic-gate 
4097c478bd9Sstevel@tonic-gate struct modspecific_info32 {
4107c478bd9Sstevel@tonic-gate 	char	msi_linkinfo[MODMAXLINKINFOLEN32]; /* name in linkage struct */
4117c478bd9Sstevel@tonic-gate 	int32_t	msi_p0;			/* module specific information */
4127c478bd9Sstevel@tonic-gate };
4137c478bd9Sstevel@tonic-gate 
4147c478bd9Sstevel@tonic-gate struct modinfo32 {
4157c478bd9Sstevel@tonic-gate 	int32_t		   mi_info;		/* Flags for info wanted */
4167c478bd9Sstevel@tonic-gate 	int32_t		   mi_state;		/* Flags for module state */
4177c478bd9Sstevel@tonic-gate 	int32_t		   mi_id;		/* id of this loaded module */
4187c478bd9Sstevel@tonic-gate 	int32_t		   mi_nextid;		/* id of next module or -1 */
4197c478bd9Sstevel@tonic-gate 	caddr32_t	   mi_base;		/* virtual addr of text */
4207c478bd9Sstevel@tonic-gate 	uint32_t	   mi_size;		/* size of module in bytes */
4217c478bd9Sstevel@tonic-gate 	int32_t		   mi_rev;		/* loadable modules rev */
4227c478bd9Sstevel@tonic-gate 	int32_t		   mi_loadcnt;		/* # of times loaded */
4237c478bd9Sstevel@tonic-gate 	char		   mi_name[MODMAXNAMELEN32]; /* name of module */
4247c478bd9Sstevel@tonic-gate 	struct modspecific_info32 mi_msinfo[MODMAXLINK32];
4257c478bd9Sstevel@tonic-gate 						/* mod specific info */
4267c478bd9Sstevel@tonic-gate };
4277c478bd9Sstevel@tonic-gate 
4287c478bd9Sstevel@tonic-gate #endif /* _SYSCALL32 */
4297c478bd9Sstevel@tonic-gate 
4307c478bd9Sstevel@tonic-gate /* Values for mi_info flags */
4317c478bd9Sstevel@tonic-gate #define	MI_INFO_ONE	1
4327c478bd9Sstevel@tonic-gate #define	MI_INFO_ALL	2
4337c478bd9Sstevel@tonic-gate #define	MI_INFO_CNT	4
4347c478bd9Sstevel@tonic-gate #ifdef _KERNEL
4357c478bd9Sstevel@tonic-gate #define	MI_INFO_LINKAGE	8	/* used internally to extract modlinkage */
4367c478bd9Sstevel@tonic-gate #endif
4377c478bd9Sstevel@tonic-gate /*
4387c478bd9Sstevel@tonic-gate  * MI_INFO_NOBASE indicates caller does not need mi_base. Failure to use this
4397c478bd9Sstevel@tonic-gate  * flag may lead 32-bit apps to receive an EOVERFLOW error from modctl(MODINFO)
4407c478bd9Sstevel@tonic-gate  * when used with a 64-bit kernel.
4417c478bd9Sstevel@tonic-gate  */
4427c478bd9Sstevel@tonic-gate #define	MI_INFO_NOBASE	16
4437c478bd9Sstevel@tonic-gate 
4447c478bd9Sstevel@tonic-gate /* Values for mi_state */
4457c478bd9Sstevel@tonic-gate #define	MI_LOADED	1
4467c478bd9Sstevel@tonic-gate #define	MI_INSTALLED	2
4477c478bd9Sstevel@tonic-gate 
4487c478bd9Sstevel@tonic-gate /*
4497c478bd9Sstevel@tonic-gate  * Macros to vector to the appropriate module specific routine.
4507c478bd9Sstevel@tonic-gate  */
4517c478bd9Sstevel@tonic-gate #define	MODL_INSTALL(MODL, MODLP) \
4527c478bd9Sstevel@tonic-gate 	(*(MODL)->misc_modops->modm_install)(MODL, MODLP)
4537c478bd9Sstevel@tonic-gate #define	MODL_REMOVE(MODL, MODLP) \
4547c478bd9Sstevel@tonic-gate 	(*(MODL)->misc_modops->modm_remove)(MODL, MODLP)
4557c478bd9Sstevel@tonic-gate #define	MODL_INFO(MODL, MODLP, P0) \
4567c478bd9Sstevel@tonic-gate 	(*(MODL)->misc_modops->modm_info)(MODL, MODLP, P0)
4577c478bd9Sstevel@tonic-gate 
4587c478bd9Sstevel@tonic-gate /*
4597c478bd9Sstevel@tonic-gate  * Definitions for stubs
4607c478bd9Sstevel@tonic-gate  */
4617c478bd9Sstevel@tonic-gate struct mod_stub_info {
4627c478bd9Sstevel@tonic-gate 	uintptr_t mods_func_adr;
4637c478bd9Sstevel@tonic-gate 	struct mod_modinfo *mods_modinfo;
4647c478bd9Sstevel@tonic-gate 	uintptr_t mods_stub_adr;
4657c478bd9Sstevel@tonic-gate 	int (*mods_errfcn)();
4667c478bd9Sstevel@tonic-gate 	int mods_flag;			/* flags defined below */
4677c478bd9Sstevel@tonic-gate };
4687c478bd9Sstevel@tonic-gate 
4697c478bd9Sstevel@tonic-gate /*
4707c478bd9Sstevel@tonic-gate  * Definitions for mods_flag.
4717c478bd9Sstevel@tonic-gate  */
4727c478bd9Sstevel@tonic-gate #define	MODS_WEAK	0x01		/* weak stub (not loaded if called) */
4737c478bd9Sstevel@tonic-gate #define	MODS_NOUNLOAD	0x02		/* module not unloadable (no _fini()) */
4747c478bd9Sstevel@tonic-gate #define	MODS_INSTALLED	0x10		/* module installed */
4757c478bd9Sstevel@tonic-gate 
4767c478bd9Sstevel@tonic-gate struct mod_modinfo {
4777c478bd9Sstevel@tonic-gate 	char *modm_module_name;
4787c478bd9Sstevel@tonic-gate 	struct modctl *mp;
4797c478bd9Sstevel@tonic-gate 	struct mod_stub_info modm_stubs[1];
4807c478bd9Sstevel@tonic-gate };
4817c478bd9Sstevel@tonic-gate 
4827c478bd9Sstevel@tonic-gate struct modctl_list {
4837c478bd9Sstevel@tonic-gate 	struct modctl_list *modl_next;
4847c478bd9Sstevel@tonic-gate 	struct modctl *modl_modp;
4857c478bd9Sstevel@tonic-gate };
4867c478bd9Sstevel@tonic-gate 
4877c478bd9Sstevel@tonic-gate /*
4887c478bd9Sstevel@tonic-gate  * Structure to manage a loadable module.
4897c478bd9Sstevel@tonic-gate  * Note: the module (mod_mp) structure's "text" and "text_size" information
4907c478bd9Sstevel@tonic-gate  * are replicated in the modctl structure so that mod_containing_pc()
4917c478bd9Sstevel@tonic-gate  * doesn't have to grab any locks (modctls are persistent; modules are not.)
4927c478bd9Sstevel@tonic-gate  */
4937aec1d6eScindi typedef struct modctl {
4947c478bd9Sstevel@tonic-gate 	struct modctl	*mod_next;	/* &modules based list */
4957c478bd9Sstevel@tonic-gate 	struct modctl	*mod_prev;
4967c478bd9Sstevel@tonic-gate 	int		mod_id;
4977c478bd9Sstevel@tonic-gate 	void		*mod_mp;
4987c478bd9Sstevel@tonic-gate 	kthread_t	*mod_inprogress_thread;
4997c478bd9Sstevel@tonic-gate 	struct mod_modinfo *mod_modinfo;
5007c478bd9Sstevel@tonic-gate 	struct modlinkage *mod_linkage;
5017c478bd9Sstevel@tonic-gate 	char		*mod_filename;
5027c478bd9Sstevel@tonic-gate 	char		*mod_modname;
5037c478bd9Sstevel@tonic-gate 
5047c478bd9Sstevel@tonic-gate 	char		mod_busy;	/* inprogress_thread has locked */
5057c478bd9Sstevel@tonic-gate 	char		mod_want;	/* someone waiting for unlock */
5067c478bd9Sstevel@tonic-gate 	char		mod_prim;	/* primary module */
5077c478bd9Sstevel@tonic-gate 
5087c478bd9Sstevel@tonic-gate 	int		mod_ref;	/* ref count - from dependent or stub */
5097c478bd9Sstevel@tonic-gate 
5107c478bd9Sstevel@tonic-gate 	char		mod_loaded;	/* module in memory */
5117c478bd9Sstevel@tonic-gate 	char		mod_installed;	/* post _init pre _fini */
5127c478bd9Sstevel@tonic-gate 	char		mod_loadflags;
5137c478bd9Sstevel@tonic-gate 	char		mod_delay_unload;	/* deferred unload */
5147c478bd9Sstevel@tonic-gate 
5157c478bd9Sstevel@tonic-gate 	struct modctl_list *mod_requisites;	/* mods this one depends on. */
516*c702eacaSToomas Soome 	void		*mod_unused;	/* NOTE: reuse (same size) is OK, */
5177c478bd9Sstevel@tonic-gate 					/* deletion causes mdb.vs.core issues */
5187c478bd9Sstevel@tonic-gate 	int		mod_loadcnt;	/* number of times mod was loaded */
5197c478bd9Sstevel@tonic-gate 	int		mod_nenabled;	/* # of enabled DTrace probes in mod */
5207c478bd9Sstevel@tonic-gate 	char		*mod_text;
5217c478bd9Sstevel@tonic-gate 	size_t		mod_text_size;
5227c478bd9Sstevel@tonic-gate 
5237c478bd9Sstevel@tonic-gate 	int		mod_gencount;	/* # times loaded/unloaded */
5247c478bd9Sstevel@tonic-gate 	struct modctl	*mod_requisite_loading;	/* mod circular dependency */
5257aec1d6eScindi } modctl_t;
5267c478bd9Sstevel@tonic-gate 
5277c478bd9Sstevel@tonic-gate /*
5287c478bd9Sstevel@tonic-gate  * mod_loadflags
5297c478bd9Sstevel@tonic-gate  */
5307c478bd9Sstevel@tonic-gate 
5317c478bd9Sstevel@tonic-gate #define	MOD_NOAUTOUNLOAD	0x1	/* Auto mod-unloader skips this mod */
5327c478bd9Sstevel@tonic-gate #define	MOD_NONOTIFY		0x2	/* No krtld notifications on (un)load */
5337c478bd9Sstevel@tonic-gate #define	MOD_NOUNLOAD		0x4	/* Assume EBUSY for all _fini's */
5347c478bd9Sstevel@tonic-gate 
535facf4a8dSllai1 
5367c478bd9Sstevel@tonic-gate #ifdef _KERNEL
5377c478bd9Sstevel@tonic-gate 
5387c478bd9Sstevel@tonic-gate #define	MOD_BIND_HASHSIZE	64
5397c478bd9Sstevel@tonic-gate #define	MOD_BIND_HASHMASK	(MOD_BIND_HASHSIZE-1)
5407c478bd9Sstevel@tonic-gate 
5417c478bd9Sstevel@tonic-gate typedef int modid_t;
5427c478bd9Sstevel@tonic-gate 
5437c478bd9Sstevel@tonic-gate /*
5447c478bd9Sstevel@tonic-gate  * global function and data declarations
5457c478bd9Sstevel@tonic-gate  */
5467c478bd9Sstevel@tonic-gate extern kmutex_t mod_lock;
5477c478bd9Sstevel@tonic-gate 
5487c478bd9Sstevel@tonic-gate extern char *systemfile;
5497c478bd9Sstevel@tonic-gate extern char **syscallnames;
5507c478bd9Sstevel@tonic-gate extern int moddebug;
5517c478bd9Sstevel@tonic-gate 
5527c478bd9Sstevel@tonic-gate /*
5537c478bd9Sstevel@tonic-gate  * this is the head of a doubly linked list.  Only the next and prev
5547c478bd9Sstevel@tonic-gate  * pointers are used
5557c478bd9Sstevel@tonic-gate  */
5567aec1d6eScindi extern modctl_t modules;
5577aec1d6eScindi 
5587aec1d6eScindi extern int modload_qualified(const char *,
55920c794b3Sgavinm     const char *, const char *, const char *, uint_t[], int, int *);
5607c478bd9Sstevel@tonic-gate 
5617c478bd9Sstevel@tonic-gate extern void	mod_setup(void);
56243d5cd3dSjohnlev extern int	modload(const char *, const char *);
56343d5cd3dSjohnlev extern int	modloadonly(const char *, const char *);
5647c478bd9Sstevel@tonic-gate extern int	modunload(int);
5657c478bd9Sstevel@tonic-gate extern int	mod_hold_stub(struct mod_stub_info *);
5667c478bd9Sstevel@tonic-gate extern void	modunload_disable(void);
5677c478bd9Sstevel@tonic-gate extern void	modunload_enable(void);
568a7aa4df7Scth extern void	modunload_begin(void);
569a7aa4df7Scth extern void	modunload_end(void);
5707c478bd9Sstevel@tonic-gate extern int	mod_remove_by_name(char *);
5717c478bd9Sstevel@tonic-gate extern int	mod_sysvar(const char *, const char *, u_longlong_t *);
5727c478bd9Sstevel@tonic-gate extern int	mod_sysctl(int, void *);
5737c478bd9Sstevel@tonic-gate struct sysparam;
5747aec1d6eScindi extern int	mod_hold_by_modctl(modctl_t *, int);
5757c478bd9Sstevel@tonic-gate #define		MOD_WAIT_ONCE		0x01
5767c478bd9Sstevel@tonic-gate #define		MOD_WAIT_FOREVER	0x02
5777c478bd9Sstevel@tonic-gate #define		MOD_LOCK_HELD		0x04
5787c478bd9Sstevel@tonic-gate #define		MOD_LOCK_NOT_HELD	0x08
5797c478bd9Sstevel@tonic-gate extern int	mod_sysctl_type(int, int (*)(struct sysparam *, void *),
5807c478bd9Sstevel@tonic-gate     void *);
5817c478bd9Sstevel@tonic-gate extern void	mod_read_system_file(int);
5827c478bd9Sstevel@tonic-gate extern void	mod_release_stub(struct mod_stub_info *);
5837c478bd9Sstevel@tonic-gate extern void	mod_askparams(void);
5847c478bd9Sstevel@tonic-gate extern void	mod_uninstall_daemon(void);
5857c478bd9Sstevel@tonic-gate extern void	modreap(void);
5867aec1d6eScindi extern modctl_t *mod_hold_by_id(modid_t);
5877aec1d6eScindi extern modctl_t *mod_hold_by_name(const char *);
5887aec1d6eScindi extern void	mod_release_mod(modctl_t *);
5897aec1d6eScindi extern uintptr_t modlookup(const char *, const char *);
5907aec1d6eScindi extern uintptr_t modlookup_by_modctl(modctl_t *, const char *);
5917c478bd9Sstevel@tonic-gate extern char	*modgetsymname(uintptr_t, unsigned long *);
5927aec1d6eScindi extern void	mod_release_requisites(modctl_t *);
5937aec1d6eScindi extern modctl_t *mod_load_requisite(modctl_t *, char *);
5947aec1d6eScindi extern modctl_t *mod_find_by_filename(char *, char *);
5957c478bd9Sstevel@tonic-gate extern uintptr_t	modgetsymvalue(char *, int);
5967c478bd9Sstevel@tonic-gate 
597c8742f64SJerry Gilliam extern int	major_valid(major_t);
598c9cc1492SJerry Gilliam extern int	driver_installed(major_t);
599c8742f64SJerry Gilliam extern int	driver_active(major_t);
600c8742f64SJerry Gilliam 
6017c478bd9Sstevel@tonic-gate extern void	mod_rele_dev_by_major(major_t);
6027c478bd9Sstevel@tonic-gate extern struct dev_ops *mod_hold_dev_by_major(major_t);
6037c478bd9Sstevel@tonic-gate extern struct dev_ops *mod_hold_dev_by_devi(dev_info_t *);
6047c478bd9Sstevel@tonic-gate extern void	mod_rele_dev_by_devi(dev_info_t *);
6057c478bd9Sstevel@tonic-gate 
606c9cc1492SJerry Gilliam extern int make_devname(char *, major_t, int);
607facf4a8dSllai1 extern int gmatch(const char *, const char *);
6087c478bd9Sstevel@tonic-gate 
6097c478bd9Sstevel@tonic-gate extern void make_aliases(struct bind **);
6107c478bd9Sstevel@tonic-gate extern int read_binding_file(char *, struct bind **,
6117c478bd9Sstevel@tonic-gate     int (*line_parser)(char *, int, char *, struct bind **));
6127c478bd9Sstevel@tonic-gate extern void clear_binding_hash(struct bind **);
6137c478bd9Sstevel@tonic-gate 
6147c478bd9Sstevel@tonic-gate extern void read_class_file(void);
6157c478bd9Sstevel@tonic-gate extern void setbootpath(char *);
6167c478bd9Sstevel@tonic-gate extern void setbootfstype(char *);
6177c478bd9Sstevel@tonic-gate 
6187aec1d6eScindi extern int install_stubs_by_name(modctl_t *, char *);
6197aec1d6eScindi extern void install_stubs(modctl_t *);
6207aec1d6eScindi extern void uninstall_stubs(modctl_t *);
6217aec1d6eScindi extern void reset_stubs(modctl_t *);
6227aec1d6eScindi extern modctl_t *mod_getctl(struct modlinkage *);
6237c478bd9Sstevel@tonic-gate extern major_t mod_name_to_major(char *);
6247c478bd9Sstevel@tonic-gate extern modid_t mod_name_to_modid(char *);
6257c478bd9Sstevel@tonic-gate extern char *mod_major_to_name(major_t);
6267c478bd9Sstevel@tonic-gate extern void init_devnamesp(int);
6277c478bd9Sstevel@tonic-gate extern void init_syscallnames(int);
6287c478bd9Sstevel@tonic-gate 
6297c478bd9Sstevel@tonic-gate extern char *mod_getsysname(int);
6307c478bd9Sstevel@tonic-gate extern int mod_getsysnum(char *);
6317c478bd9Sstevel@tonic-gate 
6327c478bd9Sstevel@tonic-gate extern char *mod_containing_pc(caddr_t);
6337c478bd9Sstevel@tonic-gate extern int mod_in_autounload(void);
634a204de77Scth extern const char *mod_modname(struct modlinkage *);
6357c478bd9Sstevel@tonic-gate 
6367aec1d6eScindi extern int dev_minorperm(dev_info_t *, char *, mperm_t *);
6371aef0e11Sjg extern void dev_devices_cleanup(void);
6387c478bd9Sstevel@tonic-gate 
6397c478bd9Sstevel@tonic-gate /*
6407c478bd9Sstevel@tonic-gate  * Declarations used for dynamic linking support routines.  Interfaces
6417c478bd9Sstevel@tonic-gate  * are marked with the pragma "unknown_control_flow" to prevent tail call
6427c478bd9Sstevel@tonic-gate  * optimization, so that implementations can reliably use caller() to
6437c478bd9Sstevel@tonic-gate  * determine initiating module.
6447c478bd9Sstevel@tonic-gate  */
6457c478bd9Sstevel@tonic-gate #define	KRTLD_MODE_FIRST	0x0001
6467c478bd9Sstevel@tonic-gate typedef	struct __ddi_modhandle	*ddi_modhandle_t;
6477c478bd9Sstevel@tonic-gate extern ddi_modhandle_t		ddi_modopen(const char *,
6487c478bd9Sstevel@tonic-gate 				    int, int *);
6497c478bd9Sstevel@tonic-gate extern void			*ddi_modsym(ddi_modhandle_t,
6507c478bd9Sstevel@tonic-gate 				    const char *, int *);
6517c478bd9Sstevel@tonic-gate extern int			ddi_modclose(ddi_modhandle_t);
6527c478bd9Sstevel@tonic-gate #pragma	unknown_control_flow(ddi_modopen, ddi_modsym, ddi_modclose)
6537c478bd9Sstevel@tonic-gate 
6547c478bd9Sstevel@tonic-gate /*
6557c478bd9Sstevel@tonic-gate  * Only the following are part of the DDI/DKI
6567c478bd9Sstevel@tonic-gate  */
6577c478bd9Sstevel@tonic-gate extern int	_init(void);
6587c478bd9Sstevel@tonic-gate extern int	_fini(void);
6597c478bd9Sstevel@tonic-gate extern int	_info(struct modinfo *);
6607c478bd9Sstevel@tonic-gate extern int	mod_install(struct modlinkage *);
6617c478bd9Sstevel@tonic-gate extern int	mod_remove(struct modlinkage *);
6627c478bd9Sstevel@tonic-gate extern int	mod_info(struct modlinkage *, struct modinfo *);
6637c478bd9Sstevel@tonic-gate 
6647c478bd9Sstevel@tonic-gate #else	/* _KERNEL */
6657c478bd9Sstevel@tonic-gate 
6667c478bd9Sstevel@tonic-gate extern int modctl(int, ...);
6677c478bd9Sstevel@tonic-gate 
6687c478bd9Sstevel@tonic-gate #endif	/* _KERNEL */
6697c478bd9Sstevel@tonic-gate 
6707c478bd9Sstevel@tonic-gate /*
6717c478bd9Sstevel@tonic-gate  * bit definitions for moddebug.
6727c478bd9Sstevel@tonic-gate  */
6737c478bd9Sstevel@tonic-gate #define	MODDEBUG_LOADMSG	0x80000000	/* print "[un]loading..." msg */
6747c478bd9Sstevel@tonic-gate #define	MODDEBUG_ERRMSG		0x40000000	/* print detailed error msgs */
6757c478bd9Sstevel@tonic-gate #define	MODDEBUG_LOADMSG2	0x20000000	/* print 2nd level msgs */
67625e8c5aaSvikram #define	MODDEBUG_RETIRE		0x10000000	/* print retire msgs */
6776532b960SJerry Gilliam #define	MODDEBUG_BINDING	0x00040000	/* driver/alias binding */
6787c478bd9Sstevel@tonic-gate #define	MODDEBUG_FINI_EBUSY	0x00020000	/* pretend fini returns EBUSY */
6797c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_IPP	0x00010000	/* no Autounloading ipp mods */
6807c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_DACF	0x00008000	/* no Autounloading dacf mods */
6817c478bd9Sstevel@tonic-gate #define	MODDEBUG_KEEPTEXT	0x00004000	/* keep text after unloading */
6827c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_DRV	0x00001000	/* no Autounloading Drivers */
6837c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_EXEC	0x00000800	/* no Autounloading Execs */
6847c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_FS	0x00000400	/* no Autounloading File sys */
6857c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_MISC	0x00000200	/* no Autounloading misc */
6867c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_SCHED	0x00000100	/* no Autounloading scheds */
6877c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_STR	0x00000080	/* no Autounloading streams */
6887c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUL_SYS	0x00000040	/* no Autounloading syscalls */
6897c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOCTF		0x00000020	/* do not load CTF debug data */
6907c478bd9Sstevel@tonic-gate #define	MODDEBUG_NOAUTOUNLOAD	0x00000010	/* no autounloading at all */
6917c478bd9Sstevel@tonic-gate #define	MODDEBUG_DDI_MOD	0x00000008	/* ddi_mod{open,sym,close} */
6927c478bd9Sstevel@tonic-gate #define	MODDEBUG_MP_MATCH	0x00000004	/* dev_minorperm */
6937c478bd9Sstevel@tonic-gate #define	MODDEBUG_MINORPERM	0x00000002	/* minor perm modctls */
6947c478bd9Sstevel@tonic-gate #define	MODDEBUG_USERDEBUG	0x00000001	/* bpt after init_module() */
6957c478bd9Sstevel@tonic-gate 
6967c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
6977c478bd9Sstevel@tonic-gate }
6987c478bd9Sstevel@tonic-gate #endif
6997c478bd9Sstevel@tonic-gate 
7007c478bd9Sstevel@tonic-gate #endif	/* _SYS_MODCTL_H */
701