xref: /aosp_15_r20/external/swiftshader/src/System/Debug.hpp (revision 03ce13f70fcc45d86ee91b7ee4cab1936a95046e)
1*03ce13f7SAndroid Build Coastguard Worker // Copyright 2016 The SwiftShader Authors. All Rights Reserved.
2*03ce13f7SAndroid Build Coastguard Worker //
3*03ce13f7SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
4*03ce13f7SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
5*03ce13f7SAndroid Build Coastguard Worker // You may obtain a copy of the License at
6*03ce13f7SAndroid Build Coastguard Worker //
7*03ce13f7SAndroid Build Coastguard Worker //    http://www.apache.org/licenses/LICENSE-2.0
8*03ce13f7SAndroid Build Coastguard Worker //
9*03ce13f7SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*03ce13f7SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
11*03ce13f7SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*03ce13f7SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
13*03ce13f7SAndroid Build Coastguard Worker // limitations under the License.
14*03ce13f7SAndroid Build Coastguard Worker 
15*03ce13f7SAndroid Build Coastguard Worker // debug.h: Debugging utilities.
16*03ce13f7SAndroid Build Coastguard Worker 
17*03ce13f7SAndroid Build Coastguard Worker #ifndef Debug_hpp
18*03ce13f7SAndroid Build Coastguard Worker #define Debug_hpp
19*03ce13f7SAndroid Build Coastguard Worker 
20*03ce13f7SAndroid Build Coastguard Worker #include <assert.h>
21*03ce13f7SAndroid Build Coastguard Worker #include <stdio.h>
22*03ce13f7SAndroid Build Coastguard Worker #include <stdlib.h>
23*03ce13f7SAndroid Build Coastguard Worker 
24*03ce13f7SAndroid Build Coastguard Worker #include <cctype>
25*03ce13f7SAndroid Build Coastguard Worker #include <string>
26*03ce13f7SAndroid Build Coastguard Worker 
27*03ce13f7SAndroid Build Coastguard Worker #if !defined(TRACE_OUTPUT_FILE)
28*03ce13f7SAndroid Build Coastguard Worker #	define TRACE_OUTPUT_FILE "debug.txt"
29*03ce13f7SAndroid Build Coastguard Worker #endif
30*03ce13f7SAndroid Build Coastguard Worker 
31*03ce13f7SAndroid Build Coastguard Worker #if defined(__GNUC__) || defined(__clang__)
32*03ce13f7SAndroid Build Coastguard Worker #	define CHECK_PRINTF_ARGS __attribute__((format(printf, 1, 2)))
33*03ce13f7SAndroid Build Coastguard Worker #else
34*03ce13f7SAndroid Build Coastguard Worker #	define CHECK_PRINTF_ARGS
35*03ce13f7SAndroid Build Coastguard Worker #endif
36*03ce13f7SAndroid Build Coastguard Worker 
37*03ce13f7SAndroid Build Coastguard Worker namespace sw {
38*03ce13f7SAndroid Build Coastguard Worker 
39*03ce13f7SAndroid Build Coastguard Worker // Outputs text to the debugging log
40*03ce13f7SAndroid Build Coastguard Worker void trace(const char *format, ...) CHECK_PRINTF_ARGS;
trace()41*03ce13f7SAndroid Build Coastguard Worker inline void trace() {}
42*03ce13f7SAndroid Build Coastguard Worker 
43*03ce13f7SAndroid Build Coastguard Worker // Outputs text to the debugging log and prints to stderr.
44*03ce13f7SAndroid Build Coastguard Worker void warn(const char *format, ...) CHECK_PRINTF_ARGS;
warn()45*03ce13f7SAndroid Build Coastguard Worker inline void warn() {}
46*03ce13f7SAndroid Build Coastguard Worker 
47*03ce13f7SAndroid Build Coastguard Worker // Outputs the message to the debugging log and stderr, and calls abort().
48*03ce13f7SAndroid Build Coastguard Worker void abort(const char *format, ...) CHECK_PRINTF_ARGS;
49*03ce13f7SAndroid Build Coastguard Worker 
50*03ce13f7SAndroid Build Coastguard Worker // Outputs text to the debugging log, and traps once if a debugger is attached.
51*03ce13f7SAndroid Build Coastguard Worker void log_trap(const char *format, ...) CHECK_PRINTF_ARGS;
52*03ce13f7SAndroid Build Coastguard Worker 
53*03ce13f7SAndroid Build Coastguard Worker }  // namespace sw
54*03ce13f7SAndroid Build Coastguard Worker 
55*03ce13f7SAndroid Build Coastguard Worker // A macro to output a trace of a function call and its arguments to the
56*03ce13f7SAndroid Build Coastguard Worker // debugging log. Disabled if SWIFTSHADER_DISABLE_TRACE is defined.
57*03ce13f7SAndroid Build Coastguard Worker #if defined(SWIFTSHADER_DISABLE_TRACE)
58*03ce13f7SAndroid Build Coastguard Worker #	define TRACE(message, ...) (void(0))
59*03ce13f7SAndroid Build Coastguard Worker #else
60*03ce13f7SAndroid Build Coastguard Worker #	define TRACE(message, ...) sw::trace("%s:%d TRACE: " message "\n", __FILE__, __LINE__, ##__VA_ARGS__)
61*03ce13f7SAndroid Build Coastguard Worker #endif
62*03ce13f7SAndroid Build Coastguard Worker 
63*03ce13f7SAndroid Build Coastguard Worker // A macro to print a warning message to the debugging log and stderr to denote
64*03ce13f7SAndroid Build Coastguard Worker // an issue that needs fixing.
65*03ce13f7SAndroid Build Coastguard Worker #define FIXME(message, ...) sw::warn("%s:%d FIXME: " message "\n", __FILE__, __LINE__, ##__VA_ARGS__)
66*03ce13f7SAndroid Build Coastguard Worker 
67*03ce13f7SAndroid Build Coastguard Worker // A macro to print a warning message to the debugging log and stderr.
68*03ce13f7SAndroid Build Coastguard Worker #define WARN(message, ...) sw::warn("%s:%d WARNING: " message "\n", __FILE__, __LINE__, ##__VA_ARGS__)
69*03ce13f7SAndroid Build Coastguard Worker 
70*03ce13f7SAndroid Build Coastguard Worker // A macro that delegates to:
71*03ce13f7SAndroid Build Coastguard Worker //   abort() in debug builds (!NDEBUG || DCHECK_ALWAYS_ON)
72*03ce13f7SAndroid Build Coastguard Worker // or
73*03ce13f7SAndroid Build Coastguard Worker //   warn() in release builds (NDEBUG && !DCHECK_ALWAYS_ON)
74*03ce13f7SAndroid Build Coastguard Worker #undef DABORT
75*03ce13f7SAndroid Build Coastguard Worker #if !defined(NDEBUG) || defined(DCHECK_ALWAYS_ON)
76*03ce13f7SAndroid Build Coastguard Worker #	define DABORT(message, ...) sw::abort("%s:%d ABORT: " message "\n", __FILE__, __LINE__, ##__VA_ARGS__)
77*03ce13f7SAndroid Build Coastguard Worker #else
78*03ce13f7SAndroid Build Coastguard Worker #	define DABORT(message, ...) sw::warn("%s:%d WARNING: " message "\n", __FILE__, __LINE__, ##__VA_ARGS__);
79*03ce13f7SAndroid Build Coastguard Worker #endif
80*03ce13f7SAndroid Build Coastguard Worker 
81*03ce13f7SAndroid Build Coastguard Worker // A macro asserting a condition.
82*03ce13f7SAndroid Build Coastguard Worker // If the condition fails, the condition and message is passed to DABORT().
83*03ce13f7SAndroid Build Coastguard Worker #undef ASSERT_MSG
84*03ce13f7SAndroid Build Coastguard Worker #if !defined(NDEBUG) || defined(DCHECK_ALWAYS_ON)
85*03ce13f7SAndroid Build Coastguard Worker #	define ASSERT_MSG(expression, format, ...)                                 \
86*03ce13f7SAndroid Build Coastguard Worker 		do                                                                      \
87*03ce13f7SAndroid Build Coastguard Worker 		{                                                                       \
88*03ce13f7SAndroid Build Coastguard Worker 			if(!(expression))                                                   \
89*03ce13f7SAndroid Build Coastguard Worker 			{                                                                   \
90*03ce13f7SAndroid Build Coastguard Worker 				DABORT("ASSERT(%s): " format "\n", #expression, ##__VA_ARGS__); \
91*03ce13f7SAndroid Build Coastguard Worker 			}                                                                   \
92*03ce13f7SAndroid Build Coastguard Worker 		} while(0)
93*03ce13f7SAndroid Build Coastguard Worker #else
94*03ce13f7SAndroid Build Coastguard Worker // Silence unused variable warnings without evaluating the expressions.
95*03ce13f7SAndroid Build Coastguard Worker // TODO(b/154914395): Also ignore variadic arguments (similar to RR_WATCH expansion)
96*03ce13f7SAndroid Build Coastguard Worker #	define ASSERT_MSG(expression, format, ...)    \
97*03ce13f7SAndroid Build Coastguard Worker 		do                                         \
98*03ce13f7SAndroid Build Coastguard Worker 		{                                          \
99*03ce13f7SAndroid Build Coastguard Worker 			(void)sizeof((int)(bool)(expression)); \
100*03ce13f7SAndroid Build Coastguard Worker 			(void)sizeof(format);                  \
101*03ce13f7SAndroid Build Coastguard Worker 		} while(0)
102*03ce13f7SAndroid Build Coastguard Worker #endif
103*03ce13f7SAndroid Build Coastguard Worker 
104*03ce13f7SAndroid Build Coastguard Worker // A macro asserting a condition.
105*03ce13f7SAndroid Build Coastguard Worker // If the condition fails, the condition is passed to DABORT().
106*03ce13f7SAndroid Build Coastguard Worker #undef ASSERT
107*03ce13f7SAndroid Build Coastguard Worker #if !defined(NDEBUG) || defined(DCHECK_ALWAYS_ON)
108*03ce13f7SAndroid Build Coastguard Worker #	define ASSERT(expression)                       \
109*03ce13f7SAndroid Build Coastguard Worker 		do                                           \
110*03ce13f7SAndroid Build Coastguard Worker 		{                                            \
111*03ce13f7SAndroid Build Coastguard Worker 			if(!(expression))                        \
112*03ce13f7SAndroid Build Coastguard Worker 			{                                        \
113*03ce13f7SAndroid Build Coastguard Worker 				DABORT("ASSERT(%s)\n", #expression); \
114*03ce13f7SAndroid Build Coastguard Worker 			}                                        \
115*03ce13f7SAndroid Build Coastguard Worker 		} while(0)
116*03ce13f7SAndroid Build Coastguard Worker #else
117*03ce13f7SAndroid Build Coastguard Worker // Silence unused variable warnings without evaluating the expressions.
118*03ce13f7SAndroid Build Coastguard Worker #	define ASSERT(expression)                     \
119*03ce13f7SAndroid Build Coastguard Worker 		do                                         \
120*03ce13f7SAndroid Build Coastguard Worker 		{                                          \
121*03ce13f7SAndroid Build Coastguard Worker 			(void)sizeof((int)(bool)(expression)); \
122*03ce13f7SAndroid Build Coastguard Worker 		} while(0)
123*03ce13f7SAndroid Build Coastguard Worker #endif
124*03ce13f7SAndroid Build Coastguard Worker 
125*03ce13f7SAndroid Build Coastguard Worker // A macro to indicate functionality currently unimplemented, for a feature advertised
126*03ce13f7SAndroid Build Coastguard Worker // as supported. Since this is a bug, a bug ID must be provided, in b/### format.
127*03ce13f7SAndroid Build Coastguard Worker // For unimplemented functionality not advertised as supported, use UNSUPPORTED() instead.
128*03ce13f7SAndroid Build Coastguard Worker #undef UNIMPLEMENTED
129*03ce13f7SAndroid Build Coastguard Worker #define UNIMPLEMENTED(format, ...)                   \
130*03ce13f7SAndroid Build Coastguard Worker 	DABORT("UNIMPLEMENTED: " format, ##__VA_ARGS__); \
131*03ce13f7SAndroid Build Coastguard Worker 	static_assert(format[0] == 'b' && format[1] == '/' && format[2] >= '0' && format[2] <= '9', "explanation must start with bug reference in b/### format")
132*03ce13f7SAndroid Build Coastguard Worker 
133*03ce13f7SAndroid Build Coastguard Worker // A macro to indicate unsupported functionality.
134*03ce13f7SAndroid Build Coastguard Worker // This should be called when a Vulkan / SPIR-V feature is attempted to be used,
135*03ce13f7SAndroid Build Coastguard Worker // but is not currently implemented by SwiftShader.
136*03ce13f7SAndroid Build Coastguard Worker // Note that in a well-behaved application these should not be reached as the
137*03ce13f7SAndroid Build Coastguard Worker // application should be respecting the advertised features / limits.
138*03ce13f7SAndroid Build Coastguard Worker #undef UNSUPPORTED
139*03ce13f7SAndroid Build Coastguard Worker #define UNSUPPORTED(format, ...) DABORT("UNSUPPORTED: " format, ##__VA_ARGS__)
140*03ce13f7SAndroid Build Coastguard Worker 
141*03ce13f7SAndroid Build Coastguard Worker // A macro for code which should never be reached, even with misbehaving
142*03ce13f7SAndroid Build Coastguard Worker // applications.
143*03ce13f7SAndroid Build Coastguard Worker #undef UNREACHABLE
144*03ce13f7SAndroid Build Coastguard Worker #define UNREACHABLE(format, ...) DABORT("UNREACHABLE: " format, ##__VA_ARGS__)
145*03ce13f7SAndroid Build Coastguard Worker 
146*03ce13f7SAndroid Build Coastguard Worker // A macro asserting a condition and returning if false.
147*03ce13f7SAndroid Build Coastguard Worker // Note this macro always evaluates the expression and also returns in Release builds.
148*03ce13f7SAndroid Build Coastguard Worker #undef ASSERT_OR_RETURN
149*03ce13f7SAndroid Build Coastguard Worker #if !defined(NDEBUG) || defined(DCHECK_ALWAYS_ON)
150*03ce13f7SAndroid Build Coastguard Worker #	define ASSERT_OR_RETURN(expression) ASSERT(expression)
151*03ce13f7SAndroid Build Coastguard Worker #else
152*03ce13f7SAndroid Build Coastguard Worker #	define ASSERT_OR_RETURN(expression) \
153*03ce13f7SAndroid Build Coastguard Worker 		do                               \
154*03ce13f7SAndroid Build Coastguard Worker 		{                                \
155*03ce13f7SAndroid Build Coastguard Worker 			if(!(expression))            \
156*03ce13f7SAndroid Build Coastguard Worker 			{                            \
157*03ce13f7SAndroid Build Coastguard Worker 				return;                  \
158*03ce13f7SAndroid Build Coastguard Worker 			}                            \
159*03ce13f7SAndroid Build Coastguard Worker 		} while(0)
160*03ce13f7SAndroid Build Coastguard Worker #endif
161*03ce13f7SAndroid Build Coastguard Worker 
162*03ce13f7SAndroid Build Coastguard Worker // A macro to indicate unoptimized code paths.
163*03ce13f7SAndroid Build Coastguard Worker #define UNOPTIMIZED(message, ...)                                                            \
164*03ce13f7SAndroid Build Coastguard Worker 	do                                                                                       \
165*03ce13f7SAndroid Build Coastguard Worker 	{                                                                                        \
166*03ce13f7SAndroid Build Coastguard Worker 		if(false)                                                                            \
167*03ce13f7SAndroid Build Coastguard Worker 		{                                                                                    \
168*03ce13f7SAndroid Build Coastguard Worker 			sw::warn("%s:%d UNOPTIMIZED: " message "\n", __FILE__, __LINE__, ##__VA_ARGS__); \
169*03ce13f7SAndroid Build Coastguard Worker 		}                                                                                    \
170*03ce13f7SAndroid Build Coastguard Worker 	} while(0)
171*03ce13f7SAndroid Build Coastguard Worker 
172*03ce13f7SAndroid Build Coastguard Worker #endif  // Debug_hpp
173