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"
160 kIOKitDiagnosticsClientType
= 0x99000002
164 struct IOKitDiagnosticsParameters
171 uint32_t reserved
[8];
173 typedef struct IOKitDiagnosticsParameters IOKitDiagnosticsParameters
;
177 kIOTrackingCallSiteBTs
= 16,
180 struct IOTrackingCallSiteInfo
184 mach_vm_address_t address
;
185 mach_vm_size_t size
[2];
187 mach_vm_address_t bt
[2][kIOTrackingCallSiteBTs
];
190 #define kIOMallocTrackingName "IOMalloc"
191 #define kIOWireTrackingName "IOWire"
192 #define kIOMapTrackingName "IOMap"
194 #if XNU_KERNEL_PRIVATE && IOTRACKING
196 struct IOTrackingQueue
;
197 struct IOTrackingCallSite
;
202 IOTrackingCallSite
* site
;
203 #if !defined(__LP64__)
208 struct IOTrackingAddress
213 #if defined(__LP64__)
218 struct IOTrackingUser
224 uintptr_t bt
[kIOTrackingCallSiteBTs
];
225 uintptr_t btUser
[kIOTrackingCallSiteBTs
];
230 kIOTrackingQueueTypeDefaultOn
= 0x00000001,
231 kIOTrackingQueueTypeAlloc
= 0x00000002,
232 kIOTrackingQueueTypeMap
= 0x00000004,
233 kIOTrackingQueueTypeUser
= 0x00000008,
237 void IOTrackingInit(void);
238 IOTrackingQueue
* IOTrackingQueueAlloc(const char * name
, uintptr_t btEntry
,
239 size_t allocSize
, size_t minCaptureSize
,
240 uint32_t type
, uint32_t numSiteQs
);
241 void IOTrackingQueueFree(IOTrackingQueue
* head
);
242 void IOTrackingAdd(IOTrackingQueue
* head
, IOTracking
* mem
, size_t size
, bool address
, vm_tag_t tag
);
243 void IOTrackingRemove(IOTrackingQueue
* head
, IOTracking
* mem
, size_t size
);
244 void IOTrackingAddUser(IOTrackingQueue
* queue
, IOTrackingUser
* mem
, vm_size_t size
);
245 void IOTrackingRemoveUser(IOTrackingQueue
* head
, IOTrackingUser
* tracking
);
247 void IOTrackingAlloc(IOTrackingQueue
* head
, uintptr_t address
, size_t size
);
248 void IOTrackingFree(IOTrackingQueue
* head
, uintptr_t address
, size_t size
);
249 void IOTrackingReset(IOTrackingQueue
* head
);
250 void IOTrackingAccumSize(IOTrackingQueue
* head
, IOTracking
* mem
, size_t size
);
251 kern_return_t
IOTrackingDebug(uint32_t selector
, uint32_t options
,
252 const char * names
, size_t namesLen
,
253 size_t size
, OSObject
** result
);
255 extern IOTrackingQueue
* gIOMallocTracking
;
256 extern IOTrackingQueue
* gIOWireTracking
;
257 extern IOTrackingQueue
* gIOMapTracking
;
259 #endif /* XNU_KERNEL_PRIVATE && IOTRACKING */
263 kIOTrackingExcludeNames
= 0x00000001,
268 kIOTrackingGetTracking
= 0x00000001,
269 kIOTrackingGetMappings
= 0x00000002,
270 kIOTrackingResetTracking
= 0x00000003,
271 kIOTrackingStartCapture
= 0x00000004,
272 kIOTrackingStopCapture
= 0x00000005,
273 kIOTrackingSetMinCaptureSize
= 0x00000006,
274 kIOTrackingLeaks
= 0x00000007,
275 kIOTrackingInvalid
= 0xFFFFFFFE,
281 #endif /* __cplusplus */
283 #endif /* ! _IOKIT_IOKITDEBUG_H */