2 * Copyright (c) 1998-2010 Apple Inc. All rights reserved.
4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
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.
15 * Please obtain a copy of the License at
16 * http://www.opensource.apple.com/apsl/ and read it before using this file.
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.
26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
29 #ifndef _IOKIT_IOKITDEBUG_H
30 #define _IOKIT_IOKITDEBUG_H
32 #include <IOKit/IOTypes.h>
37 #include <libkern/c++/OSObject.h>
38 #include <libkern/c++/OSDictionary.h>
39 #include <libkern/c++/OSSerialize.h>
41 class IOKitDiagnostics
: public OSObject
43 OSDeclareDefaultStructors(IOKitDiagnostics
)
46 static OSObject
* diagnostics( void );
47 virtual bool serialize(OSSerialize
*s
) const APPLE_KEXT_OVERRIDE
;
49 static void updateOffset( OSDictionary
* dict
,
50 UInt64 value
, const char * name
);
53 #endif /* __cplusplus */
57 kIOLogAttach
= 0x00000001ULL
,
58 kIOLogProbe
= 0x00000002ULL
,
59 kIOLogStart
= 0x00000004ULL
,
60 kIOLogRegister
= 0x00000008ULL
,
61 kIOLogMatch
= 0x00000010ULL
,
62 kIOLogConfig
= 0x00000020ULL
,
63 kIOLogYield
= 0x00000040ULL
,
64 kIOLogPower
= 0x00000080ULL
,
65 kIOLogMapping
= 0x00000100ULL
,
66 kIOLogCatalogue
= 0x00000200ULL
,
67 kIOLogTracePower
= 0x00000400ULL
, // Obsolete: Use iotrace=0x00000400ULL to enable now
68 kIOLogDebugPower
= 0x00000800ULL
,
69 kIOLogServiceTree
= 0x00001000ULL
,
70 kIOLogDTree
= 0x00002000ULL
,
71 kIOLogMemory
= 0x00004000ULL
,
72 kIOLogKextMemory
= 0x00008000ULL
,
73 kOSLogRegistryMods
= 0x00010000ULL
,// Log attempts to modify registry collections
74 kIOLogPMRootDomain
= 0x00020000ULL
,
75 kOSRegistryModsMode
= 0x00040000ULL
,// Change default registry modification handling - panic vs. log
76 // kIOTraceIOService = 0x00080000ULL, // Obsolete: Use iotrace=0x00080000ULL to enable now
77 kIOLogHibernate
= 0x00100000ULL
,
78 kIOStatistics
= 0x04000000ULL
,
79 kIOSleepWakeWdogOff
= 0x40000000ULL
,
80 kIOKextSpinDump
= 0x80000000ULL
,
82 // debug aids - change behaviour
83 kIONoFreeObjects
= 0x00100000ULL
,
84 // kIOLogSynchronous = 0x00200000ULL, // IOLog completes synchronously -- obsolete
85 kIOTracking
= 0x00400000ULL
,
86 kIOWaitQuietPanics
= 0x00800000ULL
,
87 kIOWaitQuietBeforeRoot
= 0x01000000ULL
,
88 kIOTrackingBoot
= 0x02000000ULL
,
90 _kIODebugTopFlag
= 0x8000000000000000ULL
// force enum to be 64 bits
94 kIOKitDebugUserOptions
= 0
109 | kOSRegistryModsMode
111 | kIOSleepWakeWdogOff
117 kIOTraceInterrupts
= 0x00000001ULL
, // Trace primary interrupts
118 kIOTraceWorkLoops
= 0x00000002ULL
, // Trace workloop activity
119 kIOTraceEventSources
= 0x00000004ULL
, // Trace non-passive event sources
120 kIOTraceIntEventSource
= 0x00000008ULL
, // Trace IOIES and IOFIES sources
121 kIOTraceCommandGates
= 0x00000010ULL
, // Trace command gate activity
122 kIOTraceTimers
= 0x00000020ULL
, // Trace timer event source activity
124 kIOTracePowerMgmt
= 0x00000400ULL
, // Trace power management changes
126 kIOTraceIOService
= 0x00080000ULL
, // registerService/termination
128 kIOTraceCompatBootArgs
= kIOTraceIOService
| kIOTracePowerMgmt
131 extern SInt64 gIOKitDebug
;
132 extern SInt64 gIOKitTrace
;
139 class IORegistryPlane
;
142 extern void IOPrintPlane(
144 const IORegistryPlane
* plane
146 const struct IORegistryPlane
* plane
149 #ifndef _OSCPPDEBUG_H
150 extern void OSPrintMemory( void );
152 #define IOPrintMemory OSPrintMemory
156 #define kIOKitDiagnosticsClientClassName "IOKitDiagnosticsClient"
159 kIOKitDiagnosticsClientType
= 0x99000002
163 struct IOKitDiagnosticsParameters
{
169 uint32_t reserved
[8];
171 typedef struct IOKitDiagnosticsParameters IOKitDiagnosticsParameters
;
174 kIOTrackingCallSiteBTs
= 16,
177 struct IOTrackingCallSiteInfo
{
180 mach_vm_address_t address
;
181 mach_vm_size_t size
[2];
183 mach_vm_address_t bt
[2][kIOTrackingCallSiteBTs
];
186 #define kIOMallocTrackingName "IOMalloc"
187 #define kIOWireTrackingName "IOWire"
188 #define kIOMapTrackingName "IOMap"
190 #if XNU_KERNEL_PRIVATE && IOTRACKING
192 struct IOTrackingQueue
;
193 struct IOTrackingCallSite
;
197 IOTrackingCallSite
* site
;
198 #if !defined(__LP64__)
203 struct IOTrackingAddress
{
207 #if defined(__LP64__)
212 struct IOTrackingUser
{
217 uintptr_t bt
[kIOTrackingCallSiteBTs
];
218 uintptr_t btUser
[kIOTrackingCallSiteBTs
];
222 kIOTrackingQueueTypeDefaultOn
= 0x00000001,
223 kIOTrackingQueueTypeAlloc
= 0x00000002,
224 kIOTrackingQueueTypeMap
= 0x00000004,
225 kIOTrackingQueueTypeUser
= 0x00000008,
229 void IOTrackingInit(void);
230 IOTrackingQueue
* IOTrackingQueueAlloc(const char * name
, uintptr_t btEntry
,
231 size_t allocSize
, size_t minCaptureSize
,
232 uint32_t type
, uint32_t numSiteQs
);
233 void IOTrackingQueueFree(IOTrackingQueue
* head
);
234 void IOTrackingAdd(IOTrackingQueue
* head
, IOTracking
* mem
, size_t size
, bool address
, vm_tag_t tag
);
235 void IOTrackingRemove(IOTrackingQueue
* head
, IOTracking
* mem
, size_t size
);
236 void IOTrackingAddUser(IOTrackingQueue
* queue
, IOTrackingUser
* mem
, vm_size_t size
);
237 void IOTrackingRemoveUser(IOTrackingQueue
* head
, IOTrackingUser
* tracking
);
239 void IOTrackingAlloc(IOTrackingQueue
* head
, uintptr_t address
, size_t size
);
240 void IOTrackingFree(IOTrackingQueue
* head
, uintptr_t address
, size_t size
);
241 void IOTrackingReset(IOTrackingQueue
* head
);
242 void IOTrackingAccumSize(IOTrackingQueue
* head
, IOTracking
* mem
, size_t size
);
243 kern_return_t
IOTrackingDebug(uint32_t selector
, uint32_t options
,
244 const char * names
, size_t namesLen
,
245 size_t size
, OSObject
** result
);
247 extern IOTrackingQueue
* gIOMallocTracking
;
248 extern IOTrackingQueue
* gIOWireTracking
;
249 extern IOTrackingQueue
* gIOMapTracking
;
251 #endif /* XNU_KERNEL_PRIVATE && IOTRACKING */
254 kIOTrackingExcludeNames
= 0x00000001,
258 kIOTrackingGetTracking
= 0x00000001,
259 kIOTrackingGetMappings
= 0x00000002,
260 kIOTrackingResetTracking
= 0x00000003,
261 kIOTrackingStartCapture
= 0x00000004,
262 kIOTrackingStopCapture
= 0x00000005,
263 kIOTrackingSetMinCaptureSize
= 0x00000006,
264 kIOTrackingLeaks
= 0x00000007,
265 kIOTrackingInvalid
= 0xFFFFFFFE,
271 #endif /* __cplusplus */
273 #endif /* ! _IOKIT_IOKITDEBUG_H */