xref: /aosp_15_r20/external/igt-gpu-tools/lib/igt_debugfs.h (revision d83cc019efdc2edc6c4b16e9034a3ceb8d35d77c)
1*d83cc019SAndroid Build Coastguard Worker /*
2*d83cc019SAndroid Build Coastguard Worker  * Copyright © 2013 Intel Corporation
3*d83cc019SAndroid Build Coastguard Worker  *
4*d83cc019SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*d83cc019SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*d83cc019SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*d83cc019SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*d83cc019SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*d83cc019SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*d83cc019SAndroid Build Coastguard Worker  *
11*d83cc019SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*d83cc019SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*d83cc019SAndroid Build Coastguard Worker  * Software.
14*d83cc019SAndroid Build Coastguard Worker  *
15*d83cc019SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*d83cc019SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*d83cc019SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*d83cc019SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*d83cc019SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*d83cc019SAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*d83cc019SAndroid Build Coastguard Worker  * IN THE SOFTWARE.
22*d83cc019SAndroid Build Coastguard Worker  *
23*d83cc019SAndroid Build Coastguard Worker  */
24*d83cc019SAndroid Build Coastguard Worker 
25*d83cc019SAndroid Build Coastguard Worker #ifndef __IGT_DEBUGFS_H__
26*d83cc019SAndroid Build Coastguard Worker #define __IGT_DEBUGFS_H__
27*d83cc019SAndroid Build Coastguard Worker 
28*d83cc019SAndroid Build Coastguard Worker #include <stdbool.h>
29*d83cc019SAndroid Build Coastguard Worker #include <stdint.h>
30*d83cc019SAndroid Build Coastguard Worker #include <stdio.h>
31*d83cc019SAndroid Build Coastguard Worker 
32*d83cc019SAndroid Build Coastguard Worker enum pipe
33*d83cc019SAndroid Build Coastguard Worker #ifdef __cplusplus
34*d83cc019SAndroid Build Coastguard Worker : int
35*d83cc019SAndroid Build Coastguard Worker #endif
36*d83cc019SAndroid Build Coastguard Worker ;
37*d83cc019SAndroid Build Coastguard Worker 
38*d83cc019SAndroid Build Coastguard Worker const char *igt_debugfs_mount(void);
39*d83cc019SAndroid Build Coastguard Worker char *igt_debugfs_path(int device, char *path, int pathlen);
40*d83cc019SAndroid Build Coastguard Worker 
41*d83cc019SAndroid Build Coastguard Worker int igt_debugfs_dir(int device);
42*d83cc019SAndroid Build Coastguard Worker int igt_debugfs_connector_dir(int device, char *conn_name, int mode);
43*d83cc019SAndroid Build Coastguard Worker 
44*d83cc019SAndroid Build Coastguard Worker int igt_debugfs_open(int fd, const char *filename, int mode);
45*d83cc019SAndroid Build Coastguard Worker void __igt_debugfs_read(int fd, const char *filename, char *buf, int size);
46*d83cc019SAndroid Build Coastguard Worker int igt_debugfs_simple_read(int dir, const char *filename, char *buf, int size);
47*d83cc019SAndroid Build Coastguard Worker bool igt_debugfs_search(int fd, const char *filename, const char *substring);
48*d83cc019SAndroid Build Coastguard Worker 
49*d83cc019SAndroid Build Coastguard Worker /**
50*d83cc019SAndroid Build Coastguard Worker  * igt_debugfs_read:
51*d83cc019SAndroid Build Coastguard Worker  * @filename: name of the debugfs file
52*d83cc019SAndroid Build Coastguard Worker  * @buf: buffer where the contents will be stored, allocated by the caller.
53*d83cc019SAndroid Build Coastguard Worker  *
54*d83cc019SAndroid Build Coastguard Worker  * This is just a convenience wrapper for __igt_debugfs_read. See its
55*d83cc019SAndroid Build Coastguard Worker  * documentation.
56*d83cc019SAndroid Build Coastguard Worker  */
57*d83cc019SAndroid Build Coastguard Worker #define igt_debugfs_read(fd, filename, buf) \
58*d83cc019SAndroid Build Coastguard Worker 		__igt_debugfs_read(fd, (filename), (buf), sizeof(buf))
59*d83cc019SAndroid Build Coastguard Worker 
60*d83cc019SAndroid Build Coastguard Worker /*
61*d83cc019SAndroid Build Coastguard Worker  * Pipe CRC
62*d83cc019SAndroid Build Coastguard Worker  */
63*d83cc019SAndroid Build Coastguard Worker 
64*d83cc019SAndroid Build Coastguard Worker /**
65*d83cc019SAndroid Build Coastguard Worker  * igt_pipe_crc_t:
66*d83cc019SAndroid Build Coastguard Worker  *
67*d83cc019SAndroid Build Coastguard Worker  * Pipe CRC support structure. Needs to be allocated and set up with
68*d83cc019SAndroid Build Coastguard Worker  * igt_pipe_crc_new() for a specific pipe and pipe CRC source value.
69*d83cc019SAndroid Build Coastguard Worker  */
70*d83cc019SAndroid Build Coastguard Worker typedef struct _igt_pipe_crc igt_pipe_crc_t;
71*d83cc019SAndroid Build Coastguard Worker 
72*d83cc019SAndroid Build Coastguard Worker #define DRM_MAX_CRC_NR 10
73*d83cc019SAndroid Build Coastguard Worker /**
74*d83cc019SAndroid Build Coastguard Worker  * igt_crc_t:
75*d83cc019SAndroid Build Coastguard Worker  * @frame: frame number of the capture CRC
76*d83cc019SAndroid Build Coastguard Worker  * @n_words: internal field, don't access
77*d83cc019SAndroid Build Coastguard Worker  * @crc: internal field, don't access
78*d83cc019SAndroid Build Coastguard Worker  *
79*d83cc019SAndroid Build Coastguard Worker  * Pipe CRC value. All other members than @frame are private and should not be
80*d83cc019SAndroid Build Coastguard Worker  * inspected by testcases.
81*d83cc019SAndroid Build Coastguard Worker  */
82*d83cc019SAndroid Build Coastguard Worker typedef struct {
83*d83cc019SAndroid Build Coastguard Worker 	uint32_t frame;
84*d83cc019SAndroid Build Coastguard Worker 	bool has_valid_frame;
85*d83cc019SAndroid Build Coastguard Worker 	int n_words;
86*d83cc019SAndroid Build Coastguard Worker 	uint32_t crc[DRM_MAX_CRC_NR];
87*d83cc019SAndroid Build Coastguard Worker } igt_crc_t;
88*d83cc019SAndroid Build Coastguard Worker 
89*d83cc019SAndroid Build Coastguard Worker #define INTEL_PIPE_CRC_SOURCE_AUTO "auto"
90*d83cc019SAndroid Build Coastguard Worker #define AMDGPU_PIPE_CRC_SOURCE_DPRX "dprx"
91*d83cc019SAndroid Build Coastguard Worker 
92*d83cc019SAndroid Build Coastguard Worker void igt_assert_crc_equal(const igt_crc_t *a, const igt_crc_t *b);
93*d83cc019SAndroid Build Coastguard Worker bool igt_check_crc_equal(const igt_crc_t *a, const igt_crc_t *b);
94*d83cc019SAndroid Build Coastguard Worker char *igt_crc_to_string_extended(igt_crc_t *crc, char delimiter, int crc_size);
95*d83cc019SAndroid Build Coastguard Worker char *igt_crc_to_string(igt_crc_t *crc);
96*d83cc019SAndroid Build Coastguard Worker 
97*d83cc019SAndroid Build Coastguard Worker void igt_require_pipe_crc(int fd);
98*d83cc019SAndroid Build Coastguard Worker igt_pipe_crc_t *
99*d83cc019SAndroid Build Coastguard Worker igt_pipe_crc_new(int fd, enum pipe pipe, const char *source);
100*d83cc019SAndroid Build Coastguard Worker igt_pipe_crc_t *
101*d83cc019SAndroid Build Coastguard Worker igt_pipe_crc_new_nonblock(int fd, enum pipe pipe, const char *source);
102*d83cc019SAndroid Build Coastguard Worker void igt_pipe_crc_free(igt_pipe_crc_t *pipe_crc);
103*d83cc019SAndroid Build Coastguard Worker void igt_pipe_crc_start(igt_pipe_crc_t *pipe_crc);
104*d83cc019SAndroid Build Coastguard Worker void igt_pipe_crc_stop(igt_pipe_crc_t *pipe_crc);
105*d83cc019SAndroid Build Coastguard Worker __attribute__((warn_unused_result))
106*d83cc019SAndroid Build Coastguard Worker int igt_pipe_crc_get_crcs(igt_pipe_crc_t *pipe_crc, int n_crcs,
107*d83cc019SAndroid Build Coastguard Worker 			  igt_crc_t **out_crcs);
108*d83cc019SAndroid Build Coastguard Worker void igt_pipe_crc_drain(igt_pipe_crc_t *pipe_crc);
109*d83cc019SAndroid Build Coastguard Worker void igt_pipe_crc_get_single(igt_pipe_crc_t *pipe_crc, igt_crc_t *out_crc);
110*d83cc019SAndroid Build Coastguard Worker void igt_pipe_crc_get_current(int drm_fd, igt_pipe_crc_t *pipe_crc, igt_crc_t *crc);
111*d83cc019SAndroid Build Coastguard Worker 
112*d83cc019SAndroid Build Coastguard Worker void igt_pipe_crc_collect_crc(igt_pipe_crc_t *pipe_crc, igt_crc_t *out_crc);
113*d83cc019SAndroid Build Coastguard Worker 
114*d83cc019SAndroid Build Coastguard Worker void igt_hpd_storm_set_threshold(int fd, unsigned int threshold);
115*d83cc019SAndroid Build Coastguard Worker void igt_hpd_storm_reset(int fd);
116*d83cc019SAndroid Build Coastguard Worker bool igt_hpd_storm_detected(int fd);
117*d83cc019SAndroid Build Coastguard Worker void igt_require_hpd_storm_ctl(int fd);
118*d83cc019SAndroid Build Coastguard Worker 
119*d83cc019SAndroid Build Coastguard Worker /*
120*d83cc019SAndroid Build Coastguard Worker  * Drop caches
121*d83cc019SAndroid Build Coastguard Worker  */
122*d83cc019SAndroid Build Coastguard Worker 
123*d83cc019SAndroid Build Coastguard Worker /**
124*d83cc019SAndroid Build Coastguard Worker  * DROP_UNBOUND:
125*d83cc019SAndroid Build Coastguard Worker  *
126*d83cc019SAndroid Build Coastguard Worker  * Drop all currently unbound gem buffer objects from the cache.
127*d83cc019SAndroid Build Coastguard Worker  */
128*d83cc019SAndroid Build Coastguard Worker #define DROP_UNBOUND 0x1
129*d83cc019SAndroid Build Coastguard Worker /**
130*d83cc019SAndroid Build Coastguard Worker  * DROP_BOUND:
131*d83cc019SAndroid Build Coastguard Worker  *
132*d83cc019SAndroid Build Coastguard Worker  * Drop all inactive objects which are bound into some gpu address space.
133*d83cc019SAndroid Build Coastguard Worker  */
134*d83cc019SAndroid Build Coastguard Worker #define DROP_BOUND 0x2
135*d83cc019SAndroid Build Coastguard Worker /**
136*d83cc019SAndroid Build Coastguard Worker  * DROP_RETIRE:
137*d83cc019SAndroid Build Coastguard Worker  *
138*d83cc019SAndroid Build Coastguard Worker  * Wait for all outstanding gpu commands to complete, but do not take any
139*d83cc019SAndroid Build Coastguard Worker  * further actions.
140*d83cc019SAndroid Build Coastguard Worker  */
141*d83cc019SAndroid Build Coastguard Worker #define DROP_RETIRE 0x4
142*d83cc019SAndroid Build Coastguard Worker /**
143*d83cc019SAndroid Build Coastguard Worker  * DROP_ACTIVE:
144*d83cc019SAndroid Build Coastguard Worker  *
145*d83cc019SAndroid Build Coastguard Worker  * Also drop active objects once retired.
146*d83cc019SAndroid Build Coastguard Worker  */
147*d83cc019SAndroid Build Coastguard Worker #define DROP_ACTIVE 0x8
148*d83cc019SAndroid Build Coastguard Worker /**
149*d83cc019SAndroid Build Coastguard Worker  * DROP_FREED:
150*d83cc019SAndroid Build Coastguard Worker  *
151*d83cc019SAndroid Build Coastguard Worker  * Also drop freed objects.
152*d83cc019SAndroid Build Coastguard Worker  */
153*d83cc019SAndroid Build Coastguard Worker #define DROP_FREED 0x10
154*d83cc019SAndroid Build Coastguard Worker /**
155*d83cc019SAndroid Build Coastguard Worker  * DROP_SHRINK_ALL:
156*d83cc019SAndroid Build Coastguard Worker  *
157*d83cc019SAndroid Build Coastguard Worker  * Force all unpinned buffers to be evicted from their GTT and returned to the
158*d83cc019SAndroid Build Coastguard Worker  * system.
159*d83cc019SAndroid Build Coastguard Worker  */
160*d83cc019SAndroid Build Coastguard Worker #define DROP_SHRINK_ALL 0x20
161*d83cc019SAndroid Build Coastguard Worker /**
162*d83cc019SAndroid Build Coastguard Worker  * DROP_IDLE:
163*d83cc019SAndroid Build Coastguard Worker  *
164*d83cc019SAndroid Build Coastguard Worker  * Flush the driver's idle_worker, releasing internal caches and wakerefs.
165*d83cc019SAndroid Build Coastguard Worker  */
166*d83cc019SAndroid Build Coastguard Worker #define DROP_IDLE 0x40
167*d83cc019SAndroid Build Coastguard Worker /**
168*d83cc019SAndroid Build Coastguard Worker  * DROP_RESET_ACTIVE:
169*d83cc019SAndroid Build Coastguard Worker  *
170*d83cc019SAndroid Build Coastguard Worker  * Cancel all outstanding requests by forcing a gpu reset
171*d83cc019SAndroid Build Coastguard Worker  */
172*d83cc019SAndroid Build Coastguard Worker #define DROP_RESET_ACTIVE 0x80
173*d83cc019SAndroid Build Coastguard Worker /**
174*d83cc019SAndroid Build Coastguard Worker  * DROP_RESET_SEQNO:
175*d83cc019SAndroid Build Coastguard Worker  *
176*d83cc019SAndroid Build Coastguard Worker  * Reset the global request seqno counter back to 0
177*d83cc019SAndroid Build Coastguard Worker  */
178*d83cc019SAndroid Build Coastguard Worker #define DROP_RESET_SEQNO 0x100
179*d83cc019SAndroid Build Coastguard Worker /**
180*d83cc019SAndroid Build Coastguard Worker  * DROP_ALL:
181*d83cc019SAndroid Build Coastguard Worker  *
182*d83cc019SAndroid Build Coastguard Worker  * All of the above DROP_ flags combined.
183*d83cc019SAndroid Build Coastguard Worker  */
184*d83cc019SAndroid Build Coastguard Worker #define DROP_ALL (DROP_UNBOUND | \
185*d83cc019SAndroid Build Coastguard Worker 		  DROP_BOUND | \
186*d83cc019SAndroid Build Coastguard Worker 		  DROP_SHRINK_ALL | \
187*d83cc019SAndroid Build Coastguard Worker 		  DROP_RETIRE | \
188*d83cc019SAndroid Build Coastguard Worker 		  DROP_ACTIVE | \
189*d83cc019SAndroid Build Coastguard Worker 		  DROP_FREED | \
190*d83cc019SAndroid Build Coastguard Worker 		  DROP_IDLE)
191*d83cc019SAndroid Build Coastguard Worker 
192*d83cc019SAndroid Build Coastguard Worker void igt_reset_fifo_underrun_reporting(int drm_fd);
193*d83cc019SAndroid Build Coastguard Worker 
194*d83cc019SAndroid Build Coastguard Worker bool igt_drop_caches_has(int fd, uint64_t val);
195*d83cc019SAndroid Build Coastguard Worker void igt_drop_caches_set(int fd, uint64_t val);
196*d83cc019SAndroid Build Coastguard Worker 
197*d83cc019SAndroid Build Coastguard Worker /*
198*d83cc019SAndroid Build Coastguard Worker  * Prefault control
199*d83cc019SAndroid Build Coastguard Worker  */
200*d83cc019SAndroid Build Coastguard Worker 
201*d83cc019SAndroid Build Coastguard Worker void igt_disable_prefault(void);
202*d83cc019SAndroid Build Coastguard Worker void igt_enable_prefault(void);
203*d83cc019SAndroid Build Coastguard Worker 
204*d83cc019SAndroid Build Coastguard Worker /*
205*d83cc019SAndroid Build Coastguard Worker  * Put the driver into a stable (quiescent) state and get the current number of
206*d83cc019SAndroid Build Coastguard Worker  * gem buffer objects
207*d83cc019SAndroid Build Coastguard Worker  */
208*d83cc019SAndroid Build Coastguard Worker int igt_get_stable_obj_count(int driver);
209*d83cc019SAndroid Build Coastguard Worker void __igt_debugfs_dump(int device, const char *filename, int level);
210*d83cc019SAndroid Build Coastguard Worker #define igt_debugfs_dump(d, f) __igt_debugfs_dump(d, f, IGT_LOG_DEBUG)
211*d83cc019SAndroid Build Coastguard Worker 
212*d83cc019SAndroid Build Coastguard Worker #endif /* __IGT_DEBUGFS_H__ */
213