[SRP] Add WPP
[mirror/winof/.git] / ulp / srp / kernel / srp_debug.h
1 /*\r
2  * Copyright (c) 2005 SilverStorm Technologies.  All rights reserved.\r
3  *\r
4  * This software is available to you under the OpenIB.org BSD license\r
5  * below:\r
6  *\r
7  *     Redistribution and use in source and binary forms, with or\r
8  *     without modification, are permitted provided that the following\r
9  *     conditions are met:\r
10  *\r
11  *      - Redistributions of source code must retain the above\r
12  *        copyright notice, this list of conditions and the following\r
13  *        disclaimer.\r
14  *\r
15  *      - Redistributions in binary form must reproduce the above\r
16  *        copyright notice, this list of conditions and the following\r
17  *        disclaimer in the documentation and/or other materials\r
18  *        provided with the distribution.\r
19  *\r
20  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,\r
21  * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\r
22  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\r
23  * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS\r
24  * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\r
25  * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r
26  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\r
27  * SOFTWARE.\r
28  *\r
29  * $Id$\r
30  */\r
31 \r
32 \r
33 \r
34 #ifndef _SRP_DEBUG_H_\r
35 #define _SRP_DEBUG_H_\r
36 \r
37 \r
38 #include <complib/cl_debug.h>\r
39 \r
40 \r
41 extern uint32_t         g_srp_dbg_level;\r
42 extern uint32_t         g_srp_dbg_flags;\r
43 \r
44 #if defined(EVENT_TRACING)\r
45 //\r
46 // Software Tracing Definitions \r
47 //\r
48 \r
49 \r
50 #define WPP_CONTROL_GUIDS \\r
51         WPP_DEFINE_CONTROL_GUID(SRPCtlGuid,(5AF07B3C,D119,4233,9C81,C07EF481CBE6),  \\r
52         WPP_DEFINE_BIT( SRP_DBG_ERROR) \\r
53         WPP_DEFINE_BIT( SRP_DBG_PNP) \\r
54         WPP_DEFINE_BIT( SRP_DBG_DEBUG))\r
55 \r
56 \r
57 \r
58 #define WPP_LEVEL_FLAGS_ENABLED(lvl, flags) (WPP_LEVEL_ENABLED(flags) && WPP_CONTROL(WPP_BIT_ ## flags).Level  >= lvl)\r
59 #define WPP_LEVEL_FLAGS_LOGGER(lvl,flags) WPP_LEVEL_LOGGER(flags)\r
60 #define WPP_FLAG_ENABLED(flags)(WPP_LEVEL_ENABLED(flags) && WPP_CONTROL(WPP_BIT_ ## flags).Level  >= TRACE_LEVEL_VERBOSE)\r
61 #define WPP_FLAG_LOGGER(flags) WPP_LEVEL_LOGGER(flags)\r
62 \r
63 \r
64 // begin_wpp config\r
65 // SRP_ENTER(FLAG);\r
66 // SRP_EXIT(FLAG);\r
67 // USEPREFIX(SRP_PRINT, "%!STDPREFIX! [SRP] :%!FUNC!() :");\r
68 // USESUFFIX(SRP_ENTER, " [SRP] :%!FUNC!():[");\r
69 // USESUFFIX(SRP_EXIT, " [SRP] :%!FUNC!():]");\r
70 // end_wpp\r
71 \r
72 \r
73 #else\r
74 \r
75 \r
76 #include <evntrace.h>\r
77 \r
78 /*\r
79  * Debug macros\r
80  */\r
81 \r
82 \r
83 #define SRP_DBG_ERR             (1 << 0)\r
84 #define SRP_DBG_PNP             (1 << 1)\r
85 #define SRP_DBG_DEBUG   (1 << 3)\r
86 \r
87 #define SRP_DBG_ERROR   (CL_DBG_ERROR | SRP_DBG_ERR)\r
88 #define SRP_DBG_ALL     CL_DBG_ALL\r
89 \r
90 #if DBG\r
91 \r
92 // assignment of _level_ is need to to overcome warning C4127\r
93 #define SRP_PRINT(_level_,_flag_,_msg_) \\r
94         { \\r
95                 if( g_srp_dbg_level >= (_level_) ) \\r
96                         CL_TRACE( _flag_, g_srp_dbg_flags, _msg_ ); \\r
97         }\r
98 \r
99 #define SRP_PRINT_EXIT(_level_,_flag_,_msg_) \\r
100         { \\r
101                 if( g_srp_dbg_level >= (_level_) ) \\r
102                         CL_TRACE( _flag_, g_srp_dbg_flags, _msg_ );\\r
103                 SRP_EXIT(_flag_);\\r
104         }\r
105 \r
106 #define SRP_ENTER(_flag_) \\r
107         { \\r
108                 if( g_srp_dbg_level >= TRACE_LEVEL_VERBOSE ) \\r
109                         CL_ENTER( _flag_, g_srp_dbg_flags ); \\r
110         }\r
111 \r
112 #define SRP_EXIT(_flag_)\\r
113         { \\r
114                 if( g_srp_dbg_level >= TRACE_LEVEL_VERBOSE ) \\r
115                         CL_EXIT( _flag_, g_srp_dbg_flags ); \\r
116         }\r
117 \r
118 \r
119 #else\r
120 \r
121 #define SRP_PRINT(lvl, flags, msg)\r
122 \r
123 #define SRP_PRINT_EXIT(_level_,_flag_,_msg_)\r
124 \r
125 #define SRP_ENTER(_flag_)\r
126 \r
127 #define SRP_EXIT(_flag_)\r
128 \r
129 \r
130 #endif\r
131 \r
132 \r
133 #endif //EVENT_TRACING\r
134 \r
135 extern char         g_srb_function_name[][32];\r
136 extern char         g_srb_status_name[][32];\r
137 \r
138 #endif  /* _SRP_DEBUG_H_ */\r