[SRP] add SCSI errors to the logs
[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_DATA) \\r
55         WPP_DEFINE_BIT( SRP_DBG_DEBUG))\r
56 \r
57 \r
58 \r
59 #define WPP_LEVEL_FLAGS_ENABLED(lvl, flags) (WPP_LEVEL_ENABLED(flags) && WPP_CONTROL(WPP_BIT_ ## flags).Level  >= lvl)\r
60 #define WPP_LEVEL_FLAGS_LOGGER(lvl,flags) WPP_LEVEL_LOGGER(flags)\r
61 #define WPP_FLAG_ENABLED(flags)(WPP_LEVEL_ENABLED(flags) && WPP_CONTROL(WPP_BIT_ ## flags).Level  >= TRACE_LEVEL_VERBOSE)\r
62 #define WPP_FLAG_LOGGER(flags) WPP_LEVEL_LOGGER(flags)\r
63 \r
64 \r
65 // begin_wpp config\r
66 // SRP_ENTER(FLAG);\r
67 // SRP_EXIT(FLAG);\r
68 // USEPREFIX(SRP_PRINT, "%!STDPREFIX! [SRP] :%!FUNC!() :");\r
69 // USESUFFIX(SRP_ENTER, " [SRP] :%!FUNC!():[");\r
70 // USESUFFIX(SRP_EXIT, " [SRP] :%!FUNC!():]");\r
71 // end_wpp\r
72 \r
73 \r
74 #else\r
75 \r
76 \r
77 #include <evntrace.h>\r
78 \r
79 /*\r
80  * Debug macros\r
81  */\r
82 \r
83 \r
84 #define SRP_DBG_ERR             (1 << 0)\r
85 #define SRP_DBG_PNP             (1 << 1)\r
86 #define SRP_DBG_DATA    (1 << 2)\r
87 #define SRP_DBG_DEBUG   (1 << 3)\r
88 \r
89 #define SRP_DBG_ERROR   (CL_DBG_ERROR | SRP_DBG_ERR)\r
90 #define SRP_DBG_ALL     CL_DBG_ALL\r
91 \r
92 #if DBG\r
93 \r
94 // assignment of _level_ is need to to overcome warning C4127\r
95 #define SRP_PRINT(_level_,_flag_,_msg_) \\r
96         { \\r
97                 if( g_srp_dbg_level >= (_level_) ) \\r
98                         CL_TRACE( _flag_, g_srp_dbg_flags, _msg_ ); \\r
99         }\r
100 \r
101 #define SRP_PRINT_EXIT(_level_,_flag_,_msg_) \\r
102         { \\r
103                 if( g_srp_dbg_level >= (_level_) ) \\r
104                         CL_TRACE( _flag_, g_srp_dbg_flags, _msg_ );\\r
105                 SRP_EXIT(_flag_);\\r
106         }\r
107 \r
108 #define SRP_ENTER(_flag_) \\r
109         { \\r
110                 if( g_srp_dbg_level >= TRACE_LEVEL_VERBOSE ) \\r
111                         CL_ENTER( _flag_, g_srp_dbg_flags ); \\r
112         }\r
113 \r
114 #define SRP_EXIT(_flag_)\\r
115         { \\r
116                 if( g_srp_dbg_level >= TRACE_LEVEL_VERBOSE ) \\r
117                         CL_EXIT( _flag_, g_srp_dbg_flags ); \\r
118         }\r
119 \r
120 \r
121 #else\r
122 \r
123 #define SRP_PRINT(lvl, flags, msg)\r
124 \r
125 #define SRP_PRINT_EXIT(_level_,_flag_,_msg_)\r
126 \r
127 #define SRP_ENTER(_flag_)\r
128 \r
129 #define SRP_EXIT(_flag_)\r
130 \r
131 \r
132 #endif\r
133 \r
134 \r
135 #endif //EVENT_TRACING\r
136 \r
137 extern char         g_srb_function_name[][32];\r
138 extern char         g_srb_status_name[][32];\r
139 extern char         g_srb_scsi_status_name[][32];\r
140 \r
141 #endif  /* _SRP_DEBUG_H_ */\r