123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224 |
- /*
- * Copyright(c) 2011-2016 Intel Corporation. All rights reserved.
- *
- * 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:
- * Ke Yu
- * Zhiyuan Lv <[email protected]>
- *
- * Contributors:
- * Terrence Xu <[email protected]>
- * Changbin Du <[email protected]>
- * Bing Niu <[email protected]>
- * Zhi Wang <[email protected]>
- *
- */
- #ifndef _GVT_DISPLAY_H_
- #define _GVT_DISPLAY_H_
- #include <linux/types.h>
- #include <linux/hrtimer.h>
- struct intel_gvt;
- struct intel_vgpu;
- #define SBI_REG_MAX 20
- #define DPCD_SIZE 0x700
- #define intel_vgpu_port(vgpu, port) \
- (&(vgpu->display.ports[port]))
- #define intel_vgpu_has_monitor_on_port(vgpu, port) \
- (intel_vgpu_port(vgpu, port)->edid && \
- intel_vgpu_port(vgpu, port)->edid->data_valid)
- #define intel_vgpu_port_is_dp(vgpu, port) \
- ((intel_vgpu_port(vgpu, port)->type == GVT_DP_A) || \
- (intel_vgpu_port(vgpu, port)->type == GVT_DP_B) || \
- (intel_vgpu_port(vgpu, port)->type == GVT_DP_C) || \
- (intel_vgpu_port(vgpu, port)->type == GVT_DP_D))
- #define INTEL_GVT_MAX_UEVENT_VARS 3
- /* DPCD start */
- #define DPCD_SIZE 0x700
- /* DPCD */
- #define DP_SET_POWER 0x600
- #define DP_SET_POWER_D0 0x1
- #define AUX_NATIVE_WRITE 0x8
- #define AUX_NATIVE_READ 0x9
- #define AUX_NATIVE_REPLY_MASK (0x3 << 4)
- #define AUX_NATIVE_REPLY_ACK (0x0 << 4)
- #define AUX_NATIVE_REPLY_NAK (0x1 << 4)
- #define AUX_NATIVE_REPLY_DEFER (0x2 << 4)
- #define AUX_BURST_SIZE 20
- /* DPCD addresses */
- #define DPCD_REV 0x000
- #define DPCD_MAX_LINK_RATE 0x001
- #define DPCD_MAX_LANE_COUNT 0x002
- #define DPCD_TRAINING_PATTERN_SET 0x102
- #define DPCD_SINK_COUNT 0x200
- #define DPCD_LANE0_1_STATUS 0x202
- #define DPCD_LANE2_3_STATUS 0x203
- #define DPCD_LANE_ALIGN_STATUS_UPDATED 0x204
- #define DPCD_SINK_STATUS 0x205
- /* link training */
- #define DPCD_TRAINING_PATTERN_SET_MASK 0x03
- #define DPCD_LINK_TRAINING_DISABLED 0x00
- #define DPCD_TRAINING_PATTERN_1 0x01
- #define DPCD_TRAINING_PATTERN_2 0x02
- #define DPCD_CP_READY_MASK (1 << 6)
- /* lane status */
- #define DPCD_LANES_CR_DONE 0x11
- #define DPCD_LANES_EQ_DONE 0x22
- #define DPCD_SYMBOL_LOCKED 0x44
- #define DPCD_INTERLANE_ALIGN_DONE 0x01
- #define DPCD_SINK_IN_SYNC 0x03
- /* DPCD end */
- #define SBI_RESPONSE_MASK 0x3
- #define SBI_RESPONSE_SHIFT 0x1
- #define SBI_STAT_MASK 0x1
- #define SBI_STAT_SHIFT 0x0
- #define SBI_OPCODE_SHIFT 8
- #define SBI_OPCODE_MASK (0xff << SBI_OPCODE_SHIFT)
- #define SBI_CMD_IORD 2
- #define SBI_CMD_IOWR 3
- #define SBI_CMD_CRRD 6
- #define SBI_CMD_CRWR 7
- #define SBI_ADDR_OFFSET_SHIFT 16
- #define SBI_ADDR_OFFSET_MASK (0xffff << SBI_ADDR_OFFSET_SHIFT)
- struct intel_vgpu_sbi_register {
- unsigned int offset;
- u32 value;
- };
- struct intel_vgpu_sbi {
- int number;
- struct intel_vgpu_sbi_register registers[SBI_REG_MAX];
- };
- enum intel_gvt_plane_type {
- PRIMARY_PLANE = 0,
- CURSOR_PLANE,
- SPRITE_PLANE,
- MAX_PLANE
- };
- struct intel_vgpu_dpcd_data {
- bool data_valid;
- u8 data[DPCD_SIZE];
- };
- enum intel_vgpu_port_type {
- GVT_CRT = 0,
- GVT_DP_A,
- GVT_DP_B,
- GVT_DP_C,
- GVT_DP_D,
- GVT_HDMI_B,
- GVT_HDMI_C,
- GVT_HDMI_D,
- GVT_PORT_MAX
- };
- enum intel_vgpu_edid {
- GVT_EDID_1024_768,
- GVT_EDID_1920_1200,
- GVT_EDID_NUM,
- };
- #define GVT_DEFAULT_REFRESH_RATE 60
- struct intel_vgpu_port {
- /* per display EDID information */
- struct intel_vgpu_edid_data *edid;
- /* per display DPCD information */
- struct intel_vgpu_dpcd_data *dpcd;
- int type;
- enum intel_vgpu_edid id;
- /* x1000 to get accurate 59.94, 24.976, 29.94, etc. in timing std. */
- u32 vrefresh_k;
- };
- struct intel_vgpu_vblank_timer {
- struct hrtimer timer;
- u32 vrefresh_k;
- u64 period;
- };
- static inline char *vgpu_edid_str(enum intel_vgpu_edid id)
- {
- switch (id) {
- case GVT_EDID_1024_768:
- return "1024x768";
- case GVT_EDID_1920_1200:
- return "1920x1200";
- default:
- return "";
- }
- }
- static inline unsigned int vgpu_edid_xres(enum intel_vgpu_edid id)
- {
- switch (id) {
- case GVT_EDID_1024_768:
- return 1024;
- case GVT_EDID_1920_1200:
- return 1920;
- default:
- return 0;
- }
- }
- static inline unsigned int vgpu_edid_yres(enum intel_vgpu_edid id)
- {
- switch (id) {
- case GVT_EDID_1024_768:
- return 768;
- case GVT_EDID_1920_1200:
- return 1200;
- default:
- return 0;
- }
- }
- void intel_vgpu_emulate_vblank(struct intel_vgpu *vgpu);
- void vgpu_update_vblank_emulation(struct intel_vgpu *vgpu, bool turnon);
- int intel_vgpu_init_display(struct intel_vgpu *vgpu, u64 resolution);
- void intel_vgpu_reset_display(struct intel_vgpu *vgpu);
- void intel_vgpu_clean_display(struct intel_vgpu *vgpu);
- int pipe_is_enabled(struct intel_vgpu *vgpu, int pipe);
- #endif
|