xref: /xnu-10002.1.13/iokit/Kernel/IOReporterDefs.h (revision 1031c584a5e37aff177559b9f69dbd3c8c3fd30a)
1*1031c584SApple OSS Distributions /*
2*1031c584SApple OSS Distributions  * Copyright (c) 2012-2013 Apple Computer, Inc.  All Rights Reserved.
3*1031c584SApple OSS Distributions  *
4*1031c584SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*1031c584SApple OSS Distributions  *
6*1031c584SApple OSS Distributions  * This file contains Original Code and/or Modifications of Original Code
7*1031c584SApple OSS Distributions  * as defined in and that are subject to the Apple Public Source License
8*1031c584SApple OSS Distributions  * Version 2.0 (the 'License'). You may not use this file except in
9*1031c584SApple OSS Distributions  * compliance with the License. The rights granted to you under the License
10*1031c584SApple OSS Distributions  * may not be used to create, or enable the creation or redistribution of,
11*1031c584SApple OSS Distributions  * unlawful or unlicensed copies of an Apple operating system, or to
12*1031c584SApple OSS Distributions  * circumvent, violate, or enable the circumvention or violation of, any
13*1031c584SApple OSS Distributions  * terms of an Apple operating system software license agreement.
14*1031c584SApple OSS Distributions  *
15*1031c584SApple OSS Distributions  * Please obtain a copy of the License at
16*1031c584SApple OSS Distributions  * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*1031c584SApple OSS Distributions  *
18*1031c584SApple OSS Distributions  * The Original Code and all software distributed under the License are
19*1031c584SApple OSS Distributions  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*1031c584SApple OSS Distributions  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*1031c584SApple OSS Distributions  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*1031c584SApple OSS Distributions  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*1031c584SApple OSS Distributions  * Please see the License for the specific language governing rights and
24*1031c584SApple OSS Distributions  * limitations under the License.
25*1031c584SApple OSS Distributions  *
26*1031c584SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*1031c584SApple OSS Distributions  */
28*1031c584SApple OSS Distributions 
29*1031c584SApple OSS Distributions #ifndef _IOEPORTERDEFS_H
30*1031c584SApple OSS Distributions #define _IOEPORTERDEFS_H
31*1031c584SApple OSS Distributions 
32*1031c584SApple OSS Distributions //#include "IOReportHubCommon.h"
33*1031c584SApple OSS Distributions 
34*1031c584SApple OSS Distributions //#define IORDEBUG_IOLOG
35*1031c584SApple OSS Distributions 
36*1031c584SApple OSS Distributions #if defined(IORDEBUG_IOLOG)
37*1031c584SApple OSS Distributions #define IORLOG(fmt, args...)    \
38*1031c584SApple OSS Distributions do {                            \
39*1031c584SApple OSS Distributions     IOLog((fmt), ##args);         \
40*1031c584SApple OSS Distributions     IOLog("\n");                \
41*1031c584SApple OSS Distributions } while(0)
42*1031c584SApple OSS Distributions 
43*1031c584SApple OSS Distributions #else
44*1031c584SApple OSS Distributions #define IORLOG(fmt, args...)
45*1031c584SApple OSS Distributions #endif
46*1031c584SApple OSS Distributions 
47*1031c584SApple OSS Distributions #define IORERROR_LOG
48*1031c584SApple OSS Distributions 
49*1031c584SApple OSS Distributions #ifdef IORERROR_LOG
50*1031c584SApple OSS Distributions #define IORERROR(fmt, args...) IOLog(fmt, ##args);
51*1031c584SApple OSS Distributions #else
52*1031c584SApple OSS Distributions #define IORERROR(fmt, args...)
53*1031c584SApple OSS Distributions #endif
54*1031c584SApple OSS Distributions 
55*1031c584SApple OSS Distributions // overflow detection routines
56*1031c584SApple OSS Distributions #if (SIZE_T_MAX < INT_MAX)
57*1031c584SApple OSS Distributions #error "(SIZE_T_MAX < INT_MAX) -> PREFL_MEMOP_*()) unsafe for size_t"
58*1031c584SApple OSS Distributions #endif
59*1031c584SApple OSS Distributions 
60*1031c584SApple OSS Distributions #define PREFL_MEMOP_FAIL(__val, __type) do {  \
61*1031c584SApple OSS Distributions     if (__val <= 0) {  \
62*1031c584SApple OSS Distributions 	IORERROR("%s - %s <= 0!\n", __func__, #__val);  \
63*1031c584SApple OSS Distributions 	res = kIOReturnUnderrun;  \
64*1031c584SApple OSS Distributions 	goto finish;  \
65*1031c584SApple OSS Distributions     }  else if (__val > INT_MAX / (int)sizeof(__type)) {  \
66*1031c584SApple OSS Distributions 	IORERROR("%s - %s > INT_MAX / sizeof(%s)!\n",__func__,#__val,#__type);\
67*1031c584SApple OSS Distributions 	res = kIOReturnOverrun;  \
68*1031c584SApple OSS Distributions 	goto finish;  \
69*1031c584SApple OSS Distributions     }  \
70*1031c584SApple OSS Distributions } while(0)
71*1031c584SApple OSS Distributions 
72*1031c584SApple OSS Distributions #define PREFL_MEMOP_PANIC(__val, __type) do {  \
73*1031c584SApple OSS Distributions     if (__val <= 0) {  \
74*1031c584SApple OSS Distributions 	panic("%s - %s <= 0!", __func__, #__val);  \
75*1031c584SApple OSS Distributions     }  else if (__val > INT_MAX / (int)sizeof(__type)) {  \
76*1031c584SApple OSS Distributions 	panic("%s - %s > INT_MAX / sizeof(%s)!", __func__, #__val, #__type);  \
77*1031c584SApple OSS Distributions     }  \
78*1031c584SApple OSS Distributions } while(0)
79*1031c584SApple OSS Distributions 
80*1031c584SApple OSS Distributions //#include "IOReportHubCommon.h"//
81*1031c584SApple OSS Distributions 
82*1031c584SApple OSS Distributions 
83*1031c584SApple OSS Distributions 
84*1031c584SApple OSS Distributions #define IOREPORTER_DEBUG_ELEMENT(idx)                                   \
85*1031c584SApple OSS Distributions do {                                                                    \
86*1031c584SApple OSS Distributions IOLog("IOReporter::DrvID: %llx | Elt:[%3d] |ID: %llx |Ticks: %llu |",   \
87*1031c584SApple OSS Distributions _elements[idx].provider_id,                                             \
88*1031c584SApple OSS Distributions idx,                                                                    \
89*1031c584SApple OSS Distributions _elements[idx].channel_id,                                              \
90*1031c584SApple OSS Distributions _elements[idx].timestamp);                                              \
91*1031c584SApple OSS Distributions IOLog("0: %llu | 1: %llu | 2: %llu | 3: %llu\n",                        \
92*1031c584SApple OSS Distributions _elements[idx].values.v[0],                                             \
93*1031c584SApple OSS Distributions _elements[idx].values.v[1],                                             \
94*1031c584SApple OSS Distributions _elements[idx].values.v[2],                                             \
95*1031c584SApple OSS Distributions _elements[idx].values.v[3]);                                            \
96*1031c584SApple OSS Distributions } while(0)
97*1031c584SApple OSS Distributions 
98*1031c584SApple OSS Distributions 
99*1031c584SApple OSS Distributions #define IOREPORTER_CHECK_LOCK()                                         \
100*1031c584SApple OSS Distributions do {                                                                    \
101*1031c584SApple OSS Distributions     if (!_reporterIsLocked) {                                           \
102*1031c584SApple OSS Distributions 	panic("%s was called out of locked context!", __PRETTY_FUNCTION__); \
103*1031c584SApple OSS Distributions     }                                                                   \
104*1031c584SApple OSS Distributions } while(0)                                                              \
105*1031c584SApple OSS Distributions 
106*1031c584SApple OSS Distributions #define IOREPORTER_CHECK_CONFIG_LOCK()                                  \
107*1031c584SApple OSS Distributions do {                                                                    \
108*1031c584SApple OSS Distributions     if (!_reporterConfigIsLocked) {                                     \
109*1031c584SApple OSS Distributions 	panic("%s was called out of config locked context!", __PRETTY_FUNCTION__); \
110*1031c584SApple OSS Distributions     }                                                                   \
111*1031c584SApple OSS Distributions } while(0)                                                              \
112*1031c584SApple OSS Distributions 
113*1031c584SApple OSS Distributions #endif /* ! _IOEPORTERDEFS_H */
114