1/* 2 * Copyright (c) 1998-2011 Apple Computer, Inc. All rights reserved. 3 * 4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 5 * 6 * This file contains Original Code and/or Modifications of Original Code 7 * as defined in and that are subject to the Apple Public Source License 8 * Version 2.0 (the 'License'). You may not use this file except in 9 * compliance with the License. The rights granted to you under the License 10 * may not be used to create, or enable the creation or redistribution of, 11 * unlawful or unlicensed copies of an Apple operating system, or to 12 * circumvent, violate, or enable the circumvention or violation of, any 13 * terms of an Apple operating system software license agreement. 14 * 15 * Please obtain a copy of the License at 16 * http://www.opensource.apple.com/apsl/ and read it before using this file. 17 * 18 * The Original Code and all software distributed under the License are 19 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 22 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 23 * Please see the License for the specific language governing rights and 24 * limitations under the License. 25 * 26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 27 */ 28/* 29 * Copyright (c) 1998 Apple Computer, Inc. All rights reserved. 30 * 31 * HISTORY 32 * 33 */ 34 35/* 36 * Internal definitions used between the iokit user library and 37 * server routines. 38 */ 39 40#ifndef _IOKIT_IOKITSERVER_H 41#define _IOKIT_IOKITSERVER_H 42 43#include <IOKit/IOTypes.h> 44#include <IOKit/IOKitKeys.h> 45#include <IOKit/OSMessageNotification.h> 46 47#ifdef __cplusplus 48extern "C" { 49#endif 50#include <mach/kmod.h> 51#ifdef __cplusplus 52} 53#endif 54 55// IOCatalogueSendData 56/*! 57 @enum IOCatalogueSendData user-client flags. 58 @constant kIOCatalogAddDrivers Signals a call to the addDrivers function in IOCatalogue. 59 @constant kIOCatalogAddDriversNoMatch Signals a call to the addDrivers function in IOCatalogue but does not start a matching thread. 60 @constant kIOCatalogRemoveDrivers Signals a call to the removeDrivers function in IOCatalogue. 61 @constant kIOCatalogRemoveDriversNoMatch Signals a call to the removedrivers function in IOCatalogue but does not start a matching thread. 62 @constant kIOCatalogStartMatching Signals the IOCatalogue to start an IOService matching thread. 63 @constant kIOCatalogRemoveKernelLinker Deprecated; does nothing. 64 @constant kIOCatalogKextdActive Signals the kernel that kextd is running. 65 @constant kIOCatalogKextdFinishedLaunching Signals the IOCatalogue that kextd has finished sending it information at startup. 66 @constant kIOCatalogResetDrivers Resets the IOCatalogue with a new set of personalities. 67 @constant kIOCatalogResetDriversNoMatch Resets the IOCatalogue with a new set of personalities but does not start a matching thread. 68*/ 69enum { 70 kIOCatalogAddDrivers = 1, 71 kIOCatalogAddDriversNoMatch, 72 kIOCatalogRemoveDrivers, 73 kIOCatalogRemoveDriversNoMatch, 74 kIOCatalogStartMatching, 75 kIOCatalogRemoveKernelLinker, 76 kIOCatalogKextdActive, 77 kIOCatalogKextdFinishedLaunching, 78 kIOCatalogResetDrivers, 79 kIOCatalogResetDriversNoMatch 80}; 81 82// IOCatalogueGetData 83/*! 84 @enum IOCatalogueGetData user-client flags 85 @constant kIOCatalogGetContents Returns a snapshot of the database to the caller. 86*/ 87enum { 88 kIOCatalogGetContents = 1, 89 kIOCatalogGetModuleDemandList = 2, 90 kIOCatalogGetCacheMissList = 3, 91 kIOCatalogGetROMMkextList = 4 92}; 93 94// IOCatalogueReset 95/*! 96 @enum IOCatalogueReset user-client flag 97 @constant kIOCatalogResetDefault Removes all entries from IOCatalogue except those used for booting the system. 98*/ 99enum { 100 kIOCatalogResetDefault = 1 101}; 102 103// IOCatalogueTerminate 104/*! 105 @enum IOCatalogueTerminate user-client flags. 106 @constant kIOCatalogModuleUnload Terminates all services which depend on a particular module and unloads the module. 107 @constant kIOCatalogModuleTerminate Terminates all services which depend on a particular module but does not unload the module. 108 @constant kIOCatalogServiceTerminate Terminates a particular service by name. 109*/ 110enum { 111 kIOCatalogModuleUnload = 1, 112 kIOCatalogModuleTerminate, 113 kIOCatalogServiceTerminate 114}; 115 116#endif /* ! _IOKIT_IOKITSERVER_H */ 117 118