xref: /aosp_15_r20/external/virglrenderer/src/vrend_debug.c (revision bbecb9d118dfdb95f99bd754f8fa9be01f189df3)
1*bbecb9d1SAndroid Build Coastguard Worker /**************************************************************************
2*bbecb9d1SAndroid Build Coastguard Worker  *
3*bbecb9d1SAndroid Build Coastguard Worker  * Copyright (C) 2018 Collabora Ltd
4*bbecb9d1SAndroid Build Coastguard Worker  *
5*bbecb9d1SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
6*bbecb9d1SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
7*bbecb9d1SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
8*bbecb9d1SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9*bbecb9d1SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
10*bbecb9d1SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
11*bbecb9d1SAndroid Build Coastguard Worker  *
12*bbecb9d1SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice shall be included
13*bbecb9d1SAndroid Build Coastguard Worker  * in all copies or substantial portions of the Software.
14*bbecb9d1SAndroid Build Coastguard Worker  *
15*bbecb9d1SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
16*bbecb9d1SAndroid Build Coastguard Worker  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*bbecb9d1SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*bbecb9d1SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
19*bbecb9d1SAndroid Build Coastguard Worker  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
20*bbecb9d1SAndroid Build Coastguard Worker  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
21*bbecb9d1SAndroid Build Coastguard Worker  * OTHER DEALINGS IN THE SOFTWARE.
22*bbecb9d1SAndroid Build Coastguard Worker  *
23*bbecb9d1SAndroid Build Coastguard Worker  **************************************************************************/
24*bbecb9d1SAndroid Build Coastguard Worker 
25*bbecb9d1SAndroid Build Coastguard Worker #include "vrend_debug.h"
26*bbecb9d1SAndroid Build Coastguard Worker #include "vrend_renderer.h"
27*bbecb9d1SAndroid Build Coastguard Worker #include "util/u_debug.h"
28*bbecb9d1SAndroid Build Coastguard Worker #include <stdlib.h>
29*bbecb9d1SAndroid Build Coastguard Worker #include <stdio.h>
30*bbecb9d1SAndroid Build Coastguard Worker 
31*bbecb9d1SAndroid Build Coastguard Worker static const char *command_names[VIRGL_MAX_COMMANDS] = {
32*bbecb9d1SAndroid Build Coastguard Worker    "NOP",
33*bbecb9d1SAndroid Build Coastguard Worker    "CREATE_OBJECT",
34*bbecb9d1SAndroid Build Coastguard Worker    "BIND_OBJECT",
35*bbecb9d1SAndroid Build Coastguard Worker    "DESTROY_OBJECT",
36*bbecb9d1SAndroid Build Coastguard Worker    "SET_VIEWPORT_STATE",
37*bbecb9d1SAndroid Build Coastguard Worker    "SET_FRAMEBUFFER_STATE",
38*bbecb9d1SAndroid Build Coastguard Worker    "SET_VERTEX_BUFFERS",
39*bbecb9d1SAndroid Build Coastguard Worker    "CLEAR",
40*bbecb9d1SAndroid Build Coastguard Worker    "DRAW_VBO",
41*bbecb9d1SAndroid Build Coastguard Worker    "RESOURCE_INLINE_WRITE",
42*bbecb9d1SAndroid Build Coastguard Worker    "SET_SAMPLER_VIEWS",
43*bbecb9d1SAndroid Build Coastguard Worker    "SET_INDEX_BUFFER",
44*bbecb9d1SAndroid Build Coastguard Worker    "SET_CONSTANT_BUFFER",
45*bbecb9d1SAndroid Build Coastguard Worker    "SET_STENCIL_REF",
46*bbecb9d1SAndroid Build Coastguard Worker    "SET_BLEND_COLOR",
47*bbecb9d1SAndroid Build Coastguard Worker    "SET_SCISSOR_STATE",
48*bbecb9d1SAndroid Build Coastguard Worker    "BLIT",
49*bbecb9d1SAndroid Build Coastguard Worker    "RESOURCE_COPY_REGION",
50*bbecb9d1SAndroid Build Coastguard Worker    "BIND_SAMPLER_STATES",
51*bbecb9d1SAndroid Build Coastguard Worker    "BEGIN_QUERY",
52*bbecb9d1SAndroid Build Coastguard Worker    "END_QUERY",
53*bbecb9d1SAndroid Build Coastguard Worker    "GET_QUERY_RESULT",
54*bbecb9d1SAndroid Build Coastguard Worker    "SET_POLYGON_STIPPLE",
55*bbecb9d1SAndroid Build Coastguard Worker    "SET_CLIP_STATE",
56*bbecb9d1SAndroid Build Coastguard Worker    "SET_SAMPLE_MASK",
57*bbecb9d1SAndroid Build Coastguard Worker    "SET_STREAMOUT_TARGETS",
58*bbecb9d1SAndroid Build Coastguard Worker    "SET_RENDER_CONDITION",
59*bbecb9d1SAndroid Build Coastguard Worker    "SET_UNIFORM_BUFFER",
60*bbecb9d1SAndroid Build Coastguard Worker    "SET_SUB_CTX",
61*bbecb9d1SAndroid Build Coastguard Worker    "CREATE_SUB_CTX",
62*bbecb9d1SAndroid Build Coastguard Worker    "DESTROY_SUB_CTX",
63*bbecb9d1SAndroid Build Coastguard Worker    "BIND_SHADER",
64*bbecb9d1SAndroid Build Coastguard Worker    "SET_TESS_STATE",
65*bbecb9d1SAndroid Build Coastguard Worker    "SET_MIN_SAMPLES",
66*bbecb9d1SAndroid Build Coastguard Worker    "SET_SHADER_BUFFERS",
67*bbecb9d1SAndroid Build Coastguard Worker    "SET_SHADER_IMAGES",
68*bbecb9d1SAndroid Build Coastguard Worker    "MEMORY_BARRIER",
69*bbecb9d1SAndroid Build Coastguard Worker    "LAUNCH_GRID",
70*bbecb9d1SAndroid Build Coastguard Worker    "SET_FRAMEBUFFER_STATE_NO_ATTACH",
71*bbecb9d1SAndroid Build Coastguard Worker    "TEXTURE_BARRIER",
72*bbecb9d1SAndroid Build Coastguard Worker    "SET_ATOMIC_BUFFERS",
73*bbecb9d1SAndroid Build Coastguard Worker    "SET_DEBUG_FLAGS",
74*bbecb9d1SAndroid Build Coastguard Worker    "GET_QBO_RESULT",
75*bbecb9d1SAndroid Build Coastguard Worker    "TRANSFER3D",
76*bbecb9d1SAndroid Build Coastguard Worker    "END_TRANSFERS",
77*bbecb9d1SAndroid Build Coastguard Worker    "COPY_TRANSFER3D",
78*bbecb9d1SAndroid Build Coastguard Worker    "TWEAK",
79*bbecb9d1SAndroid Build Coastguard Worker    "CLEAR_TEXTURE",
80*bbecb9d1SAndroid Build Coastguard Worker    "PIPE_RESOURCE_CREATE",
81*bbecb9d1SAndroid Build Coastguard Worker    "PIPE_RESOURCE_SET_TYPE",
82*bbecb9d1SAndroid Build Coastguard Worker    "GET_MEMORY_INFO",
83*bbecb9d1SAndroid Build Coastguard Worker    "SEND_STRING_MARKER",
84*bbecb9d1SAndroid Build Coastguard Worker    "LINK_SHADER",
85*bbecb9d1SAndroid Build Coastguard Worker    "CREATE_VIDEO_CODEC",
86*bbecb9d1SAndroid Build Coastguard Worker    "DESTROY_VIDEO_CODEC",
87*bbecb9d1SAndroid Build Coastguard Worker    "CREATE_VIDEO_BUFFER",
88*bbecb9d1SAndroid Build Coastguard Worker    "DESTROY_VIDEO_BUFFER",
89*bbecb9d1SAndroid Build Coastguard Worker    "BEGIN_FRAME",
90*bbecb9d1SAndroid Build Coastguard Worker    "DECODE_MACROBLOCK",
91*bbecb9d1SAndroid Build Coastguard Worker    "DECODE_BITSTREAM",
92*bbecb9d1SAndroid Build Coastguard Worker    "ENCODE_BITSTREAM",
93*bbecb9d1SAndroid Build Coastguard Worker    "END_FRAME",
94*bbecb9d1SAndroid Build Coastguard Worker };
95*bbecb9d1SAndroid Build Coastguard Worker 
96*bbecb9d1SAndroid Build Coastguard Worker static const char *object_type_names[VIRGL_MAX_OBJECTS] = {
97*bbecb9d1SAndroid Build Coastguard Worker    "NULL",
98*bbecb9d1SAndroid Build Coastguard Worker    "BLEND",
99*bbecb9d1SAndroid Build Coastguard Worker    "RASTERIZER",
100*bbecb9d1SAndroid Build Coastguard Worker    "DSA",
101*bbecb9d1SAndroid Build Coastguard Worker    "SHADER",
102*bbecb9d1SAndroid Build Coastguard Worker    "VERTEX_ELEMENTS",
103*bbecb9d1SAndroid Build Coastguard Worker    "SAMPLER_VIEW",
104*bbecb9d1SAndroid Build Coastguard Worker    "SAMPLER_STATE",
105*bbecb9d1SAndroid Build Coastguard Worker    "SURFACE",
106*bbecb9d1SAndroid Build Coastguard Worker    "QUERY",
107*bbecb9d1SAndroid Build Coastguard Worker    "STREAMOUT_TARGET",
108*bbecb9d1SAndroid Build Coastguard Worker    "MSAA_SURFACE"
109*bbecb9d1SAndroid Build Coastguard Worker };
110*bbecb9d1SAndroid Build Coastguard Worker 
vrend_get_comand_name(enum virgl_context_cmd cmd)111*bbecb9d1SAndroid Build Coastguard Worker const char *vrend_get_comand_name(enum virgl_context_cmd cmd)
112*bbecb9d1SAndroid Build Coastguard Worker {
113*bbecb9d1SAndroid Build Coastguard Worker    if (cmd < VIRGL_MAX_COMMANDS)
114*bbecb9d1SAndroid Build Coastguard Worker       return command_names[cmd];
115*bbecb9d1SAndroid Build Coastguard Worker    return "UNKNOWN";
116*bbecb9d1SAndroid Build Coastguard Worker }
117*bbecb9d1SAndroid Build Coastguard Worker 
vrend_get_object_type_name(enum virgl_object_type obj)118*bbecb9d1SAndroid Build Coastguard Worker extern const char *vrend_get_object_type_name(enum virgl_object_type obj)
119*bbecb9d1SAndroid Build Coastguard Worker {
120*bbecb9d1SAndroid Build Coastguard Worker    if (obj < VIRGL_MAX_OBJECTS)
121*bbecb9d1SAndroid Build Coastguard Worker       return object_type_names[obj];
122*bbecb9d1SAndroid Build Coastguard Worker    return "UNKNOWN";
123*bbecb9d1SAndroid Build Coastguard Worker }
124*bbecb9d1SAndroid Build Coastguard Worker 
125*bbecb9d1SAndroid Build Coastguard Worker static const struct debug_named_value vrend_debug_options[] = {
126*bbecb9d1SAndroid Build Coastguard Worker    {"tgsi", dbg_shader_tgsi, "Print TGSI"},
127*bbecb9d1SAndroid Build Coastguard Worker    {"glsl", dbg_shader_glsl, "Print GLSL shaders created from TGSI"},
128*bbecb9d1SAndroid Build Coastguard Worker    {"shader", dbg_shader, "Print TGSI and created GLSL shaders"},
129*bbecb9d1SAndroid Build Coastguard Worker    {"stream", dbg_shader_streamout, "Print shader streamout"},
130*bbecb9d1SAndroid Build Coastguard Worker    {"cmd", dbg_cmd, "Print incoming commands"},
131*bbecb9d1SAndroid Build Coastguard Worker    {"obj", dbg_object, "Print object creation"},
132*bbecb9d1SAndroid Build Coastguard Worker    {"blit", dbg_blit, "Debug blit code path"},
133*bbecb9d1SAndroid Build Coastguard Worker    {"copyres", dbg_copy_resource, "Debug copy resource code path"},
134*bbecb9d1SAndroid Build Coastguard Worker    {"feat", dbg_features, "Log features found"},
135*bbecb9d1SAndroid Build Coastguard Worker    {"tex", dbg_tex, "Log texture operations"},
136*bbecb9d1SAndroid Build Coastguard Worker    {"caller", dbg_caller, "Log who is creating the context"},
137*bbecb9d1SAndroid Build Coastguard Worker    {"tweak", dbg_tweak, "Log tweaks"},
138*bbecb9d1SAndroid Build Coastguard Worker    {"query", dbg_query, "Log queries"},
139*bbecb9d1SAndroid Build Coastguard Worker    {"gles", dbg_gles, "GLES host specific debug"},
140*bbecb9d1SAndroid Build Coastguard Worker    {"bgra", dbg_bgra, "Debug specific to BGRA emulation on GLES hosts"},
141*bbecb9d1SAndroid Build Coastguard Worker    {"all", dbg_all, "Enable all debugging output"},
142*bbecb9d1SAndroid Build Coastguard Worker    {"guestallow", dbg_allow_guest_override, "Allow the guest to override the debug flags"},
143*bbecb9d1SAndroid Build Coastguard Worker    {"khr", dbg_khr, "Enable debug via KHR_debug extension"},
144*bbecb9d1SAndroid Build Coastguard Worker    DEBUG_NAMED_VALUE_END
145*bbecb9d1SAndroid Build Coastguard Worker };
146*bbecb9d1SAndroid Build Coastguard Worker 
147*bbecb9d1SAndroid Build Coastguard Worker static uint64_t vrend_debug_flags = 0;
148*bbecb9d1SAndroid Build Coastguard Worker static int vrend_debug_flags_initalized = 0;
149*bbecb9d1SAndroid Build Coastguard Worker 
vrend_get_debug_flags(const char * flagstring)150*bbecb9d1SAndroid Build Coastguard Worker int vrend_get_debug_flags(const char *flagstring)
151*bbecb9d1SAndroid Build Coastguard Worker {
152*bbecb9d1SAndroid Build Coastguard Worker    int retval;
153*bbecb9d1SAndroid Build Coastguard Worker    char buf[1024] = "";
154*bbecb9d1SAndroid Build Coastguard Worker 
155*bbecb9d1SAndroid Build Coastguard Worker    /* Unfortunately the available function to scan the flags take the string
156*bbecb9d1SAndroid Build Coastguard Worker     * from the environment. The alternative to using setenv would be to
157*bbecb9d1SAndroid Build Coastguard Worker     * duplicate code or to change the gallium/util intefaces and diverge more
158*bbecb9d1SAndroid Build Coastguard Worker     * from mesa. So just stick to the environment variable. */
159*bbecb9d1SAndroid Build Coastguard Worker    snprintf(buf, 1024, "VREND_TEMP_DEBUG_STRING_%d", getpid());
160*bbecb9d1SAndroid Build Coastguard Worker    setenv(buf, flagstring, 1);
161*bbecb9d1SAndroid Build Coastguard Worker 
162*bbecb9d1SAndroid Build Coastguard Worker    retval = (int)debug_get_flags_option(buf,
163*bbecb9d1SAndroid Build Coastguard Worker                                         vrend_debug_options, 0);
164*bbecb9d1SAndroid Build Coastguard Worker    unsetenv(buf);
165*bbecb9d1SAndroid Build Coastguard Worker    return retval;
166*bbecb9d1SAndroid Build Coastguard Worker }
167*bbecb9d1SAndroid Build Coastguard Worker 
vrend_init_debug_flags(void)168*bbecb9d1SAndroid Build Coastguard Worker void vrend_init_debug_flags(void)
169*bbecb9d1SAndroid Build Coastguard Worker {
170*bbecb9d1SAndroid Build Coastguard Worker    if (!vrend_debug_flags_initalized)  {
171*bbecb9d1SAndroid Build Coastguard Worker       vrend_debug_flags_initalized = 1;
172*bbecb9d1SAndroid Build Coastguard Worker       vrend_debug_flags = debug_get_flags_option("VREND_DEBUG",
173*bbecb9d1SAndroid Build Coastguard Worker                                                  vrend_debug_options, 0);
174*bbecb9d1SAndroid Build Coastguard Worker    }
175*bbecb9d1SAndroid Build Coastguard Worker }
176*bbecb9d1SAndroid Build Coastguard Worker 
vrend_debug(const struct vrend_context * ctx,enum virgl_debug_flags flag)177*bbecb9d1SAndroid Build Coastguard Worker unsigned vrend_debug(const struct vrend_context *ctx, enum virgl_debug_flags flag)
178*bbecb9d1SAndroid Build Coastguard Worker {
179*bbecb9d1SAndroid Build Coastguard Worker    return (vrend_debug_flags & flag) || vrend_context_has_debug_flag(ctx, flag);
180*bbecb9d1SAndroid Build Coastguard Worker }
181*bbecb9d1SAndroid Build Coastguard Worker 
vrend_debug_add_flag(enum virgl_debug_flags flag)182*bbecb9d1SAndroid Build Coastguard Worker void vrend_debug_add_flag(enum virgl_debug_flags flag)
183*bbecb9d1SAndroid Build Coastguard Worker {
184*bbecb9d1SAndroid Build Coastguard Worker    vrend_debug_flags |= flag;
185*bbecb9d1SAndroid Build Coastguard Worker }
186*bbecb9d1SAndroid Build Coastguard Worker 
vrend_debug_can_override(void)187*bbecb9d1SAndroid Build Coastguard Worker int  vrend_debug_can_override(void)
188*bbecb9d1SAndroid Build Coastguard Worker {
189*bbecb9d1SAndroid Build Coastguard Worker    return vrend_debug_flags & dbg_allow_guest_override;
190*bbecb9d1SAndroid Build Coastguard Worker }
191