]> git.saurik.com Git - apple/xnu.git/blobdiff - iokit/Kernel/IOServicePrivate.h
xnu-2782.1.97.tar.gz
[apple/xnu.git] / iokit / Kernel / IOServicePrivate.h
index d9a341f470ffe9d60217e0f20cb602bdeec609b1..465b8261a08638dab0684ec5bb0218bdd4032196 100644 (file)
@@ -1,16 +1,19 @@
 /*
  * Copyright (c) 1998-2000 Apple Computer, Inc. All rights reserved.
  *
- * @APPLE_LICENSE_HEADER_START@
- * 
- * Copyright (c) 1999-2003 Apple Computer, Inc.  All Rights Reserved.
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
  * This file contains Original Code and/or Modifications of Original Code
  * as defined in and that are subject to the Apple Public Source License
  * Version 2.0 (the 'License'). You may not use this file except in
- * compliance with the License. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
+ * compliance with the License. The rights granted to you under the License
+ * may not be used to create, or enable the creation or redistribution of,
+ * unlawful or unlicensed copies of an Apple operating system, or to
+ * circumvent, violate, or enable the circumvention or violation of, any
+ * terms of an Apple operating system software license agreement.
+ * 
+ * Please obtain a copy of the License at
+ * http://www.opensource.apple.com/apsl/ and read it before using this file.
  * 
  * The Original Code and all software distributed under the License are
  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
@@ -20,7 +23,7 @@
  * Please see the License for the specific language governing rights and
  * limitations under the License.
  * 
- * @APPLE_LICENSE_HEADER_END@
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 /*
  * Copyright (c) 1999 Apple Computer, Inc.  All rights reserved. 
 
 // options for getExistingServices()
 enum {
-    kIONotifyOnce              = 0x00000001
+    kIONotifyOnce            = 0x00000001,
+    kIOServiceExistingSet     = 0x00000002,
+    kIOServiceChangesOK       = 0x00000004,
+    kIOServiceInternalDone    = 0x00000008,
+    kIOServiceClassDone       = 0x00000010,
 };
 
 // masks for __state[1]
@@ -49,13 +56,13 @@ enum {
 
     kIOServiceSyncPubState     = 0x08000000,
     kIOServiceConfigState      = 0x04000000,
+    kIOServiceStartState       = 0x02000000,
     kIOServiceTermPhase2State  = 0x01000000,
     kIOServiceTermPhase3State  = 0x00800000,
-};
-
-// options for terminate()
-enum {
+    kIOServiceTermPhase1State  = 0x00400000,
+    kIOServiceTerm1WaiterState  = 0x00200000,
     kIOServiceRecursing                = 0x00100000,
+    kIOServiceNeedWillTerminate = 0x00080000,
 };
 
 // notify state
@@ -80,7 +87,8 @@ public:
     OSOrderedSet *                     whence;
 
     OSDictionary *                     matching;
-    IOServiceNotificationHandler       handler;
+    IOServiceMatchingNotificationHandler handler;
+    IOServiceNotificationHandler       compatHandler;
     void *                             target;
     void *                             ref;
     SInt32                             priority;
@@ -101,7 +109,7 @@ class _IOServiceInterestNotifier : public IONotifier
     OSDeclareDefaultStructors(_IOServiceInterestNotifier)
 
 public:
-    OSArray *                  whence;
+    queue_chain_t              chain;
 
     IOServiceInterestHandler   handler;
     void *                     target;
@@ -114,6 +122,7 @@ public:
     virtual bool disable();
     virtual void enable( bool was );
     virtual void wait();
+    virtual bool init();
 };
 
 class _IOConfigThread : public OSObject
@@ -123,20 +132,14 @@ class _IOConfigThread : public OSObject
     OSDeclareDefaultStructors(_IOConfigThread)
 
 public:
-    IOThread           thread;
-
     virtual void free();
 
-    static _IOConfigThread * configThread( void );
-    static void main( _IOConfigThread * self );
+    static void configThread( void );
+    static void main( void * arg, wait_result_t result );
 };
 
 enum {
-#ifdef LESS_THREAD_CREATE
-    kMaxConfigThreads  = 4,
-#else
-    kMaxConfigThreads  = 32,
-#endif
+       kMaxConfigThreads       = CONFIG_MAX_THREADS,
 };
 
 enum {
@@ -168,6 +171,7 @@ class IOResources : public IOService
 
 public:
     static IOService * resources( void );
+    virtual bool init( OSDictionary * dictionary = 0 );
     virtual IOWorkLoop * getWorkLoop( ) const;
     virtual bool matchPropertyTable( OSDictionary * table );
     virtual IOReturn setProperties( OSObject * properties );
@@ -194,5 +198,11 @@ public:
     virtual OSObject * getNextObject();
 };
 
+extern const OSSymbol * gIOConsoleUsersKey;
+extern const OSSymbol * gIOConsoleSessionUIDKey;
+extern const OSSymbol *        gIOConsoleSessionAuditIDKey;
+extern const OSSymbol * gIOConsoleSessionOnConsoleKey;
+extern const OSSymbol * gIOConsoleSessionSecureInputPIDKey;
+
 #endif /* ! _IOKIT_IOSERVICEPRIVATE_H */