| /* |
| * Copyright © 2013 Intel Corporation |
| * |
| * Permission is hereby granted, free of charge, to any person obtaining a |
| * copy of this software and associated documentation files (the "Software"), |
| * to deal in the Software without restriction, including without limitation |
| * the rights to use, copy, modify, merge, publish, distribute, sublicense, |
| * and/or sell copies of the Software, and to permit persons to whom the |
| * Software is furnished to do so, subject to the following conditions: |
| * |
| * The above copyright notice and this permission notice (including the next |
| * paragraph) shall be included in all copies or substantial portions of the |
| * Software. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
| * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
| * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS |
| * IN THE SOFTWARE. |
| * |
| */ |
| |
| #ifndef __IGT_DEBUGFS_H__ |
| #define __IGT_DEBUGFS_H__ |
| |
| #include <stdbool.h> |
| #include <stdint.h> |
| #include <stdio.h> |
| |
| enum pipe; |
| |
| const char *igt_debugfs_mount(void); |
| char *igt_debugfs_path(int device, char *path, int pathlen); |
| |
| int igt_debugfs_dir(int device); |
| int igt_debugfs_connector_dir(int device, char *conn_name, int mode); |
| |
| int igt_debugfs_open(int fd, const char *filename, int mode); |
| void __igt_debugfs_read(int fd, const char *filename, char *buf, int size); |
| int igt_debugfs_simple_read(int dir, const char *filename, char *buf, int size); |
| bool igt_debugfs_search(int fd, const char *filename, const char *substring); |
| |
| /** |
| * igt_debugfs_read: |
| * @filename: name of the debugfs file |
| * @buf: buffer where the contents will be stored, allocated by the caller. |
| * |
| * This is just a convenience wrapper for __igt_debugfs_read. See its |
| * documentation. |
| */ |
| #define igt_debugfs_read(fd, filename, buf) \ |
| __igt_debugfs_read(fd, (filename), (buf), sizeof(buf)) |
| |
| /* |
| * Pipe CRC |
| */ |
| |
| /** |
| * igt_pipe_crc_t: |
| * |
| * Pipe CRC support structure. Needs to be allocated and set up with |
| * igt_pipe_crc_new() for a specific pipe and pipe CRC source value. |
| */ |
| typedef struct _igt_pipe_crc igt_pipe_crc_t; |
| |
| #define DRM_MAX_CRC_NR 10 |
| /** |
| * igt_crc_t: |
| * @frame: frame number of the capture CRC |
| * @n_words: internal field, don't access |
| * @crc: internal field, don't access |
| * |
| * Pipe CRC value. All other members than @frame are private and should not be |
| * inspected by testcases. |
| */ |
| typedef struct { |
| uint32_t frame; |
| bool has_valid_frame; |
| int n_words; |
| uint32_t crc[DRM_MAX_CRC_NR]; |
| } igt_crc_t; |
| |
| /** |
| * intel_pipe_crc_source: |
| * @INTEL_PIPE_CRC_SOURCE_NONE: No source |
| * @INTEL_PIPE_CRC_SOURCE_PLANE1: Plane 1 |
| * @INTEL_PIPE_CRC_SOURCE_PLANE2: Plane 2 |
| * @INTEL_PIPE_CRC_SOURCE_PF: Panel Filter |
| * @INTEL_PIPE_CRC_SOURCE_PIPE: Pipe |
| * @INTEL_PIPE_CRC_SOURCE_TV: TV |
| * @INTEL_PIPE_CRC_SOURCE_DP_B: DisplayPort B |
| * @INTEL_PIPE_CRC_SOURCE_DP_C: DisplayPort C |
| * @INTEL_PIPE_CRC_SOURCE_DP_D: DisplayPort D |
| * @INTEL_PIPE_CRC_SOURCE_AUTO: Automatic source selection |
| * @INTEL_PIPE_CRC_SOURCE_MAX: Number of available sources |
| * |
| * Enumeration of all supported pipe CRC sources. Not all platforms and all |
| * outputs support all of them. Generic tests should just use |
| * INTEL_PIPE_CRC_SOURCE_AUTO. It should always map to an end-of-pipe CRC |
| * suitable for checking planes, cursor, color correction and any other |
| * output-agnostic features. |
| */ |
| enum intel_pipe_crc_source { |
| INTEL_PIPE_CRC_SOURCE_NONE, |
| INTEL_PIPE_CRC_SOURCE_PLANE1, |
| INTEL_PIPE_CRC_SOURCE_PLANE2, |
| INTEL_PIPE_CRC_SOURCE_PF, |
| INTEL_PIPE_CRC_SOURCE_PIPE, |
| INTEL_PIPE_CRC_SOURCE_TV, |
| INTEL_PIPE_CRC_SOURCE_DP_B, |
| INTEL_PIPE_CRC_SOURCE_DP_C, |
| INTEL_PIPE_CRC_SOURCE_DP_D, |
| INTEL_PIPE_CRC_SOURCE_AUTO, |
| INTEL_PIPE_CRC_SOURCE_MAX, |
| }; |
| |
| void igt_assert_crc_equal(const igt_crc_t *a, const igt_crc_t *b); |
| bool igt_check_crc_equal(const igt_crc_t *a, const igt_crc_t *b); |
| char *igt_crc_to_string_extended(igt_crc_t *crc, char delimiter, int crc_size); |
| char *igt_crc_to_string(igt_crc_t *crc); |
| |
| void igt_require_pipe_crc(int fd); |
| igt_pipe_crc_t * |
| igt_pipe_crc_new(int fd, enum pipe pipe, enum intel_pipe_crc_source source); |
| igt_pipe_crc_t * |
| igt_pipe_crc_new_nonblock(int fd, enum pipe pipe, enum intel_pipe_crc_source source); |
| void igt_pipe_crc_free(igt_pipe_crc_t *pipe_crc); |
| void igt_pipe_crc_start(igt_pipe_crc_t *pipe_crc); |
| void igt_pipe_crc_stop(igt_pipe_crc_t *pipe_crc); |
| __attribute__((warn_unused_result)) |
| int igt_pipe_crc_get_crcs(igt_pipe_crc_t *pipe_crc, int n_crcs, |
| igt_crc_t **out_crcs); |
| void igt_pipe_crc_drain(igt_pipe_crc_t *pipe_crc); |
| void igt_pipe_crc_get_single(igt_pipe_crc_t *pipe_crc, igt_crc_t *out_crc); |
| void igt_pipe_crc_get_current(int drm_fd, igt_pipe_crc_t *pipe_crc, igt_crc_t *crc); |
| |
| void igt_pipe_crc_collect_crc(igt_pipe_crc_t *pipe_crc, igt_crc_t *out_crc); |
| |
| void igt_hpd_storm_set_threshold(int fd, unsigned int threshold); |
| void igt_hpd_storm_reset(int fd); |
| bool igt_hpd_storm_detected(int fd); |
| void igt_require_hpd_storm_ctl(int fd); |
| |
| /* |
| * Drop caches |
| */ |
| |
| /** |
| * DROP_UNBOUND: |
| * |
| * Drop all currently unbound gem buffer objects from the cache. |
| */ |
| #define DROP_UNBOUND 0x1 |
| /** |
| * DROP_BOUND: |
| * |
| * Drop all inactive objects which are bound into some gpu address space. |
| */ |
| #define DROP_BOUND 0x2 |
| /** |
| * DROP_RETIRE: |
| * |
| * Wait for all outstanding gpu commands to complete, but do not take any |
| * further actions. |
| */ |
| #define DROP_RETIRE 0x4 |
| /** |
| * DROP_ACTIVE: |
| * |
| * Also drop active objects once retired. |
| */ |
| #define DROP_ACTIVE 0x8 |
| /** |
| * DROP_FREED: |
| * |
| * Also drop freed objects. |
| */ |
| #define DROP_FREED 0x10 |
| /** |
| * DROP_SHRINK_ALL: |
| * |
| * Force all unpinned buffers to be evicted from their GTT and returned to the |
| * system. |
| */ |
| #define DROP_SHRINK_ALL 0x20 |
| /** |
| * DROP_IDLE: |
| * |
| * Flush the driver's idle_worker, releasing internal caches and wakerefs. |
| */ |
| #define DROP_IDLE 0x40 |
| /** |
| * DROP_RESET_ACTIVE: |
| * |
| * Cancel all outstanding requests by forcing a gpu reset |
| */ |
| #define DROP_RESET_ACTIVE 0x80 |
| /** |
| * DROP_RESET_SEQNO: |
| * |
| * Reset the global request seqno counter back to 0 |
| */ |
| #define DROP_RESET_SEQNO 0x100 |
| /** |
| * DROP_ALL: |
| * |
| * All of the above DROP_ flags combined. |
| */ |
| #define DROP_ALL (DROP_UNBOUND | \ |
| DROP_BOUND | \ |
| DROP_SHRINK_ALL | \ |
| DROP_RETIRE | \ |
| DROP_ACTIVE | \ |
| DROP_FREED | \ |
| DROP_IDLE) |
| |
| bool igt_drop_caches_has(int fd, uint64_t val); |
| void igt_drop_caches_set(int fd, uint64_t val); |
| |
| /* |
| * Prefault control |
| */ |
| |
| void igt_disable_prefault(void); |
| void igt_enable_prefault(void); |
| |
| /* |
| * Put the driver into a stable (quiescent) state and get the current number of |
| * gem buffer objects |
| */ |
| int igt_get_stable_obj_count(int driver); |
| void igt_debugfs_dump(int device, const char *filename); |
| |
| #endif /* __IGT_DEBUGFS_H__ */ |