1 /*
2 * Copyright(c) 2011-2016 Intel Corporation. All rights reserved.
3 *
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
10 *
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
13 * Software.
14 *
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 * SOFTWARE.
22 *
23 * Authors:
24 * Ke Yu
25 * Zhiyuan Lv <zhiyuan.lv@intel.com>
26 *
27 * Contributors:
28 * Terrence Xu <terrence.xu@intel.com>
29 * Changbin Du <changbin.du@intel.com>
30 * Bing Niu <bing.niu@intel.com>
31 * Zhi Wang <zhi.a.wang@intel.com>
32 *
33 */
34
35 #include "i915_drv.h"
36 #include "i915_reg.h"
37 #include "gvt.h"
38
39 #include "display/intel_display.h"
40 #include "display/intel_dpio_phy.h"
41
get_edp_pipe(struct intel_vgpu * vgpu)42 static int get_edp_pipe(struct intel_vgpu *vgpu)
43 {
44 u32 data = vgpu_vreg(vgpu, _TRANS_DDI_FUNC_CTL_EDP);
45 int pipe = -1;
46
47 switch (data & TRANS_DDI_EDP_INPUT_MASK) {
48 case TRANS_DDI_EDP_INPUT_A_ON:
49 case TRANS_DDI_EDP_INPUT_A_ONOFF:
50 pipe = PIPE_A;
51 break;
52 case TRANS_DDI_EDP_INPUT_B_ONOFF:
53 pipe = PIPE_B;
54 break;
55 case TRANS_DDI_EDP_INPUT_C_ONOFF:
56 pipe = PIPE_C;
57 break;
58 }
59 return pipe;
60 }
61
edp_pipe_is_enabled(struct intel_vgpu * vgpu)62 static int edp_pipe_is_enabled(struct intel_vgpu *vgpu)
63 {
64 struct drm_i915_private *dev_priv = vgpu->gvt->gt->i915;
65
66 if (!(vgpu_vreg_t(vgpu, TRANSCONF(TRANSCODER_EDP)) & TRANSCONF_ENABLE))
67 return 0;
68
69 if (!(vgpu_vreg(vgpu, _TRANS_DDI_FUNC_CTL_EDP) & TRANS_DDI_FUNC_ENABLE))
70 return 0;
71 return 1;
72 }
73
pipe_is_enabled(struct intel_vgpu * vgpu,int pipe)74 int pipe_is_enabled(struct intel_vgpu *vgpu, int pipe)
75 {
76 struct drm_i915_private *dev_priv = vgpu->gvt->gt->i915;
77
78 if (drm_WARN_ON(&dev_priv->drm,
79 pipe < PIPE_A || pipe >= I915_MAX_PIPES))
80 return -EINVAL;
81
82 if (vgpu_vreg_t(vgpu, TRANSCONF(pipe)) & TRANSCONF_ENABLE)
83 return 1;
84
85 if (edp_pipe_is_enabled(vgpu) &&
86 get_edp_pipe(vgpu) == pipe)
87 return 1;
88 return 0;
89 }
90
91 static unsigned char virtual_dp_monitor_edid[GVT_EDID_NUM][EDID_SIZE] = {
92 {
93 /* EDID with 1024x768 as its resolution */
94 /*Header*/
95 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00,
96 /* Vendor & Product Identification */
97 0x22, 0xf0, 0x54, 0x29, 0x00, 0x00, 0x00, 0x00, 0x04, 0x17,
98 /* Version & Revision */
99 0x01, 0x04,
100 /* Basic Display Parameters & Features */
101 0xa5, 0x34, 0x20, 0x78, 0x23,
102 /* Color Characteristics */
103 0xfc, 0x81, 0xa4, 0x55, 0x4d, 0x9d, 0x25, 0x12, 0x50, 0x54,
104 /* Established Timings: maximum resolution is 1024x768 */
105 0x21, 0x08, 0x00,
106 /* Standard Timings. All invalid */
107 0x00, 0xc0, 0x00, 0xc0, 0x00, 0x40, 0x00, 0x80, 0x00, 0x00,
108 0x00, 0x40, 0x00, 0x00, 0x00, 0x01,
109 /* 18 Byte Data Blocks 1: invalid */
110 0x00, 0x00, 0x80, 0xa0, 0x70, 0xb0,
111 0x23, 0x40, 0x30, 0x20, 0x36, 0x00, 0x06, 0x44, 0x21, 0x00, 0x00, 0x1a,
112 /* 18 Byte Data Blocks 2: invalid */
113 0x00, 0x00, 0x00, 0xfd, 0x00, 0x18, 0x3c, 0x18, 0x50, 0x11, 0x00, 0x0a,
114 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
115 /* 18 Byte Data Blocks 3: invalid */
116 0x00, 0x00, 0x00, 0xfc, 0x00, 0x48,
117 0x50, 0x20, 0x5a, 0x52, 0x32, 0x34, 0x34, 0x30, 0x77, 0x0a, 0x20, 0x20,
118 /* 18 Byte Data Blocks 4: invalid */
119 0x00, 0x00, 0x00, 0xff, 0x00, 0x43, 0x4e, 0x34, 0x33, 0x30, 0x34, 0x30,
120 0x44, 0x58, 0x51, 0x0a, 0x20, 0x20,
121 /* Extension Block Count */
122 0x00,
123 /* Checksum */
124 0xef,
125 },
126 {
127 /* EDID with 1920x1200 as its resolution */
128 /*Header*/
129 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00,
130 /* Vendor & Product Identification */
131 0x22, 0xf0, 0x54, 0x29, 0x00, 0x00, 0x00, 0x00, 0x04, 0x17,
132 /* Version & Revision */
133 0x01, 0x04,
134 /* Basic Display Parameters & Features */
135 0xa5, 0x34, 0x20, 0x78, 0x23,
136 /* Color Characteristics */
137 0xfc, 0x81, 0xa4, 0x55, 0x4d, 0x9d, 0x25, 0x12, 0x50, 0x54,
138 /* Established Timings: maximum resolution is 1024x768 */
139 0x21, 0x08, 0x00,
140 /*
141 * Standard Timings.
142 * below new resolutions can be supported:
143 * 1920x1080, 1280x720, 1280x960, 1280x1024,
144 * 1440x900, 1600x1200, 1680x1050
145 */
146 0xd1, 0xc0, 0x81, 0xc0, 0x81, 0x40, 0x81, 0x80, 0x95, 0x00,
147 0xa9, 0x40, 0xb3, 0x00, 0x01, 0x01,
148 /* 18 Byte Data Blocks 1: max resolution is 1920x1200 */
149 0x28, 0x3c, 0x80, 0xa0, 0x70, 0xb0,
150 0x23, 0x40, 0x30, 0x20, 0x36, 0x00, 0x06, 0x44, 0x21, 0x00, 0x00, 0x1a,
151 /* 18 Byte Data Blocks 2: invalid */
152 0x00, 0x00, 0x00, 0xfd, 0x00, 0x18, 0x3c, 0x18, 0x50, 0x11, 0x00, 0x0a,
153 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
154 /* 18 Byte Data Blocks 3: invalid */
155 0x00, 0x00, 0x00, 0xfc, 0x00, 0x48,
156 0x50, 0x20, 0x5a, 0x52, 0x32, 0x34, 0x34, 0x30, 0x77, 0x0a, 0x20, 0x20,
157 /* 18 Byte Data Blocks 4: invalid */
158 0x00, 0x00, 0x00, 0xff, 0x00, 0x43, 0x4e, 0x34, 0x33, 0x30, 0x34, 0x30,
159 0x44, 0x58, 0x51, 0x0a, 0x20, 0x20,
160 /* Extension Block Count */
161 0x00,
162 /* Checksum */
163 0x45,
164 },
165 };
166
167 #define DPCD_HEADER_SIZE 0xb
168
169 /* let the virtual display supports DP1.2 */
170 static u8 dpcd_fix_data[DPCD_HEADER_SIZE] = {
171 0x12, 0x014, 0x84, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
172 };
173
emulate_monitor_status_change(struct intel_vgpu * vgpu)174 static void emulate_monitor_status_change(struct intel_vgpu *vgpu)
175 {
176 struct drm_i915_private *dev_priv = vgpu->gvt->gt->i915;
177 int pipe;
178
179 if (IS_BROXTON(dev_priv)) {
180 enum transcoder trans;
181 enum port port;
182
183 /* Clear PIPE, DDI, PHY, HPD before setting new */
184 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) &=
185 ~(GEN8_DE_PORT_HOTPLUG(HPD_PORT_A) |
186 GEN8_DE_PORT_HOTPLUG(HPD_PORT_B) |
187 GEN8_DE_PORT_HOTPLUG(HPD_PORT_C));
188
189 for_each_pipe(dev_priv, pipe) {
190 vgpu_vreg_t(vgpu, TRANSCONF(pipe)) &=
191 ~(TRANSCONF_ENABLE | TRANSCONF_STATE_ENABLE);
192 vgpu_vreg_t(vgpu, DSPCNTR(pipe)) &= ~DISP_ENABLE;
193 vgpu_vreg_t(vgpu, SPRCTL(pipe)) &= ~SPRITE_ENABLE;
194 vgpu_vreg_t(vgpu, CURCNTR(pipe)) &= ~MCURSOR_MODE_MASK;
195 vgpu_vreg_t(vgpu, CURCNTR(pipe)) |= MCURSOR_MODE_DISABLE;
196 }
197
198 for (trans = TRANSCODER_A; trans <= TRANSCODER_EDP; trans++) {
199 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(trans)) &=
200 ~(TRANS_DDI_BPC_MASK | TRANS_DDI_MODE_SELECT_MASK |
201 TRANS_DDI_PORT_MASK | TRANS_DDI_FUNC_ENABLE);
202 }
203 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) &=
204 ~(TRANS_DDI_BPC_MASK | TRANS_DDI_MODE_SELECT_MASK |
205 TRANS_DDI_PORT_MASK);
206
207 for (port = PORT_A; port <= PORT_C; port++) {
208 vgpu_vreg_t(vgpu, BXT_PHY_CTL(port)) &=
209 ~BXT_PHY_LANE_ENABLED;
210 vgpu_vreg_t(vgpu, BXT_PHY_CTL(port)) |=
211 (BXT_PHY_CMNLANE_POWERDOWN_ACK |
212 BXT_PHY_LANE_POWERDOWN_ACK);
213
214 vgpu_vreg_t(vgpu, BXT_PORT_PLL_ENABLE(port)) &=
215 ~(PORT_PLL_POWER_STATE | PORT_PLL_POWER_ENABLE |
216 PORT_PLL_REF_SEL | PORT_PLL_LOCK |
217 PORT_PLL_ENABLE);
218
219 vgpu_vreg_t(vgpu, DDI_BUF_CTL(port)) &=
220 ~(DDI_INIT_DISPLAY_DETECTED |
221 DDI_BUF_CTL_ENABLE);
222 vgpu_vreg_t(vgpu, DDI_BUF_CTL(port)) |= DDI_BUF_IS_IDLE;
223 }
224 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) &=
225 ~(PORTA_HOTPLUG_ENABLE | PORTA_HOTPLUG_STATUS_MASK);
226 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) &=
227 ~(PORTB_HOTPLUG_ENABLE | PORTB_HOTPLUG_STATUS_MASK);
228 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) &=
229 ~(PORTC_HOTPLUG_ENABLE | PORTC_HOTPLUG_STATUS_MASK);
230 /* No hpd_invert set in vgpu vbt, need to clear invert mask */
231 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) &= ~BXT_DDI_HPD_INVERT_MASK;
232 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) &= ~BXT_DE_PORT_HOTPLUG_MASK;
233
234 vgpu_vreg_t(vgpu, BXT_P_CR_GT_DISP_PWRON) &= ~(BIT(0) | BIT(1));
235 vgpu_vreg_t(vgpu, BXT_PORT_CL1CM_DW0(DPIO_PHY0)) &=
236 ~PHY_POWER_GOOD;
237 vgpu_vreg_t(vgpu, BXT_PORT_CL1CM_DW0(DPIO_PHY1)) &=
238 ~PHY_POWER_GOOD;
239 vgpu_vreg_t(vgpu, BXT_PHY_CTL_FAMILY(DPIO_PHY0)) &= ~BIT(30);
240 vgpu_vreg_t(vgpu, BXT_PHY_CTL_FAMILY(DPIO_PHY1)) &= ~BIT(30);
241
242 vgpu_vreg_t(vgpu, SFUSE_STRAP) &= ~SFUSE_STRAP_DDIB_DETECTED;
243 vgpu_vreg_t(vgpu, SFUSE_STRAP) &= ~SFUSE_STRAP_DDIC_DETECTED;
244
245 /*
246 * Only 1 PIPE enabled in current vGPU display and PIPE_A is
247 * tied to TRANSCODER_A in HW, so it's safe to assume PIPE_A,
248 * TRANSCODER_A can be enabled. PORT_x depends on the input of
249 * setup_virtual_dp_monitor.
250 */
251 vgpu_vreg_t(vgpu, TRANSCONF(TRANSCODER_A)) |= TRANSCONF_ENABLE;
252 vgpu_vreg_t(vgpu, TRANSCONF(TRANSCODER_A)) |= TRANSCONF_STATE_ENABLE;
253
254 /*
255 * Golden M/N are calculated based on:
256 * 24 bpp, 4 lanes, 154000 pixel clk (from virtual EDID),
257 * DP link clk 1620 MHz and non-constant_n.
258 * TODO: calculate DP link symbol clk and stream clk m/n.
259 */
260 vgpu_vreg_t(vgpu, PIPE_DATA_M1(TRANSCODER_A)) = TU_SIZE(64);
261 vgpu_vreg_t(vgpu, PIPE_DATA_M1(TRANSCODER_A)) |= 0x5b425e;
262 vgpu_vreg_t(vgpu, PIPE_DATA_N1(TRANSCODER_A)) = 0x800000;
263 vgpu_vreg_t(vgpu, PIPE_LINK_M1(TRANSCODER_A)) = 0x3cd6e;
264 vgpu_vreg_t(vgpu, PIPE_LINK_N1(TRANSCODER_A)) = 0x80000;
265
266 /* Enable per-DDI/PORT vreg */
267 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_A)) {
268 vgpu_vreg_t(vgpu, BXT_P_CR_GT_DISP_PWRON) |= BIT(1);
269 vgpu_vreg_t(vgpu, BXT_PORT_CL1CM_DW0(DPIO_PHY1)) |=
270 PHY_POWER_GOOD;
271 vgpu_vreg_t(vgpu, BXT_PHY_CTL_FAMILY(DPIO_PHY1)) |=
272 BIT(30);
273 vgpu_vreg_t(vgpu, BXT_PHY_CTL(PORT_A)) |=
274 BXT_PHY_LANE_ENABLED;
275 vgpu_vreg_t(vgpu, BXT_PHY_CTL(PORT_A)) &=
276 ~(BXT_PHY_CMNLANE_POWERDOWN_ACK |
277 BXT_PHY_LANE_POWERDOWN_ACK);
278 vgpu_vreg_t(vgpu, BXT_PORT_PLL_ENABLE(PORT_A)) |=
279 (PORT_PLL_POWER_STATE | PORT_PLL_POWER_ENABLE |
280 PORT_PLL_REF_SEL | PORT_PLL_LOCK |
281 PORT_PLL_ENABLE);
282 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_A)) |=
283 (DDI_BUF_CTL_ENABLE | DDI_INIT_DISPLAY_DETECTED);
284 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_A)) &=
285 ~DDI_BUF_IS_IDLE;
286 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_EDP)) |=
287 (TRANS_DDI_BPC_8 | TRANS_DDI_MODE_SELECT_DP_SST |
288 TRANS_DDI_FUNC_ENABLE);
289 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) |=
290 PORTA_HOTPLUG_ENABLE;
291 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) |=
292 GEN8_DE_PORT_HOTPLUG(HPD_PORT_A);
293 }
294
295 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_B)) {
296 vgpu_vreg_t(vgpu, SFUSE_STRAP) |= SFUSE_STRAP_DDIB_DETECTED;
297 vgpu_vreg_t(vgpu, BXT_P_CR_GT_DISP_PWRON) |= BIT(0);
298 vgpu_vreg_t(vgpu, BXT_PORT_CL1CM_DW0(DPIO_PHY0)) |=
299 PHY_POWER_GOOD;
300 vgpu_vreg_t(vgpu, BXT_PHY_CTL_FAMILY(DPIO_PHY0)) |=
301 BIT(30);
302 vgpu_vreg_t(vgpu, BXT_PHY_CTL(PORT_B)) |=
303 BXT_PHY_LANE_ENABLED;
304 vgpu_vreg_t(vgpu, BXT_PHY_CTL(PORT_B)) &=
305 ~(BXT_PHY_CMNLANE_POWERDOWN_ACK |
306 BXT_PHY_LANE_POWERDOWN_ACK);
307 vgpu_vreg_t(vgpu, BXT_PORT_PLL_ENABLE(PORT_B)) |=
308 (PORT_PLL_POWER_STATE | PORT_PLL_POWER_ENABLE |
309 PORT_PLL_REF_SEL | PORT_PLL_LOCK |
310 PORT_PLL_ENABLE);
311 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_B)) |=
312 DDI_BUF_CTL_ENABLE;
313 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_B)) &=
314 ~DDI_BUF_IS_IDLE;
315 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) |=
316 (TRANS_DDI_BPC_8 | TRANS_DDI_MODE_SELECT_DP_SST |
317 (PORT_B << TRANS_DDI_PORT_SHIFT) |
318 TRANS_DDI_FUNC_ENABLE);
319 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) |=
320 PORTB_HOTPLUG_ENABLE;
321 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) |=
322 GEN8_DE_PORT_HOTPLUG(HPD_PORT_B);
323 }
324
325 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_C)) {
326 vgpu_vreg_t(vgpu, SFUSE_STRAP) |= SFUSE_STRAP_DDIC_DETECTED;
327 vgpu_vreg_t(vgpu, BXT_P_CR_GT_DISP_PWRON) |= BIT(0);
328 vgpu_vreg_t(vgpu, BXT_PORT_CL1CM_DW0(DPIO_PHY0)) |=
329 PHY_POWER_GOOD;
330 vgpu_vreg_t(vgpu, BXT_PHY_CTL_FAMILY(DPIO_PHY0)) |=
331 BIT(30);
332 vgpu_vreg_t(vgpu, BXT_PHY_CTL(PORT_C)) |=
333 BXT_PHY_LANE_ENABLED;
334 vgpu_vreg_t(vgpu, BXT_PHY_CTL(PORT_C)) &=
335 ~(BXT_PHY_CMNLANE_POWERDOWN_ACK |
336 BXT_PHY_LANE_POWERDOWN_ACK);
337 vgpu_vreg_t(vgpu, BXT_PORT_PLL_ENABLE(PORT_C)) |=
338 (PORT_PLL_POWER_STATE | PORT_PLL_POWER_ENABLE |
339 PORT_PLL_REF_SEL | PORT_PLL_LOCK |
340 PORT_PLL_ENABLE);
341 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_C)) |=
342 DDI_BUF_CTL_ENABLE;
343 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_C)) &=
344 ~DDI_BUF_IS_IDLE;
345 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) |=
346 (TRANS_DDI_BPC_8 | TRANS_DDI_MODE_SELECT_DP_SST |
347 (PORT_B << TRANS_DDI_PORT_SHIFT) |
348 TRANS_DDI_FUNC_ENABLE);
349 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) |=
350 PORTC_HOTPLUG_ENABLE;
351 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) |=
352 GEN8_DE_PORT_HOTPLUG(HPD_PORT_C);
353 }
354
355 return;
356 }
357
358 vgpu_vreg_t(vgpu, SDEISR) &= ~(SDE_PORTB_HOTPLUG_CPT |
359 SDE_PORTC_HOTPLUG_CPT |
360 SDE_PORTD_HOTPLUG_CPT);
361
362 if (IS_SKYLAKE(dev_priv) ||
363 IS_KABYLAKE(dev_priv) ||
364 IS_COFFEELAKE(dev_priv) ||
365 IS_COMETLAKE(dev_priv)) {
366 vgpu_vreg_t(vgpu, SDEISR) &= ~(SDE_PORTA_HOTPLUG_SPT |
367 SDE_PORTE_HOTPLUG_SPT);
368 vgpu_vreg_t(vgpu, SKL_FUSE_STATUS) |=
369 SKL_FUSE_DOWNLOAD_STATUS |
370 SKL_FUSE_PG_DIST_STATUS(SKL_PG0) |
371 SKL_FUSE_PG_DIST_STATUS(SKL_PG1) |
372 SKL_FUSE_PG_DIST_STATUS(SKL_PG2);
373 /*
374 * Only 1 PIPE enabled in current vGPU display and PIPE_A is
375 * tied to TRANSCODER_A in HW, so it's safe to assume PIPE_A,
376 * TRANSCODER_A can be enabled. PORT_x depends on the input of
377 * setup_virtual_dp_monitor, we can bind DPLL0 to any PORT_x
378 * so we fixed to DPLL0 here.
379 * Setup DPLL0: DP link clk 1620 MHz, non SSC, DP Mode
380 */
381 vgpu_vreg_t(vgpu, DPLL_CTRL1) =
382 DPLL_CTRL1_OVERRIDE(DPLL_ID_SKL_DPLL0);
383 vgpu_vreg_t(vgpu, DPLL_CTRL1) |=
384 DPLL_CTRL1_LINK_RATE(DPLL_CTRL1_LINK_RATE_1620, DPLL_ID_SKL_DPLL0);
385 vgpu_vreg_t(vgpu, LCPLL1_CTL) =
386 LCPLL_PLL_ENABLE | LCPLL_PLL_LOCK;
387 vgpu_vreg_t(vgpu, DPLL_STATUS) = DPLL_LOCK(DPLL_ID_SKL_DPLL0);
388 /*
389 * Golden M/N are calculated based on:
390 * 24 bpp, 4 lanes, 154000 pixel clk (from virtual EDID),
391 * DP link clk 1620 MHz and non-constant_n.
392 * TODO: calculate DP link symbol clk and stream clk m/n.
393 */
394 vgpu_vreg_t(vgpu, PIPE_DATA_M1(TRANSCODER_A)) = TU_SIZE(64);
395 vgpu_vreg_t(vgpu, PIPE_DATA_M1(TRANSCODER_A)) |= 0x5b425e;
396 vgpu_vreg_t(vgpu, PIPE_DATA_N1(TRANSCODER_A)) = 0x800000;
397 vgpu_vreg_t(vgpu, PIPE_LINK_M1(TRANSCODER_A)) = 0x3cd6e;
398 vgpu_vreg_t(vgpu, PIPE_LINK_N1(TRANSCODER_A)) = 0x80000;
399 }
400
401 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_B)) {
402 vgpu_vreg_t(vgpu, DPLL_CTRL2) &=
403 ~DPLL_CTRL2_DDI_CLK_OFF(PORT_B);
404 vgpu_vreg_t(vgpu, DPLL_CTRL2) |=
405 DPLL_CTRL2_DDI_CLK_SEL(DPLL_ID_SKL_DPLL0, PORT_B);
406 vgpu_vreg_t(vgpu, DPLL_CTRL2) |=
407 DPLL_CTRL2_DDI_SEL_OVERRIDE(PORT_B);
408 vgpu_vreg_t(vgpu, SFUSE_STRAP) |= SFUSE_STRAP_DDIB_DETECTED;
409 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) &=
410 ~(TRANS_DDI_BPC_MASK | TRANS_DDI_MODE_SELECT_MASK |
411 TRANS_DDI_PORT_MASK);
412 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) |=
413 (TRANS_DDI_BPC_8 | TRANS_DDI_MODE_SELECT_DP_SST |
414 (PORT_B << TRANS_DDI_PORT_SHIFT) |
415 TRANS_DDI_FUNC_ENABLE);
416 if (IS_BROADWELL(dev_priv)) {
417 vgpu_vreg_t(vgpu, PORT_CLK_SEL(PORT_B)) &=
418 ~PORT_CLK_SEL_MASK;
419 vgpu_vreg_t(vgpu, PORT_CLK_SEL(PORT_B)) |=
420 PORT_CLK_SEL_LCPLL_810;
421 }
422 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_B)) |= DDI_BUF_CTL_ENABLE;
423 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_B)) &= ~DDI_BUF_IS_IDLE;
424 vgpu_vreg_t(vgpu, SDEISR) |= SDE_PORTB_HOTPLUG_CPT;
425 }
426
427 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_C)) {
428 vgpu_vreg_t(vgpu, DPLL_CTRL2) &=
429 ~DPLL_CTRL2_DDI_CLK_OFF(PORT_C);
430 vgpu_vreg_t(vgpu, DPLL_CTRL2) |=
431 DPLL_CTRL2_DDI_CLK_SEL(DPLL_ID_SKL_DPLL0, PORT_C);
432 vgpu_vreg_t(vgpu, DPLL_CTRL2) |=
433 DPLL_CTRL2_DDI_SEL_OVERRIDE(PORT_C);
434 vgpu_vreg_t(vgpu, SDEISR) |= SDE_PORTC_HOTPLUG_CPT;
435 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) &=
436 ~(TRANS_DDI_BPC_MASK | TRANS_DDI_MODE_SELECT_MASK |
437 TRANS_DDI_PORT_MASK);
438 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) |=
439 (TRANS_DDI_BPC_8 | TRANS_DDI_MODE_SELECT_DP_SST |
440 (PORT_C << TRANS_DDI_PORT_SHIFT) |
441 TRANS_DDI_FUNC_ENABLE);
442 if (IS_BROADWELL(dev_priv)) {
443 vgpu_vreg_t(vgpu, PORT_CLK_SEL(PORT_C)) &=
444 ~PORT_CLK_SEL_MASK;
445 vgpu_vreg_t(vgpu, PORT_CLK_SEL(PORT_C)) |=
446 PORT_CLK_SEL_LCPLL_810;
447 }
448 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_C)) |= DDI_BUF_CTL_ENABLE;
449 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_C)) &= ~DDI_BUF_IS_IDLE;
450 vgpu_vreg_t(vgpu, SFUSE_STRAP) |= SFUSE_STRAP_DDIC_DETECTED;
451 }
452
453 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_D)) {
454 vgpu_vreg_t(vgpu, DPLL_CTRL2) &=
455 ~DPLL_CTRL2_DDI_CLK_OFF(PORT_D);
456 vgpu_vreg_t(vgpu, DPLL_CTRL2) |=
457 DPLL_CTRL2_DDI_CLK_SEL(DPLL_ID_SKL_DPLL0, PORT_D);
458 vgpu_vreg_t(vgpu, DPLL_CTRL2) |=
459 DPLL_CTRL2_DDI_SEL_OVERRIDE(PORT_D);
460 vgpu_vreg_t(vgpu, SDEISR) |= SDE_PORTD_HOTPLUG_CPT;
461 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) &=
462 ~(TRANS_DDI_BPC_MASK | TRANS_DDI_MODE_SELECT_MASK |
463 TRANS_DDI_PORT_MASK);
464 vgpu_vreg_t(vgpu, TRANS_DDI_FUNC_CTL(TRANSCODER_A)) |=
465 (TRANS_DDI_BPC_8 | TRANS_DDI_MODE_SELECT_DP_SST |
466 (PORT_D << TRANS_DDI_PORT_SHIFT) |
467 TRANS_DDI_FUNC_ENABLE);
468 if (IS_BROADWELL(dev_priv)) {
469 vgpu_vreg_t(vgpu, PORT_CLK_SEL(PORT_D)) &=
470 ~PORT_CLK_SEL_MASK;
471 vgpu_vreg_t(vgpu, PORT_CLK_SEL(PORT_D)) |=
472 PORT_CLK_SEL_LCPLL_810;
473 }
474 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_D)) |= DDI_BUF_CTL_ENABLE;
475 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_D)) &= ~DDI_BUF_IS_IDLE;
476 vgpu_vreg_t(vgpu, SFUSE_STRAP) |= SFUSE_STRAP_DDID_DETECTED;
477 }
478
479 if ((IS_SKYLAKE(dev_priv) ||
480 IS_KABYLAKE(dev_priv) ||
481 IS_COFFEELAKE(dev_priv) ||
482 IS_COMETLAKE(dev_priv)) &&
483 intel_vgpu_has_monitor_on_port(vgpu, PORT_E)) {
484 vgpu_vreg_t(vgpu, SDEISR) |= SDE_PORTE_HOTPLUG_SPT;
485 }
486
487 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_A)) {
488 if (IS_BROADWELL(dev_priv))
489 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) |=
490 GEN8_DE_PORT_HOTPLUG(HPD_PORT_A);
491 else
492 vgpu_vreg_t(vgpu, SDEISR) |= SDE_PORTA_HOTPLUG_SPT;
493
494 vgpu_vreg_t(vgpu, DDI_BUF_CTL(PORT_A)) |= DDI_INIT_DISPLAY_DETECTED;
495 }
496
497 /* Clear host CRT status, so guest couldn't detect this host CRT. */
498 if (IS_BROADWELL(dev_priv))
499 vgpu_vreg_t(vgpu, PCH_ADPA) &= ~ADPA_CRT_HOTPLUG_MONITOR_MASK;
500
501 /* Disable Primary/Sprite/Cursor plane */
502 for_each_pipe(dev_priv, pipe) {
503 vgpu_vreg_t(vgpu, DSPCNTR(pipe)) &= ~DISP_ENABLE;
504 vgpu_vreg_t(vgpu, SPRCTL(pipe)) &= ~SPRITE_ENABLE;
505 vgpu_vreg_t(vgpu, CURCNTR(pipe)) &= ~MCURSOR_MODE_MASK;
506 vgpu_vreg_t(vgpu, CURCNTR(pipe)) |= MCURSOR_MODE_DISABLE;
507 }
508
509 vgpu_vreg_t(vgpu, TRANSCONF(TRANSCODER_A)) |= TRANSCONF_ENABLE;
510 }
511
clean_virtual_dp_monitor(struct intel_vgpu * vgpu,int port_num)512 static void clean_virtual_dp_monitor(struct intel_vgpu *vgpu, int port_num)
513 {
514 struct intel_vgpu_port *port = intel_vgpu_port(vgpu, port_num);
515
516 kfree(port->edid);
517 port->edid = NULL;
518
519 kfree(port->dpcd);
520 port->dpcd = NULL;
521 }
522
vblank_timer_fn(struct hrtimer * data)523 static enum hrtimer_restart vblank_timer_fn(struct hrtimer *data)
524 {
525 struct intel_vgpu_vblank_timer *vblank_timer;
526 struct intel_vgpu *vgpu;
527
528 vblank_timer = container_of(data, struct intel_vgpu_vblank_timer, timer);
529 vgpu = container_of(vblank_timer, struct intel_vgpu, vblank_timer);
530
531 /* Set vblank emulation request per-vGPU bit */
532 intel_gvt_request_service(vgpu->gvt,
533 INTEL_GVT_REQUEST_EMULATE_VBLANK + vgpu->id);
534 hrtimer_add_expires_ns(&vblank_timer->timer, vblank_timer->period);
535 return HRTIMER_RESTART;
536 }
537
setup_virtual_dp_monitor(struct intel_vgpu * vgpu,int port_num,int type,unsigned int resolution)538 static int setup_virtual_dp_monitor(struct intel_vgpu *vgpu, int port_num,
539 int type, unsigned int resolution)
540 {
541 struct drm_i915_private *i915 = vgpu->gvt->gt->i915;
542 struct intel_vgpu_port *port = intel_vgpu_port(vgpu, port_num);
543 struct intel_vgpu_vblank_timer *vblank_timer = &vgpu->vblank_timer;
544
545 if (drm_WARN_ON(&i915->drm, resolution >= GVT_EDID_NUM))
546 return -EINVAL;
547
548 port->edid = kzalloc(sizeof(*(port->edid)), GFP_KERNEL);
549 if (!port->edid)
550 return -ENOMEM;
551
552 port->dpcd = kzalloc(sizeof(*(port->dpcd)), GFP_KERNEL);
553 if (!port->dpcd) {
554 kfree(port->edid);
555 return -ENOMEM;
556 }
557
558 memcpy(port->edid->edid_block, virtual_dp_monitor_edid[resolution],
559 EDID_SIZE);
560 port->edid->data_valid = true;
561
562 memcpy(port->dpcd->data, dpcd_fix_data, DPCD_HEADER_SIZE);
563 port->dpcd->data_valid = true;
564 port->dpcd->data[DPCD_SINK_COUNT] = 0x1;
565 port->type = type;
566 port->id = resolution;
567 port->vrefresh_k = GVT_DEFAULT_REFRESH_RATE * MSEC_PER_SEC;
568 vgpu->display.port_num = port_num;
569
570 /* Init hrtimer based on default refresh rate */
571 hrtimer_init(&vblank_timer->timer, CLOCK_MONOTONIC, HRTIMER_MODE_ABS);
572 vblank_timer->timer.function = vblank_timer_fn;
573 vblank_timer->vrefresh_k = port->vrefresh_k;
574 vblank_timer->period = DIV64_U64_ROUND_CLOSEST(NSEC_PER_SEC * MSEC_PER_SEC, vblank_timer->vrefresh_k);
575
576 emulate_monitor_status_change(vgpu);
577
578 return 0;
579 }
580
581 /**
582 * vgpu_update_vblank_emulation - Update per-vGPU vblank_timer
583 * @vgpu: vGPU operated
584 * @turnon: Turn ON/OFF vblank_timer
585 *
586 * This function is used to turn on/off or update the per-vGPU vblank_timer
587 * when TRANSCONF is enabled or disabled. vblank_timer period is also updated
588 * if guest changed the refresh rate.
589 *
590 */
vgpu_update_vblank_emulation(struct intel_vgpu * vgpu,bool turnon)591 void vgpu_update_vblank_emulation(struct intel_vgpu *vgpu, bool turnon)
592 {
593 struct intel_vgpu_vblank_timer *vblank_timer = &vgpu->vblank_timer;
594 struct intel_vgpu_port *port =
595 intel_vgpu_port(vgpu, vgpu->display.port_num);
596
597 if (turnon) {
598 /*
599 * Skip the re-enable if already active and vrefresh unchanged.
600 * Otherwise, stop timer if already active and restart with new
601 * period.
602 */
603 if (vblank_timer->vrefresh_k != port->vrefresh_k ||
604 !hrtimer_active(&vblank_timer->timer)) {
605 /* Stop timer before start with new period if active */
606 if (hrtimer_active(&vblank_timer->timer))
607 hrtimer_cancel(&vblank_timer->timer);
608
609 /* Make sure new refresh rate updated to timer period */
610 vblank_timer->vrefresh_k = port->vrefresh_k;
611 vblank_timer->period = DIV64_U64_ROUND_CLOSEST(NSEC_PER_SEC * MSEC_PER_SEC, vblank_timer->vrefresh_k);
612 hrtimer_start(&vblank_timer->timer,
613 ktime_add_ns(ktime_get(), vblank_timer->period),
614 HRTIMER_MODE_ABS);
615 }
616 } else {
617 /* Caller request to stop vblank */
618 hrtimer_cancel(&vblank_timer->timer);
619 }
620 }
621
emulate_vblank_on_pipe(struct intel_vgpu * vgpu,int pipe)622 static void emulate_vblank_on_pipe(struct intel_vgpu *vgpu, int pipe)
623 {
624 struct drm_i915_private *dev_priv = vgpu->gvt->gt->i915;
625 struct intel_vgpu_irq *irq = &vgpu->irq;
626 int vblank_event[] = {
627 [PIPE_A] = PIPE_A_VBLANK,
628 [PIPE_B] = PIPE_B_VBLANK,
629 [PIPE_C] = PIPE_C_VBLANK,
630 };
631 int event;
632
633 if (pipe < PIPE_A || pipe > PIPE_C)
634 return;
635
636 for_each_set_bit(event, irq->flip_done_event[pipe],
637 INTEL_GVT_EVENT_MAX) {
638 clear_bit(event, irq->flip_done_event[pipe]);
639 if (!pipe_is_enabled(vgpu, pipe))
640 continue;
641
642 intel_vgpu_trigger_virtual_event(vgpu, event);
643 }
644
645 if (pipe_is_enabled(vgpu, pipe)) {
646 vgpu_vreg_t(vgpu, PIPE_FRMCOUNT_G4X(pipe))++;
647 intel_vgpu_trigger_virtual_event(vgpu, vblank_event[pipe]);
648 }
649 }
650
intel_vgpu_emulate_vblank(struct intel_vgpu * vgpu)651 void intel_vgpu_emulate_vblank(struct intel_vgpu *vgpu)
652 {
653 int pipe;
654
655 mutex_lock(&vgpu->vgpu_lock);
656 for_each_pipe(vgpu->gvt->gt->i915, pipe)
657 emulate_vblank_on_pipe(vgpu, pipe);
658 mutex_unlock(&vgpu->vgpu_lock);
659 }
660
661 /**
662 * intel_vgpu_emulate_hotplug - trigger hotplug event for vGPU
663 * @vgpu: a vGPU
664 * @connected: link state
665 *
666 * This function is used to trigger hotplug interrupt for vGPU
667 *
668 */
intel_vgpu_emulate_hotplug(struct intel_vgpu * vgpu,bool connected)669 void intel_vgpu_emulate_hotplug(struct intel_vgpu *vgpu, bool connected)
670 {
671 struct drm_i915_private *i915 = vgpu->gvt->gt->i915;
672
673 /* TODO: add more platforms support */
674 if (IS_SKYLAKE(i915) ||
675 IS_KABYLAKE(i915) ||
676 IS_COFFEELAKE(i915) ||
677 IS_COMETLAKE(i915)) {
678 if (connected) {
679 vgpu_vreg_t(vgpu, SFUSE_STRAP) |=
680 SFUSE_STRAP_DDID_DETECTED;
681 vgpu_vreg_t(vgpu, SDEISR) |= SDE_PORTD_HOTPLUG_CPT;
682 } else {
683 vgpu_vreg_t(vgpu, SFUSE_STRAP) &=
684 ~SFUSE_STRAP_DDID_DETECTED;
685 vgpu_vreg_t(vgpu, SDEISR) &= ~SDE_PORTD_HOTPLUG_CPT;
686 }
687 vgpu_vreg_t(vgpu, SDEIIR) |= SDE_PORTD_HOTPLUG_CPT;
688 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) |=
689 PORTD_HOTPLUG_STATUS_MASK;
690 intel_vgpu_trigger_virtual_event(vgpu, DP_D_HOTPLUG);
691 } else if (IS_BROXTON(i915)) {
692 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_A)) {
693 if (connected) {
694 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) |=
695 GEN8_DE_PORT_HOTPLUG(HPD_PORT_A);
696 } else {
697 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) &=
698 ~GEN8_DE_PORT_HOTPLUG(HPD_PORT_A);
699 }
700 vgpu_vreg_t(vgpu, GEN8_DE_PORT_IIR) |=
701 GEN8_DE_PORT_HOTPLUG(HPD_PORT_A);
702 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) &=
703 ~PORTA_HOTPLUG_STATUS_MASK;
704 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) |=
705 PORTA_HOTPLUG_LONG_DETECT;
706 intel_vgpu_trigger_virtual_event(vgpu, DP_A_HOTPLUG);
707 }
708 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_B)) {
709 if (connected) {
710 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) |=
711 GEN8_DE_PORT_HOTPLUG(HPD_PORT_B);
712 vgpu_vreg_t(vgpu, SFUSE_STRAP) |=
713 SFUSE_STRAP_DDIB_DETECTED;
714 } else {
715 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) &=
716 ~GEN8_DE_PORT_HOTPLUG(HPD_PORT_B);
717 vgpu_vreg_t(vgpu, SFUSE_STRAP) &=
718 ~SFUSE_STRAP_DDIB_DETECTED;
719 }
720 vgpu_vreg_t(vgpu, GEN8_DE_PORT_IIR) |=
721 GEN8_DE_PORT_HOTPLUG(HPD_PORT_B);
722 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) &=
723 ~PORTB_HOTPLUG_STATUS_MASK;
724 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) |=
725 PORTB_HOTPLUG_LONG_DETECT;
726 intel_vgpu_trigger_virtual_event(vgpu, DP_B_HOTPLUG);
727 }
728 if (intel_vgpu_has_monitor_on_port(vgpu, PORT_C)) {
729 if (connected) {
730 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) |=
731 GEN8_DE_PORT_HOTPLUG(HPD_PORT_C);
732 vgpu_vreg_t(vgpu, SFUSE_STRAP) |=
733 SFUSE_STRAP_DDIC_DETECTED;
734 } else {
735 vgpu_vreg_t(vgpu, GEN8_DE_PORT_ISR) &=
736 ~GEN8_DE_PORT_HOTPLUG(HPD_PORT_C);
737 vgpu_vreg_t(vgpu, SFUSE_STRAP) &=
738 ~SFUSE_STRAP_DDIC_DETECTED;
739 }
740 vgpu_vreg_t(vgpu, GEN8_DE_PORT_IIR) |=
741 GEN8_DE_PORT_HOTPLUG(HPD_PORT_C);
742 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) &=
743 ~PORTC_HOTPLUG_STATUS_MASK;
744 vgpu_vreg_t(vgpu, PCH_PORT_HOTPLUG) |=
745 PORTC_HOTPLUG_LONG_DETECT;
746 intel_vgpu_trigger_virtual_event(vgpu, DP_C_HOTPLUG);
747 }
748 }
749 }
750
751 /**
752 * intel_vgpu_clean_display - clean vGPU virtual display emulation
753 * @vgpu: a vGPU
754 *
755 * This function is used to clean vGPU virtual display emulation stuffs
756 *
757 */
intel_vgpu_clean_display(struct intel_vgpu * vgpu)758 void intel_vgpu_clean_display(struct intel_vgpu *vgpu)
759 {
760 struct drm_i915_private *dev_priv = vgpu->gvt->gt->i915;
761
762 if (IS_SKYLAKE(dev_priv) ||
763 IS_KABYLAKE(dev_priv) ||
764 IS_COFFEELAKE(dev_priv) ||
765 IS_COMETLAKE(dev_priv))
766 clean_virtual_dp_monitor(vgpu, PORT_D);
767 else
768 clean_virtual_dp_monitor(vgpu, PORT_B);
769
770 vgpu_update_vblank_emulation(vgpu, false);
771 }
772
773 /**
774 * intel_vgpu_init_display- initialize vGPU virtual display emulation
775 * @vgpu: a vGPU
776 * @resolution: resolution index for intel_vgpu_edid
777 *
778 * This function is used to initialize vGPU virtual display emulation stuffs
779 *
780 * Returns:
781 * Zero on success, negative error code if failed.
782 *
783 */
intel_vgpu_init_display(struct intel_vgpu * vgpu,u64 resolution)784 int intel_vgpu_init_display(struct intel_vgpu *vgpu, u64 resolution)
785 {
786 struct drm_i915_private *dev_priv = vgpu->gvt->gt->i915;
787
788 intel_vgpu_init_i2c_edid(vgpu);
789
790 if (IS_SKYLAKE(dev_priv) ||
791 IS_KABYLAKE(dev_priv) ||
792 IS_COFFEELAKE(dev_priv) ||
793 IS_COMETLAKE(dev_priv))
794 return setup_virtual_dp_monitor(vgpu, PORT_D, GVT_DP_D,
795 resolution);
796 else
797 return setup_virtual_dp_monitor(vgpu, PORT_B, GVT_DP_B,
798 resolution);
799 }
800
801 /**
802 * intel_vgpu_reset_display- reset vGPU virtual display emulation
803 * @vgpu: a vGPU
804 *
805 * This function is used to reset vGPU virtual display emulation stuffs
806 *
807 */
intel_vgpu_reset_display(struct intel_vgpu * vgpu)808 void intel_vgpu_reset_display(struct intel_vgpu *vgpu)
809 {
810 emulate_monitor_status_change(vgpu);
811 }
812