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