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