mirror of
https://github.com/tiagovignatti/intel-gpu-tools.git
synced 2025-06-07 16:06:25 +00:00
Fixup some fallout from the connector probing changes so testdisplay -m will pick up newly hotplugged displays correctly. Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org.
297 lines
8.6 KiB
C
297 lines
8.6 KiB
C
/*
|
|
* 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.
|
|
*
|
|
* Authors:
|
|
* Daniel Vetter <daniel.vetter@ffwll.ch>
|
|
* Damien Lespiau <damien.lespiau@intel.com>
|
|
*/
|
|
|
|
#ifndef __IGT_KMS_H__
|
|
#define __IGT_KMS_H__
|
|
|
|
#include <stdbool.h>
|
|
#include <stdint.h>
|
|
#include <stddef.h>
|
|
|
|
#include <xf86drmMode.h>
|
|
|
|
#include "igt_fb.h"
|
|
#include "ioctl_wrappers.h"
|
|
|
|
/* Low-level helpers with kmstest_ prefix */
|
|
|
|
enum pipe {
|
|
PIPE_ANY = -1,
|
|
PIPE_A = 0,
|
|
PIPE_B,
|
|
PIPE_C,
|
|
I915_MAX_PIPES
|
|
};
|
|
const char *kmstest_pipe_name(enum pipe pipe);
|
|
|
|
/* We namespace this enum to not conflict with the Android i915_drm.h */
|
|
enum igt_plane {
|
|
IGT_PLANE_1 = 0,
|
|
IGT_PLANE_PRIMARY = IGT_PLANE_1,
|
|
IGT_PLANE_2,
|
|
IGT_PLANE_3,
|
|
IGT_PLANE_CURSOR,
|
|
};
|
|
|
|
const char *kmstest_plane_name(enum igt_plane plane);
|
|
|
|
enum port {
|
|
PORT_A = 0,
|
|
PORT_B,
|
|
PORT_C,
|
|
PORT_D,
|
|
PORT_E,
|
|
I915_MAX_PORTS
|
|
};
|
|
|
|
/**
|
|
* kmstest_port_name:
|
|
* @port: display plane
|
|
*
|
|
* Returns: String representing @port, e.g. "A".
|
|
*/
|
|
#define kmstest_port_name(port) ((port) + 'A')
|
|
|
|
/**
|
|
* kmstest_encoder_type_str:
|
|
* @type: DRM_MODE_ENCODER_* enumeration value
|
|
*
|
|
* Returns: A string representing the drm encoder @type.
|
|
*/
|
|
const char *kmstest_encoder_type_str(int type);
|
|
|
|
/**
|
|
* kmstest_connector_status_str:
|
|
* @status: DRM_MODE_* connector status value
|
|
*
|
|
* Returns: A string representing the drm connector status @status.
|
|
*/
|
|
const char *kmstest_connector_status_str(int status);
|
|
|
|
/**
|
|
* kmstest_connector_type_str:
|
|
* @type: DRM_MODE_CONNECTOR_* enumeration value
|
|
*
|
|
* Returns: A string representing the drm connector @type.
|
|
*/
|
|
const char *kmstest_connector_type_str(int type);
|
|
|
|
void kmstest_dump_mode(drmModeModeInfo *mode);
|
|
|
|
int kmstest_get_pipe_from_crtc_id(int fd, int crtc_id);
|
|
void kmstest_set_vt_graphics_mode(void);
|
|
void kmstest_restore_vt_mode(void);
|
|
|
|
struct kmstest_connector_config {
|
|
drmModeCrtc *crtc;
|
|
drmModeConnector *connector;
|
|
drmModeEncoder *encoder;
|
|
drmModeModeInfo default_mode;
|
|
int crtc_idx;
|
|
int pipe;
|
|
};
|
|
|
|
/**
|
|
* kmstest_force_connector_state:
|
|
* @FORCE_CONNECTOR_UNSPECIFIED: Unspecified
|
|
* @FORCE_CONNECTOR_ON: On
|
|
* @FORCE_CONNECTOR_DIGITAL: Digital
|
|
* @FORCE_CONNECTOR_OFF: Off
|
|
*/
|
|
enum kmstest_force_connector_state {
|
|
FORCE_CONNECTOR_UNSPECIFIED,
|
|
FORCE_CONNECTOR_ON,
|
|
FORCE_CONNECTOR_DIGITAL,
|
|
FORCE_CONNECTOR_OFF
|
|
};
|
|
|
|
bool kmstest_force_connector(int fd, drmModeConnector *connector,
|
|
enum kmstest_force_connector_state state);
|
|
void kmstest_edid_add_3d(const unsigned char *edid, size_t length, unsigned char *new_edid_ptr[], size_t *new_length);
|
|
void kmstest_force_edid(int drm_fd, drmModeConnector *connector,
|
|
const unsigned char *edid, size_t length);
|
|
|
|
bool kmstest_get_connector_default_mode(int drm_fd, drmModeConnector *connector,
|
|
drmModeModeInfo *mode);
|
|
bool kmstest_get_connector_config(int drm_fd, uint32_t connector_id,
|
|
unsigned long crtc_idx_mask,
|
|
struct kmstest_connector_config *config);
|
|
bool kmstest_probe_connector_config(int drm_fd, uint32_t connector_id,
|
|
unsigned long crtc_idx_mask,
|
|
struct kmstest_connector_config *config);
|
|
void kmstest_free_connector_config(struct kmstest_connector_config *config);
|
|
|
|
void kmstest_set_connector_dpms(int fd, drmModeConnector *connector, int mode);
|
|
bool kmstest_get_property(int drm_fd, uint32_t object_id, uint32_t object_type,
|
|
const char *name, uint32_t *prop_id, uint64_t *value,
|
|
drmModePropertyPtr *prop);
|
|
void kmstest_unset_all_crtcs(int drm_fd, drmModeResPtr resources);
|
|
|
|
/*
|
|
* A small modeset API
|
|
*/
|
|
|
|
/* High-level kms api with igt_ prefix */
|
|
enum igt_commit_style {
|
|
COMMIT_LEGACY = 0,
|
|
COMMIT_UNIVERSAL,
|
|
/* We'll add atomic here eventually. */
|
|
};
|
|
|
|
typedef struct igt_display igt_display_t;
|
|
typedef struct igt_pipe igt_pipe_t;
|
|
typedef uint32_t igt_fixed_t; /* 16.16 fixed point */
|
|
|
|
typedef enum {
|
|
/* this maps to the kernel API */
|
|
IGT_ROTATION_0 = 1 << 0,
|
|
IGT_ROTATION_90 = 1 << 1,
|
|
IGT_ROTATION_180 = 1 << 2,
|
|
IGT_ROTATION_270 = 1 << 3,
|
|
} igt_rotation_t;
|
|
|
|
typedef struct {
|
|
/*< private >*/
|
|
igt_pipe_t *pipe;
|
|
int index;
|
|
/* capabilities */
|
|
unsigned int is_primary : 1;
|
|
unsigned int is_cursor : 1;
|
|
/* state tracking */
|
|
unsigned int fb_changed : 1;
|
|
unsigned int position_changed : 1;
|
|
unsigned int panning_changed : 1;
|
|
unsigned int rotation_changed : 1;
|
|
unsigned int size_changed : 1;
|
|
/*
|
|
* drm_plane can be NULL for primary and cursor planes (when not
|
|
* using the atomic modeset API)
|
|
*/
|
|
drmModePlane *drm_plane;
|
|
struct igt_fb *fb;
|
|
|
|
uint32_t rotation_property;
|
|
|
|
/* position within pipe_src_w x pipe_src_h */
|
|
int crtc_x, crtc_y;
|
|
/* size within pipe_src_w x pipe_src_h */
|
|
int crtc_w, crtc_h;
|
|
/* panning offset within the fb */
|
|
unsigned int pan_x, pan_y;
|
|
igt_rotation_t rotation;
|
|
} igt_plane_t;
|
|
|
|
struct igt_pipe {
|
|
igt_display_t *display;
|
|
enum pipe pipe;
|
|
bool enabled;
|
|
#define IGT_MAX_PLANES 4
|
|
int n_planes;
|
|
igt_plane_t planes[IGT_MAX_PLANES];
|
|
uint64_t background; /* Background color MSB BGR 16bpc LSB */
|
|
uint32_t background_changed : 1;
|
|
uint32_t background_property;
|
|
};
|
|
|
|
typedef struct {
|
|
/*< private >*/
|
|
igt_display_t *display;
|
|
uint32_t id; /* KMS id */
|
|
struct kmstest_connector_config config;
|
|
char *name;
|
|
bool valid;
|
|
unsigned long pending_crtc_idx_mask;
|
|
bool use_override_mode;
|
|
drmModeModeInfo override_mode;
|
|
} igt_output_t;
|
|
|
|
struct igt_display {
|
|
int drm_fd;
|
|
int log_shift;
|
|
int n_pipes;
|
|
int n_outputs;
|
|
unsigned long pipes_in_use;
|
|
igt_output_t *outputs;
|
|
igt_pipe_t pipes[I915_MAX_PIPES];
|
|
bool has_universal_planes;
|
|
};
|
|
|
|
void igt_display_init(igt_display_t *display, int drm_fd);
|
|
void igt_display_fini(igt_display_t *display);
|
|
int igt_display_commit2(igt_display_t *display, enum igt_commit_style s);
|
|
int igt_display_commit(igt_display_t *display);
|
|
int igt_display_try_commit2(igt_display_t *display, enum igt_commit_style s);
|
|
int igt_display_get_n_pipes(igt_display_t *display);
|
|
|
|
const char *igt_output_name(igt_output_t *output);
|
|
drmModeModeInfo *igt_output_get_mode(igt_output_t *output);
|
|
void igt_output_override_mode(igt_output_t *output, drmModeModeInfo *mode);
|
|
void igt_output_set_pipe(igt_output_t *output, enum pipe pipe);
|
|
igt_plane_t *igt_output_get_plane(igt_output_t *output, enum igt_plane plane);
|
|
|
|
static inline bool igt_plane_supports_rotation(igt_plane_t *plane)
|
|
{
|
|
return plane->rotation_property != 0;
|
|
}
|
|
|
|
void igt_plane_set_fb(igt_plane_t *plane, struct igt_fb *fb);
|
|
void igt_plane_set_position(igt_plane_t *plane, int x, int y);
|
|
void igt_plane_set_size(igt_plane_t *plane, int w, int h);
|
|
void igt_plane_set_panning(igt_plane_t *plane, int x, int y);
|
|
void igt_plane_set_rotation(igt_plane_t *plane, igt_rotation_t rotation);
|
|
void igt_crtc_set_background(igt_pipe_t *pipe, uint64_t background);
|
|
void igt_fb_set_position(struct igt_fb *fb, igt_plane_t *plane,
|
|
uint32_t x, uint32_t y);
|
|
void igt_fb_set_size(struct igt_fb *fb, igt_plane_t *plane,
|
|
uint32_t w, uint32_t h);
|
|
|
|
void igt_wait_for_vblank(int drm_fd, enum pipe pipe);
|
|
|
|
#define for_each_connected_output(display, output) \
|
|
for (int i__ = 0; i__ < (display)->n_outputs; i__++) \
|
|
if ((output = &(display)->outputs[i__]), output->valid)
|
|
|
|
#define for_each_pipe(display, pipe) \
|
|
for (pipe = 0; pipe < igt_display_get_n_pipes(display); pipe++) \
|
|
|
|
#define for_each_plane_on_pipe(display, pipe, plane) \
|
|
for (int i__ = 0; (plane) = &(display)->pipes[(pipe)].planes[i__], \
|
|
i__ < (display)->pipes[(pipe)].n_planes; i__++)
|
|
|
|
#define IGT_FIXED(i,f) ((i) << 16 | (f))
|
|
|
|
void igt_enable_connectors(void);
|
|
void igt_reset_connectors(void);
|
|
|
|
#define EDID_LENGTH 128
|
|
const unsigned char* igt_kms_get_base_edid(void);
|
|
const unsigned char* igt_kms_get_alt_edid(void);
|
|
|
|
|
|
#endif /* __IGT_KMS_H__ */
|
|
|