]> git.saurik.com Git - apple/xnu.git/blame - iokit/IOKit/IOKitDebug.h
xnu-3248.50.21.tar.gz
[apple/xnu.git] / iokit / IOKit / IOKitDebug.h
CommitLineData
1c79356b 1/*
6d2010ae 2 * Copyright (c) 1998-2010 Apple Inc. All rights reserved.
1c79356b 3 *
2d21ac55 4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
1c79356b 5 *
2d21ac55
A
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.
8f6c56a5 14 *
2d21ac55
A
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
8f6c56a5
A
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
2d21ac55
A
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.
8f6c56a5 25 *
2d21ac55 26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
1c79356b 27 */
1c79356b
A
28
29#ifndef _IOKIT_IOKITDEBUG_H
30#define _IOKIT_IOKITDEBUG_H
31
32#include <IOKit/IOTypes.h>
33
34
35#ifdef __cplusplus
36
37#include <libkern/c++/OSObject.h>
38#include <libkern/c++/OSDictionary.h>
39#include <libkern/c++/OSSerialize.h>
40
41class IOKitDiagnostics : public OSObject
42{
43 OSDeclareDefaultStructors(IOKitDiagnostics)
44
45public:
46 static OSObject * diagnostics( void );
3e170ce0 47 virtual bool serialize(OSSerialize *s) const APPLE_KEXT_OVERRIDE;
1c79356b
A
48private:
49 static void updateOffset( OSDictionary * dict,
3e170ce0 50 UInt64 value, const char * name );
1c79356b
A
51};
52
b0d623f7 53#endif /* __cplusplus */
1c79356b
A
54
55enum {
b0d623f7
A
56 // loggage
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,
060df5ea 67 kIOLogTracePower = 0x00000400ULL, // Obsolete: Use iotrace=0x00000400ULL to enable now
b0d623f7
A
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
060df5ea 76// kIOTraceIOService = 0x00080000ULL, // Obsolete: Use iotrace=0x00080000ULL to enable now
b0d623f7 77 kIOLogHibernate = 0x00100000ULL,
6d2010ae 78 kIOStatistics = 0x04000000ULL,
39236c6e 79 kIOSleepWakeWdogOff = 0x40000000ULL,
3e170ce0 80 kIOKextSpinDump = 0x80000000ULL,
b0d623f7
A
81
82 // debug aids - change behaviour
83 kIONoFreeObjects = 0x00100000ULL,
84 kIOLogSynchronous = 0x00200000ULL, // IOLog completes synchronously
3e170ce0 85 kIOTracking = 0x00400000ULL,
39236c6e 86 kIOWaitQuietPanics = 0x00800000ULL,
3e170ce0
A
87 kIOWaitQuietBeforeRoot = 0x01000000ULL,
88 kIOTrackingBoot = 0x02000000ULL,
b0d623f7
A
89
90 _kIODebugTopFlag = 0x8000000000000000ULL // force enum to be 64 bits
1c79356b
A
91};
92
060df5ea
A
93enum {
94 kIOTraceInterrupts = 0x00000001ULL, // Trace primary interrupts
95 kIOTraceWorkLoops = 0x00000002ULL, // Trace workloop activity
96 kIOTraceEventSources = 0x00000004ULL, // Trace non-passive event sources
97 kIOTraceIntEventSource = 0x00000008ULL, // Trace IOIES and IOFIES sources
98 kIOTraceCommandGates = 0x00000010ULL, // Trace command gate activity
fe8ab488 99 kIOTraceTimers = 0x00000020ULL, // Trace timer event source activity
060df5ea
A
100
101 kIOTracePowerMgmt = 0x00000400ULL, // Trace power management changes
102
103 kIOTraceIOService = 0x00080000ULL, // registerService/termination
104
105 kIOTraceCompatBootArgs = kIOTraceIOService | kIOTracePowerMgmt
106};
107
b0d623f7 108extern SInt64 gIOKitDebug;
060df5ea 109extern SInt64 gIOKitTrace;
1c79356b 110
55e303ae
A
111#ifdef __cplusplus
112extern "C" {
113#endif
114
6d2010ae
A
115#ifdef __cplusplus
116class IORegistryPlane;
117#endif
118
119extern void IOPrintPlane(
120#ifdef __cplusplus
121 const IORegistryPlane * plane
122#else
123 const struct IORegistryPlane * plane
124#endif
125 );
b0d623f7
A
126#ifndef _OSCPPDEBUG_H
127extern void OSPrintMemory( void );
128#endif
1c79356b
A
129#define IOPrintMemory OSPrintMemory
130
3e170ce0
A
131
132
133#define kIOKitDiagnosticsClientClassName "IOKitDiagnosticsClient"
134
135enum
136{
137 kIOKitDiagnosticsClientType = 0x99000002
138};
139
140
141struct IOKitDiagnosticsParameters
142{
143 size_t size;
144 uint64_t value;
145 uint32_t options;
146 uint32_t reserved[3];
147};
148typedef struct IOKitDiagnosticsParameters IOKitDiagnosticsParameters;
149
150enum
151{
152 kIOTrackingCallSiteBTs = 16,
153};
154
155struct IOTrackingCallSiteInfo
156{
157 uint32_t count;
158 size_t size[2];
159 uintptr_t bt[kIOTrackingCallSiteBTs];
160};
161
162#define kIOMallocTrackingName "IOMalloc"
163#define kIOWireTrackingName "IOWire"
164#define kIOMapTrackingName "IOMap"
165
166#if KERNEL && IOTRACKING
167
168struct IOTrackingQueue;
169struct IOTrackingCallSite;
170
171struct IOTracking
172{
173 queue_chain_t link;
174 IOTrackingCallSite * site;
175#if !defined(__LP64__)
176 uint32_t flags;
177#endif
178};
179
180struct IOTrackingAddress
181{
182 IOTracking tracking;
183 uintptr_t address;
184 size_t size;
185#if defined(__LP64__)
186 uint32_t flags;
187#endif
188};
189
190void IOTrackingInit(void);
191IOTrackingQueue * IOTrackingQueueAlloc(const char * name, size_t allocSize, size_t minCaptureSize, bool isAlloc);
192void IOTrackingQueueFree(IOTrackingQueue * head);
193void IOTrackingAdd(IOTrackingQueue * head, IOTracking * mem, size_t size, bool address);
194void IOTrackingRemove(IOTrackingQueue * head, IOTracking * mem, size_t size);
195void IOTrackingAlloc(IOTrackingQueue * head, uintptr_t address, size_t size);
196void IOTrackingFree(IOTrackingQueue * head, uintptr_t address, size_t size);
197void IOTrackingReset(IOTrackingQueue * head);
198void IOTrackingAccumSize(IOTrackingQueue * head, IOTracking * mem, size_t size);
199kern_return_t IOTrackingDebug(uint32_t selector, uint32_t options,
200 const char * names, size_t namesLen,
201 size_t size, OSObject ** result);
202
203extern IOTrackingQueue * gIOMallocTracking;
204extern IOTrackingQueue * gIOWireTracking;
205extern IOTrackingQueue * gIOMapTracking;
206
207#endif /* KERNEL && IOTRACKING */
208
209enum
210{
211 kIOTrackingExcludeNames = 0x00000001,
212};
213
214enum
215{
216 kIOTrackingGetTracking = 0x00000001,
217 kIOTrackingPrintTracking = 0x00000002,
218 kIOTrackingResetTracking = 0x00000003,
219 kIOTrackingStartCapture = 0x00000004,
220 kIOTrackingStopCapture = 0x00000005,
221 kIOTrackingSetMinCaptureSize = 0x00000006,
222 kIOTrackingLeaks = 0x00000007,
223 kIOTrackingInvalid = 0xFFFFFFFE,
224};
225
226
1c79356b
A
227#ifdef __cplusplus
228} /* extern "C" */
229#endif /* __cplusplus */
230
231#endif /* ! _IOKIT_IOKITDEBUG_H */