xref: /openbmc/linux/drivers/gpu/drm/i915/display/intel_display_debugfs.c (revision f97cee494dc92395a668445bcd24d34c89f4ff8c)
1 // SPDX-License-Identifier: MIT
2 /*
3  * Copyright © 2020 Intel Corporation
4  */
5 
6 #include <drm/drm_debugfs.h>
7 #include <drm/drm_fourcc.h>
8 
9 #include "i915_debugfs.h"
10 #include "intel_csr.h"
11 #include "intel_display_debugfs.h"
12 #include "intel_display_power.h"
13 #include "intel_display_types.h"
14 #include "intel_dp.h"
15 #include "intel_fbc.h"
16 #include "intel_hdcp.h"
17 #include "intel_hdmi.h"
18 #include "intel_pm.h"
19 #include "intel_psr.h"
20 #include "intel_sideband.h"
21 
22 static inline struct drm_i915_private *node_to_i915(struct drm_info_node *node)
23 {
24 	return to_i915(node->minor->dev);
25 }
26 
27 static int i915_frontbuffer_tracking(struct seq_file *m, void *unused)
28 {
29 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
30 
31 	seq_printf(m, "FB tracking busy bits: 0x%08x\n",
32 		   dev_priv->fb_tracking.busy_bits);
33 
34 	seq_printf(m, "FB tracking flip bits: 0x%08x\n",
35 		   dev_priv->fb_tracking.flip_bits);
36 
37 	return 0;
38 }
39 
40 static int i915_fbc_status(struct seq_file *m, void *unused)
41 {
42 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
43 	struct intel_fbc *fbc = &dev_priv->fbc;
44 	intel_wakeref_t wakeref;
45 
46 	if (!HAS_FBC(dev_priv))
47 		return -ENODEV;
48 
49 	wakeref = intel_runtime_pm_get(&dev_priv->runtime_pm);
50 	mutex_lock(&fbc->lock);
51 
52 	if (intel_fbc_is_active(dev_priv))
53 		seq_puts(m, "FBC enabled\n");
54 	else
55 		seq_printf(m, "FBC disabled: %s\n", fbc->no_fbc_reason);
56 
57 	if (intel_fbc_is_active(dev_priv)) {
58 		u32 mask;
59 
60 		if (INTEL_GEN(dev_priv) >= 8)
61 			mask = intel_de_read(dev_priv, IVB_FBC_STATUS2) & BDW_FBC_COMP_SEG_MASK;
62 		else if (INTEL_GEN(dev_priv) >= 7)
63 			mask = intel_de_read(dev_priv, IVB_FBC_STATUS2) & IVB_FBC_COMP_SEG_MASK;
64 		else if (INTEL_GEN(dev_priv) >= 5)
65 			mask = intel_de_read(dev_priv, ILK_DPFC_STATUS) & ILK_DPFC_COMP_SEG_MASK;
66 		else if (IS_G4X(dev_priv))
67 			mask = intel_de_read(dev_priv, DPFC_STATUS) & DPFC_COMP_SEG_MASK;
68 		else
69 			mask = intel_de_read(dev_priv, FBC_STATUS) &
70 				(FBC_STAT_COMPRESSING | FBC_STAT_COMPRESSED);
71 
72 		seq_printf(m, "Compressing: %s\n", yesno(mask));
73 	}
74 
75 	mutex_unlock(&fbc->lock);
76 	intel_runtime_pm_put(&dev_priv->runtime_pm, wakeref);
77 
78 	return 0;
79 }
80 
81 static int i915_fbc_false_color_get(void *data, u64 *val)
82 {
83 	struct drm_i915_private *dev_priv = data;
84 
85 	if (INTEL_GEN(dev_priv) < 7 || !HAS_FBC(dev_priv))
86 		return -ENODEV;
87 
88 	*val = dev_priv->fbc.false_color;
89 
90 	return 0;
91 }
92 
93 static int i915_fbc_false_color_set(void *data, u64 val)
94 {
95 	struct drm_i915_private *dev_priv = data;
96 	u32 reg;
97 
98 	if (INTEL_GEN(dev_priv) < 7 || !HAS_FBC(dev_priv))
99 		return -ENODEV;
100 
101 	mutex_lock(&dev_priv->fbc.lock);
102 
103 	reg = intel_de_read(dev_priv, ILK_DPFC_CONTROL);
104 	dev_priv->fbc.false_color = val;
105 
106 	intel_de_write(dev_priv, ILK_DPFC_CONTROL,
107 		       val ? (reg | FBC_CTL_FALSE_COLOR) : (reg & ~FBC_CTL_FALSE_COLOR));
108 
109 	mutex_unlock(&dev_priv->fbc.lock);
110 	return 0;
111 }
112 
113 DEFINE_SIMPLE_ATTRIBUTE(i915_fbc_false_color_fops,
114 			i915_fbc_false_color_get, i915_fbc_false_color_set,
115 			"%llu\n");
116 
117 static int i915_ips_status(struct seq_file *m, void *unused)
118 {
119 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
120 	intel_wakeref_t wakeref;
121 
122 	if (!HAS_IPS(dev_priv))
123 		return -ENODEV;
124 
125 	wakeref = intel_runtime_pm_get(&dev_priv->runtime_pm);
126 
127 	seq_printf(m, "Enabled by kernel parameter: %s\n",
128 		   yesno(dev_priv->params.enable_ips));
129 
130 	if (INTEL_GEN(dev_priv) >= 8) {
131 		seq_puts(m, "Currently: unknown\n");
132 	} else {
133 		if (intel_de_read(dev_priv, IPS_CTL) & IPS_ENABLE)
134 			seq_puts(m, "Currently: enabled\n");
135 		else
136 			seq_puts(m, "Currently: disabled\n");
137 	}
138 
139 	intel_runtime_pm_put(&dev_priv->runtime_pm, wakeref);
140 
141 	return 0;
142 }
143 
144 static int i915_sr_status(struct seq_file *m, void *unused)
145 {
146 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
147 	intel_wakeref_t wakeref;
148 	bool sr_enabled = false;
149 
150 	wakeref = intel_display_power_get(dev_priv, POWER_DOMAIN_INIT);
151 
152 	if (INTEL_GEN(dev_priv) >= 9)
153 		/* no global SR status; inspect per-plane WM */;
154 	else if (HAS_PCH_SPLIT(dev_priv))
155 		sr_enabled = intel_de_read(dev_priv, WM1_LP_ILK) & WM1_LP_SR_EN;
156 	else if (IS_I965GM(dev_priv) || IS_G4X(dev_priv) ||
157 		 IS_I945G(dev_priv) || IS_I945GM(dev_priv))
158 		sr_enabled = intel_de_read(dev_priv, FW_BLC_SELF) & FW_BLC_SELF_EN;
159 	else if (IS_I915GM(dev_priv))
160 		sr_enabled = intel_de_read(dev_priv, INSTPM) & INSTPM_SELF_EN;
161 	else if (IS_PINEVIEW(dev_priv))
162 		sr_enabled = intel_de_read(dev_priv, DSPFW3) & PINEVIEW_SELF_REFRESH_EN;
163 	else if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv))
164 		sr_enabled = intel_de_read(dev_priv, FW_BLC_SELF_VLV) & FW_CSPWRDWNEN;
165 
166 	intel_display_power_put(dev_priv, POWER_DOMAIN_INIT, wakeref);
167 
168 	seq_printf(m, "self-refresh: %s\n", enableddisabled(sr_enabled));
169 
170 	return 0;
171 }
172 
173 static int i915_opregion(struct seq_file *m, void *unused)
174 {
175 	struct intel_opregion *opregion = &node_to_i915(m->private)->opregion;
176 
177 	if (opregion->header)
178 		seq_write(m, opregion->header, OPREGION_SIZE);
179 
180 	return 0;
181 }
182 
183 static int i915_vbt(struct seq_file *m, void *unused)
184 {
185 	struct intel_opregion *opregion = &node_to_i915(m->private)->opregion;
186 
187 	if (opregion->vbt)
188 		seq_write(m, opregion->vbt, opregion->vbt_size);
189 
190 	return 0;
191 }
192 
193 static int i915_gem_framebuffer_info(struct seq_file *m, void *data)
194 {
195 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
196 	struct drm_device *dev = &dev_priv->drm;
197 	struct intel_framebuffer *fbdev_fb = NULL;
198 	struct drm_framebuffer *drm_fb;
199 
200 #ifdef CONFIG_DRM_FBDEV_EMULATION
201 	if (dev_priv->fbdev && dev_priv->fbdev->helper.fb) {
202 		fbdev_fb = to_intel_framebuffer(dev_priv->fbdev->helper.fb);
203 
204 		seq_printf(m, "fbcon size: %d x %d, depth %d, %d bpp, modifier 0x%llx, refcount %d, obj ",
205 			   fbdev_fb->base.width,
206 			   fbdev_fb->base.height,
207 			   fbdev_fb->base.format->depth,
208 			   fbdev_fb->base.format->cpp[0] * 8,
209 			   fbdev_fb->base.modifier,
210 			   drm_framebuffer_read_refcount(&fbdev_fb->base));
211 		i915_debugfs_describe_obj(m, intel_fb_obj(&fbdev_fb->base));
212 		seq_putc(m, '\n');
213 	}
214 #endif
215 
216 	mutex_lock(&dev->mode_config.fb_lock);
217 	drm_for_each_fb(drm_fb, dev) {
218 		struct intel_framebuffer *fb = to_intel_framebuffer(drm_fb);
219 		if (fb == fbdev_fb)
220 			continue;
221 
222 		seq_printf(m, "user size: %d x %d, depth %d, %d bpp, modifier 0x%llx, refcount %d, obj ",
223 			   fb->base.width,
224 			   fb->base.height,
225 			   fb->base.format->depth,
226 			   fb->base.format->cpp[0] * 8,
227 			   fb->base.modifier,
228 			   drm_framebuffer_read_refcount(&fb->base));
229 		i915_debugfs_describe_obj(m, intel_fb_obj(&fb->base));
230 		seq_putc(m, '\n');
231 	}
232 	mutex_unlock(&dev->mode_config.fb_lock);
233 
234 	return 0;
235 }
236 
237 static int i915_psr_sink_status_show(struct seq_file *m, void *data)
238 {
239 	u8 val;
240 	static const char * const sink_status[] = {
241 		"inactive",
242 		"transition to active, capture and display",
243 		"active, display from RFB",
244 		"active, capture and display on sink device timings",
245 		"transition to inactive, capture and display, timing re-sync",
246 		"reserved",
247 		"reserved",
248 		"sink internal error",
249 	};
250 	struct drm_connector *connector = m->private;
251 	struct drm_i915_private *dev_priv = to_i915(connector->dev);
252 	struct intel_dp *intel_dp =
253 		intel_attached_dp(to_intel_connector(connector));
254 	int ret;
255 
256 	if (!CAN_PSR(dev_priv)) {
257 		seq_puts(m, "PSR Unsupported\n");
258 		return -ENODEV;
259 	}
260 
261 	if (connector->status != connector_status_connected)
262 		return -ENODEV;
263 
264 	ret = drm_dp_dpcd_readb(&intel_dp->aux, DP_PSR_STATUS, &val);
265 
266 	if (ret == 1) {
267 		const char *str = "unknown";
268 
269 		val &= DP_PSR_SINK_STATE_MASK;
270 		if (val < ARRAY_SIZE(sink_status))
271 			str = sink_status[val];
272 		seq_printf(m, "Sink PSR status: 0x%x [%s]\n", val, str);
273 	} else {
274 		return ret;
275 	}
276 
277 	return 0;
278 }
279 DEFINE_SHOW_ATTRIBUTE(i915_psr_sink_status);
280 
281 static void
282 psr_source_status(struct drm_i915_private *dev_priv, struct seq_file *m)
283 {
284 	u32 val, status_val;
285 	const char *status = "unknown";
286 
287 	if (dev_priv->psr.psr2_enabled) {
288 		static const char * const live_status[] = {
289 			"IDLE",
290 			"CAPTURE",
291 			"CAPTURE_FS",
292 			"SLEEP",
293 			"BUFON_FW",
294 			"ML_UP",
295 			"SU_STANDBY",
296 			"FAST_SLEEP",
297 			"DEEP_SLEEP",
298 			"BUF_ON",
299 			"TG_ON"
300 		};
301 		val = intel_de_read(dev_priv,
302 				    EDP_PSR2_STATUS(dev_priv->psr.transcoder));
303 		status_val = (val & EDP_PSR2_STATUS_STATE_MASK) >>
304 			      EDP_PSR2_STATUS_STATE_SHIFT;
305 		if (status_val < ARRAY_SIZE(live_status))
306 			status = live_status[status_val];
307 	} else {
308 		static const char * const live_status[] = {
309 			"IDLE",
310 			"SRDONACK",
311 			"SRDENT",
312 			"BUFOFF",
313 			"BUFON",
314 			"AUXACK",
315 			"SRDOFFACK",
316 			"SRDENT_ON",
317 		};
318 		val = intel_de_read(dev_priv,
319 				    EDP_PSR_STATUS(dev_priv->psr.transcoder));
320 		status_val = (val & EDP_PSR_STATUS_STATE_MASK) >>
321 			      EDP_PSR_STATUS_STATE_SHIFT;
322 		if (status_val < ARRAY_SIZE(live_status))
323 			status = live_status[status_val];
324 	}
325 
326 	seq_printf(m, "Source PSR status: %s [0x%08x]\n", status, val);
327 }
328 
329 static int i915_edp_psr_status(struct seq_file *m, void *data)
330 {
331 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
332 	struct i915_psr *psr = &dev_priv->psr;
333 	intel_wakeref_t wakeref;
334 	const char *status;
335 	bool enabled;
336 	u32 val;
337 
338 	if (!HAS_PSR(dev_priv))
339 		return -ENODEV;
340 
341 	seq_printf(m, "Sink support: %s", yesno(psr->sink_support));
342 	if (psr->dp)
343 		seq_printf(m, " [0x%02x]", psr->dp->psr_dpcd[0]);
344 	seq_puts(m, "\n");
345 
346 	if (!psr->sink_support)
347 		return 0;
348 
349 	wakeref = intel_runtime_pm_get(&dev_priv->runtime_pm);
350 	mutex_lock(&psr->lock);
351 
352 	if (psr->enabled)
353 		status = psr->psr2_enabled ? "PSR2 enabled" : "PSR1 enabled";
354 	else
355 		status = "disabled";
356 	seq_printf(m, "PSR mode: %s\n", status);
357 
358 	if (!psr->enabled) {
359 		seq_printf(m, "PSR sink not reliable: %s\n",
360 			   yesno(psr->sink_not_reliable));
361 
362 		goto unlock;
363 	}
364 
365 	if (psr->psr2_enabled) {
366 		val = intel_de_read(dev_priv,
367 				    EDP_PSR2_CTL(dev_priv->psr.transcoder));
368 		enabled = val & EDP_PSR2_ENABLE;
369 	} else {
370 		val = intel_de_read(dev_priv,
371 				    EDP_PSR_CTL(dev_priv->psr.transcoder));
372 		enabled = val & EDP_PSR_ENABLE;
373 	}
374 	seq_printf(m, "Source PSR ctl: %s [0x%08x]\n",
375 		   enableddisabled(enabled), val);
376 	psr_source_status(dev_priv, m);
377 	seq_printf(m, "Busy frontbuffer bits: 0x%08x\n",
378 		   psr->busy_frontbuffer_bits);
379 
380 	/*
381 	 * SKL+ Perf counter is reset to 0 everytime DC state is entered
382 	 */
383 	if (IS_HASWELL(dev_priv) || IS_BROADWELL(dev_priv)) {
384 		val = intel_de_read(dev_priv,
385 				    EDP_PSR_PERF_CNT(dev_priv->psr.transcoder));
386 		val &= EDP_PSR_PERF_CNT_MASK;
387 		seq_printf(m, "Performance counter: %u\n", val);
388 	}
389 
390 	if (psr->debug & I915_PSR_DEBUG_IRQ) {
391 		seq_printf(m, "Last attempted entry at: %lld\n",
392 			   psr->last_entry_attempt);
393 		seq_printf(m, "Last exit at: %lld\n", psr->last_exit);
394 	}
395 
396 	if (psr->psr2_enabled) {
397 		u32 su_frames_val[3];
398 		int frame;
399 
400 		/*
401 		 * Reading all 3 registers before hand to minimize crossing a
402 		 * frame boundary between register reads
403 		 */
404 		for (frame = 0; frame < PSR2_SU_STATUS_FRAMES; frame += 3) {
405 			val = intel_de_read(dev_priv,
406 					    PSR2_SU_STATUS(dev_priv->psr.transcoder, frame));
407 			su_frames_val[frame / 3] = val;
408 		}
409 
410 		seq_puts(m, "Frame:\tPSR2 SU blocks:\n");
411 
412 		for (frame = 0; frame < PSR2_SU_STATUS_FRAMES; frame++) {
413 			u32 su_blocks;
414 
415 			su_blocks = su_frames_val[frame / 3] &
416 				    PSR2_SU_STATUS_MASK(frame);
417 			su_blocks = su_blocks >> PSR2_SU_STATUS_SHIFT(frame);
418 			seq_printf(m, "%d\t%d\n", frame, su_blocks);
419 		}
420 	}
421 
422 unlock:
423 	mutex_unlock(&psr->lock);
424 	intel_runtime_pm_put(&dev_priv->runtime_pm, wakeref);
425 
426 	return 0;
427 }
428 
429 static int
430 i915_edp_psr_debug_set(void *data, u64 val)
431 {
432 	struct drm_i915_private *dev_priv = data;
433 	intel_wakeref_t wakeref;
434 	int ret;
435 
436 	if (!CAN_PSR(dev_priv))
437 		return -ENODEV;
438 
439 	drm_dbg_kms(&dev_priv->drm, "Setting PSR debug to %llx\n", val);
440 
441 	wakeref = intel_runtime_pm_get(&dev_priv->runtime_pm);
442 
443 	ret = intel_psr_debug_set(dev_priv, val);
444 
445 	intel_runtime_pm_put(&dev_priv->runtime_pm, wakeref);
446 
447 	return ret;
448 }
449 
450 static int
451 i915_edp_psr_debug_get(void *data, u64 *val)
452 {
453 	struct drm_i915_private *dev_priv = data;
454 
455 	if (!CAN_PSR(dev_priv))
456 		return -ENODEV;
457 
458 	*val = READ_ONCE(dev_priv->psr.debug);
459 	return 0;
460 }
461 
462 DEFINE_SIMPLE_ATTRIBUTE(i915_edp_psr_debug_fops,
463 			i915_edp_psr_debug_get, i915_edp_psr_debug_set,
464 			"%llu\n");
465 
466 static int i915_power_domain_info(struct seq_file *m, void *unused)
467 {
468 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
469 	struct i915_power_domains *power_domains = &dev_priv->power_domains;
470 	int i;
471 
472 	mutex_lock(&power_domains->lock);
473 
474 	seq_printf(m, "%-25s %s\n", "Power well/domain", "Use count");
475 	for (i = 0; i < power_domains->power_well_count; i++) {
476 		struct i915_power_well *power_well;
477 		enum intel_display_power_domain power_domain;
478 
479 		power_well = &power_domains->power_wells[i];
480 		seq_printf(m, "%-25s %d\n", power_well->desc->name,
481 			   power_well->count);
482 
483 		for_each_power_domain(power_domain, power_well->desc->domains)
484 			seq_printf(m, "  %-23s %d\n",
485 				 intel_display_power_domain_str(power_domain),
486 				 power_domains->domain_use_count[power_domain]);
487 	}
488 
489 	mutex_unlock(&power_domains->lock);
490 
491 	return 0;
492 }
493 
494 static int i915_dmc_info(struct seq_file *m, void *unused)
495 {
496 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
497 	intel_wakeref_t wakeref;
498 	struct intel_csr *csr;
499 	i915_reg_t dc5_reg, dc6_reg = {};
500 
501 	if (!HAS_CSR(dev_priv))
502 		return -ENODEV;
503 
504 	csr = &dev_priv->csr;
505 
506 	wakeref = intel_runtime_pm_get(&dev_priv->runtime_pm);
507 
508 	seq_printf(m, "fw loaded: %s\n", yesno(csr->dmc_payload != NULL));
509 	seq_printf(m, "path: %s\n", csr->fw_path);
510 
511 	if (!csr->dmc_payload)
512 		goto out;
513 
514 	seq_printf(m, "version: %d.%d\n", CSR_VERSION_MAJOR(csr->version),
515 		   CSR_VERSION_MINOR(csr->version));
516 
517 	if (INTEL_GEN(dev_priv) >= 12) {
518 		dc5_reg = TGL_DMC_DEBUG_DC5_COUNT;
519 		dc6_reg = TGL_DMC_DEBUG_DC6_COUNT;
520 		/*
521 		 * NOTE: DMC_DEBUG3 is a general purpose reg.
522 		 * According to B.Specs:49196 DMC f/w reuses DC5/6 counter
523 		 * reg for DC3CO debugging and validation,
524 		 * but TGL DMC f/w is using DMC_DEBUG3 reg for DC3CO counter.
525 		 */
526 		seq_printf(m, "DC3CO count: %d\n",
527 			   intel_de_read(dev_priv, DMC_DEBUG3));
528 	} else {
529 		dc5_reg = IS_BROXTON(dev_priv) ? BXT_CSR_DC3_DC5_COUNT :
530 						 SKL_CSR_DC3_DC5_COUNT;
531 		if (!IS_GEN9_LP(dev_priv))
532 			dc6_reg = SKL_CSR_DC5_DC6_COUNT;
533 	}
534 
535 	seq_printf(m, "DC3 -> DC5 count: %d\n",
536 		   intel_de_read(dev_priv, dc5_reg));
537 	if (dc6_reg.reg)
538 		seq_printf(m, "DC5 -> DC6 count: %d\n",
539 			   intel_de_read(dev_priv, dc6_reg));
540 
541 out:
542 	seq_printf(m, "program base: 0x%08x\n",
543 		   intel_de_read(dev_priv, CSR_PROGRAM(0)));
544 	seq_printf(m, "ssp base: 0x%08x\n",
545 		   intel_de_read(dev_priv, CSR_SSP_BASE));
546 	seq_printf(m, "htp: 0x%08x\n", intel_de_read(dev_priv, CSR_HTP_SKL));
547 
548 	intel_runtime_pm_put(&dev_priv->runtime_pm, wakeref);
549 
550 	return 0;
551 }
552 
553 static void intel_seq_print_mode(struct seq_file *m, int tabs,
554 				 const struct drm_display_mode *mode)
555 {
556 	int i;
557 
558 	for (i = 0; i < tabs; i++)
559 		seq_putc(m, '\t');
560 
561 	seq_printf(m, DRM_MODE_FMT "\n", DRM_MODE_ARG(mode));
562 }
563 
564 static void intel_encoder_info(struct seq_file *m,
565 			       struct intel_crtc *crtc,
566 			       struct intel_encoder *encoder)
567 {
568 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
569 	struct drm_connector_list_iter conn_iter;
570 	struct drm_connector *connector;
571 
572 	seq_printf(m, "\t[ENCODER:%d:%s]: connectors:\n",
573 		   encoder->base.base.id, encoder->base.name);
574 
575 	drm_connector_list_iter_begin(&dev_priv->drm, &conn_iter);
576 	drm_for_each_connector_iter(connector, &conn_iter) {
577 		const struct drm_connector_state *conn_state =
578 			connector->state;
579 
580 		if (conn_state->best_encoder != &encoder->base)
581 			continue;
582 
583 		seq_printf(m, "\t\t[CONNECTOR:%d:%s]\n",
584 			   connector->base.id, connector->name);
585 	}
586 	drm_connector_list_iter_end(&conn_iter);
587 }
588 
589 static void intel_panel_info(struct seq_file *m, struct intel_panel *panel)
590 {
591 	const struct drm_display_mode *mode = panel->fixed_mode;
592 
593 	seq_printf(m, "\tfixed mode: " DRM_MODE_FMT "\n", DRM_MODE_ARG(mode));
594 }
595 
596 static void intel_hdcp_info(struct seq_file *m,
597 			    struct intel_connector *intel_connector)
598 {
599 	bool hdcp_cap, hdcp2_cap;
600 
601 	hdcp_cap = intel_hdcp_capable(intel_connector);
602 	hdcp2_cap = intel_hdcp2_capable(intel_connector);
603 
604 	if (hdcp_cap)
605 		seq_puts(m, "HDCP1.4 ");
606 	if (hdcp2_cap)
607 		seq_puts(m, "HDCP2.2 ");
608 
609 	if (!hdcp_cap && !hdcp2_cap)
610 		seq_puts(m, "None");
611 
612 	seq_puts(m, "\n");
613 }
614 
615 static void intel_dp_info(struct seq_file *m,
616 			  struct intel_connector *intel_connector)
617 {
618 	struct intel_encoder *intel_encoder = intel_attached_encoder(intel_connector);
619 	struct intel_dp *intel_dp = enc_to_intel_dp(intel_encoder);
620 
621 	seq_printf(m, "\tDPCD rev: %x\n", intel_dp->dpcd[DP_DPCD_REV]);
622 	seq_printf(m, "\taudio support: %s\n", yesno(intel_dp->has_audio));
623 	if (intel_connector->base.connector_type == DRM_MODE_CONNECTOR_eDP)
624 		intel_panel_info(m, &intel_connector->panel);
625 
626 	drm_dp_downstream_debug(m, intel_dp->dpcd, intel_dp->downstream_ports,
627 				&intel_dp->aux);
628 	if (intel_connector->hdcp.shim) {
629 		seq_puts(m, "\tHDCP version: ");
630 		intel_hdcp_info(m, intel_connector);
631 	}
632 }
633 
634 static void intel_dp_mst_info(struct seq_file *m,
635 			      struct intel_connector *intel_connector)
636 {
637 	bool has_audio = intel_connector->port->has_audio;
638 
639 	seq_printf(m, "\taudio support: %s\n", yesno(has_audio));
640 }
641 
642 static void intel_hdmi_info(struct seq_file *m,
643 			    struct intel_connector *intel_connector)
644 {
645 	struct intel_encoder *intel_encoder = intel_attached_encoder(intel_connector);
646 	struct intel_hdmi *intel_hdmi = enc_to_intel_hdmi(intel_encoder);
647 
648 	seq_printf(m, "\taudio support: %s\n", yesno(intel_hdmi->has_audio));
649 	if (intel_connector->hdcp.shim) {
650 		seq_puts(m, "\tHDCP version: ");
651 		intel_hdcp_info(m, intel_connector);
652 	}
653 }
654 
655 static void intel_lvds_info(struct seq_file *m,
656 			    struct intel_connector *intel_connector)
657 {
658 	intel_panel_info(m, &intel_connector->panel);
659 }
660 
661 static void intel_connector_info(struct seq_file *m,
662 				 struct drm_connector *connector)
663 {
664 	struct intel_connector *intel_connector = to_intel_connector(connector);
665 	const struct drm_connector_state *conn_state = connector->state;
666 	struct intel_encoder *encoder =
667 		to_intel_encoder(conn_state->best_encoder);
668 	const struct drm_display_mode *mode;
669 
670 	seq_printf(m, "[CONNECTOR:%d:%s]: status: %s\n",
671 		   connector->base.id, connector->name,
672 		   drm_get_connector_status_name(connector->status));
673 
674 	if (connector->status == connector_status_disconnected)
675 		return;
676 
677 	seq_printf(m, "\tphysical dimensions: %dx%dmm\n",
678 		   connector->display_info.width_mm,
679 		   connector->display_info.height_mm);
680 	seq_printf(m, "\tsubpixel order: %s\n",
681 		   drm_get_subpixel_order_name(connector->display_info.subpixel_order));
682 	seq_printf(m, "\tCEA rev: %d\n", connector->display_info.cea_rev);
683 
684 	if (!encoder)
685 		return;
686 
687 	switch (connector->connector_type) {
688 	case DRM_MODE_CONNECTOR_DisplayPort:
689 	case DRM_MODE_CONNECTOR_eDP:
690 		if (encoder->type == INTEL_OUTPUT_DP_MST)
691 			intel_dp_mst_info(m, intel_connector);
692 		else
693 			intel_dp_info(m, intel_connector);
694 		break;
695 	case DRM_MODE_CONNECTOR_LVDS:
696 		if (encoder->type == INTEL_OUTPUT_LVDS)
697 			intel_lvds_info(m, intel_connector);
698 		break;
699 	case DRM_MODE_CONNECTOR_HDMIA:
700 		if (encoder->type == INTEL_OUTPUT_HDMI ||
701 		    encoder->type == INTEL_OUTPUT_DDI)
702 			intel_hdmi_info(m, intel_connector);
703 		break;
704 	default:
705 		break;
706 	}
707 
708 	seq_printf(m, "\tmodes:\n");
709 	list_for_each_entry(mode, &connector->modes, head)
710 		intel_seq_print_mode(m, 2, mode);
711 }
712 
713 static const char *plane_type(enum drm_plane_type type)
714 {
715 	switch (type) {
716 	case DRM_PLANE_TYPE_OVERLAY:
717 		return "OVL";
718 	case DRM_PLANE_TYPE_PRIMARY:
719 		return "PRI";
720 	case DRM_PLANE_TYPE_CURSOR:
721 		return "CUR";
722 	/*
723 	 * Deliberately omitting default: to generate compiler warnings
724 	 * when a new drm_plane_type gets added.
725 	 */
726 	}
727 
728 	return "unknown";
729 }
730 
731 static void plane_rotation(char *buf, size_t bufsize, unsigned int rotation)
732 {
733 	/*
734 	 * According to doc only one DRM_MODE_ROTATE_ is allowed but this
735 	 * will print them all to visualize if the values are misused
736 	 */
737 	snprintf(buf, bufsize,
738 		 "%s%s%s%s%s%s(0x%08x)",
739 		 (rotation & DRM_MODE_ROTATE_0) ? "0 " : "",
740 		 (rotation & DRM_MODE_ROTATE_90) ? "90 " : "",
741 		 (rotation & DRM_MODE_ROTATE_180) ? "180 " : "",
742 		 (rotation & DRM_MODE_ROTATE_270) ? "270 " : "",
743 		 (rotation & DRM_MODE_REFLECT_X) ? "FLIPX " : "",
744 		 (rotation & DRM_MODE_REFLECT_Y) ? "FLIPY " : "",
745 		 rotation);
746 }
747 
748 static void intel_plane_uapi_info(struct seq_file *m, struct intel_plane *plane)
749 {
750 	const struct intel_plane_state *plane_state =
751 		to_intel_plane_state(plane->base.state);
752 	const struct drm_framebuffer *fb = plane_state->uapi.fb;
753 	struct drm_format_name_buf format_name;
754 	struct drm_rect src, dst;
755 	char rot_str[48];
756 
757 	src = drm_plane_state_src(&plane_state->uapi);
758 	dst = drm_plane_state_dest(&plane_state->uapi);
759 
760 	if (fb)
761 		drm_get_format_name(fb->format->format, &format_name);
762 
763 	plane_rotation(rot_str, sizeof(rot_str),
764 		       plane_state->uapi.rotation);
765 
766 	seq_printf(m, "\t\tuapi: fb=%d,%s,%dx%d, src=" DRM_RECT_FP_FMT ", dst=" DRM_RECT_FMT ", rotation=%s\n",
767 		   fb ? fb->base.id : 0, fb ? format_name.str : "n/a",
768 		   fb ? fb->width : 0, fb ? fb->height : 0,
769 		   DRM_RECT_FP_ARG(&src),
770 		   DRM_RECT_ARG(&dst),
771 		   rot_str);
772 }
773 
774 static void intel_plane_hw_info(struct seq_file *m, struct intel_plane *plane)
775 {
776 	const struct intel_plane_state *plane_state =
777 		to_intel_plane_state(plane->base.state);
778 	const struct drm_framebuffer *fb = plane_state->hw.fb;
779 	struct drm_format_name_buf format_name;
780 	char rot_str[48];
781 
782 	if (!fb)
783 		return;
784 
785 	drm_get_format_name(fb->format->format, &format_name);
786 
787 	plane_rotation(rot_str, sizeof(rot_str),
788 		       plane_state->hw.rotation);
789 
790 	seq_printf(m, "\t\thw: fb=%d,%s,%dx%d, visible=%s, src=" DRM_RECT_FP_FMT ", dst=" DRM_RECT_FMT ", rotation=%s\n",
791 		   fb->base.id, format_name.str,
792 		   fb->width, fb->height,
793 		   yesno(plane_state->uapi.visible),
794 		   DRM_RECT_FP_ARG(&plane_state->uapi.src),
795 		   DRM_RECT_ARG(&plane_state->uapi.dst),
796 		   rot_str);
797 }
798 
799 static void intel_plane_info(struct seq_file *m, struct intel_crtc *crtc)
800 {
801 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
802 	struct intel_plane *plane;
803 
804 	for_each_intel_plane_on_crtc(&dev_priv->drm, crtc, plane) {
805 		seq_printf(m, "\t[PLANE:%d:%s]: type=%s\n",
806 			   plane->base.base.id, plane->base.name,
807 			   plane_type(plane->base.type));
808 		intel_plane_uapi_info(m, plane);
809 		intel_plane_hw_info(m, plane);
810 	}
811 }
812 
813 static void intel_scaler_info(struct seq_file *m, struct intel_crtc *crtc)
814 {
815 	const struct intel_crtc_state *crtc_state =
816 		to_intel_crtc_state(crtc->base.state);
817 	int num_scalers = crtc->num_scalers;
818 	int i;
819 
820 	/* Not all platformas have a scaler */
821 	if (num_scalers) {
822 		seq_printf(m, "\tnum_scalers=%d, scaler_users=%x scaler_id=%d",
823 			   num_scalers,
824 			   crtc_state->scaler_state.scaler_users,
825 			   crtc_state->scaler_state.scaler_id);
826 
827 		for (i = 0; i < num_scalers; i++) {
828 			const struct intel_scaler *sc =
829 				&crtc_state->scaler_state.scalers[i];
830 
831 			seq_printf(m, ", scalers[%d]: use=%s, mode=%x",
832 				   i, yesno(sc->in_use), sc->mode);
833 		}
834 		seq_puts(m, "\n");
835 	} else {
836 		seq_puts(m, "\tNo scalers available on this platform\n");
837 	}
838 }
839 
840 static void intel_crtc_info(struct seq_file *m, struct intel_crtc *crtc)
841 {
842 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
843 	const struct intel_crtc_state *crtc_state =
844 		to_intel_crtc_state(crtc->base.state);
845 	struct intel_encoder *encoder;
846 
847 	seq_printf(m, "[CRTC:%d:%s]:\n",
848 		   crtc->base.base.id, crtc->base.name);
849 
850 	seq_printf(m, "\tuapi: enable=%s, active=%s, mode=" DRM_MODE_FMT "\n",
851 		   yesno(crtc_state->uapi.enable),
852 		   yesno(crtc_state->uapi.active),
853 		   DRM_MODE_ARG(&crtc_state->uapi.mode));
854 
855 	if (crtc_state->hw.enable) {
856 		seq_printf(m, "\thw: active=%s, adjusted_mode=" DRM_MODE_FMT "\n",
857 			   yesno(crtc_state->hw.active),
858 			   DRM_MODE_ARG(&crtc_state->hw.adjusted_mode));
859 
860 		seq_printf(m, "\tpipe src size=%dx%d, dither=%s, bpp=%d\n",
861 			   crtc_state->pipe_src_w, crtc_state->pipe_src_h,
862 			   yesno(crtc_state->dither), crtc_state->pipe_bpp);
863 
864 		intel_scaler_info(m, crtc);
865 	}
866 
867 	for_each_intel_encoder_mask(&dev_priv->drm, encoder,
868 				    crtc_state->uapi.encoder_mask)
869 		intel_encoder_info(m, crtc, encoder);
870 
871 	intel_plane_info(m, crtc);
872 
873 	seq_printf(m, "\tunderrun reporting: cpu=%s pch=%s\n",
874 		   yesno(!crtc->cpu_fifo_underrun_disabled),
875 		   yesno(!crtc->pch_fifo_underrun_disabled));
876 }
877 
878 static int i915_display_info(struct seq_file *m, void *unused)
879 {
880 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
881 	struct drm_device *dev = &dev_priv->drm;
882 	struct intel_crtc *crtc;
883 	struct drm_connector *connector;
884 	struct drm_connector_list_iter conn_iter;
885 	intel_wakeref_t wakeref;
886 
887 	wakeref = intel_runtime_pm_get(&dev_priv->runtime_pm);
888 
889 	drm_modeset_lock_all(dev);
890 
891 	seq_printf(m, "CRTC info\n");
892 	seq_printf(m, "---------\n");
893 	for_each_intel_crtc(dev, crtc)
894 		intel_crtc_info(m, crtc);
895 
896 	seq_printf(m, "\n");
897 	seq_printf(m, "Connector info\n");
898 	seq_printf(m, "--------------\n");
899 	drm_connector_list_iter_begin(dev, &conn_iter);
900 	drm_for_each_connector_iter(connector, &conn_iter)
901 		intel_connector_info(m, connector);
902 	drm_connector_list_iter_end(&conn_iter);
903 
904 	drm_modeset_unlock_all(dev);
905 
906 	intel_runtime_pm_put(&dev_priv->runtime_pm, wakeref);
907 
908 	return 0;
909 }
910 
911 static int i915_shared_dplls_info(struct seq_file *m, void *unused)
912 {
913 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
914 	struct drm_device *dev = &dev_priv->drm;
915 	int i;
916 
917 	drm_modeset_lock_all(dev);
918 
919 	seq_printf(m, "PLL refclks: non-SSC: %d kHz, SSC: %d kHz\n",
920 		   dev_priv->dpll.ref_clks.nssc,
921 		   dev_priv->dpll.ref_clks.ssc);
922 
923 	for (i = 0; i < dev_priv->dpll.num_shared_dpll; i++) {
924 		struct intel_shared_dpll *pll = &dev_priv->dpll.shared_dplls[i];
925 
926 		seq_printf(m, "DPLL%i: %s, id: %i\n", i, pll->info->name,
927 			   pll->info->id);
928 		seq_printf(m, " crtc_mask: 0x%08x, active: 0x%x, on: %s\n",
929 			   pll->state.crtc_mask, pll->active_mask, yesno(pll->on));
930 		seq_printf(m, " tracked hardware state:\n");
931 		seq_printf(m, " dpll:    0x%08x\n", pll->state.hw_state.dpll);
932 		seq_printf(m, " dpll_md: 0x%08x\n",
933 			   pll->state.hw_state.dpll_md);
934 		seq_printf(m, " fp0:     0x%08x\n", pll->state.hw_state.fp0);
935 		seq_printf(m, " fp1:     0x%08x\n", pll->state.hw_state.fp1);
936 		seq_printf(m, " wrpll:   0x%08x\n", pll->state.hw_state.wrpll);
937 		seq_printf(m, " cfgcr0:  0x%08x\n", pll->state.hw_state.cfgcr0);
938 		seq_printf(m, " cfgcr1:  0x%08x\n", pll->state.hw_state.cfgcr1);
939 		seq_printf(m, " mg_refclkin_ctl:        0x%08x\n",
940 			   pll->state.hw_state.mg_refclkin_ctl);
941 		seq_printf(m, " mg_clktop2_coreclkctl1: 0x%08x\n",
942 			   pll->state.hw_state.mg_clktop2_coreclkctl1);
943 		seq_printf(m, " mg_clktop2_hsclkctl:    0x%08x\n",
944 			   pll->state.hw_state.mg_clktop2_hsclkctl);
945 		seq_printf(m, " mg_pll_div0:  0x%08x\n",
946 			   pll->state.hw_state.mg_pll_div0);
947 		seq_printf(m, " mg_pll_div1:  0x%08x\n",
948 			   pll->state.hw_state.mg_pll_div1);
949 		seq_printf(m, " mg_pll_lf:    0x%08x\n",
950 			   pll->state.hw_state.mg_pll_lf);
951 		seq_printf(m, " mg_pll_frac_lock: 0x%08x\n",
952 			   pll->state.hw_state.mg_pll_frac_lock);
953 		seq_printf(m, " mg_pll_ssc:   0x%08x\n",
954 			   pll->state.hw_state.mg_pll_ssc);
955 		seq_printf(m, " mg_pll_bias:  0x%08x\n",
956 			   pll->state.hw_state.mg_pll_bias);
957 		seq_printf(m, " mg_pll_tdc_coldst_bias: 0x%08x\n",
958 			   pll->state.hw_state.mg_pll_tdc_coldst_bias);
959 	}
960 	drm_modeset_unlock_all(dev);
961 
962 	return 0;
963 }
964 
965 static int i915_ipc_status_show(struct seq_file *m, void *data)
966 {
967 	struct drm_i915_private *dev_priv = m->private;
968 
969 	seq_printf(m, "Isochronous Priority Control: %s\n",
970 			yesno(dev_priv->ipc_enabled));
971 	return 0;
972 }
973 
974 static int i915_ipc_status_open(struct inode *inode, struct file *file)
975 {
976 	struct drm_i915_private *dev_priv = inode->i_private;
977 
978 	if (!HAS_IPC(dev_priv))
979 		return -ENODEV;
980 
981 	return single_open(file, i915_ipc_status_show, dev_priv);
982 }
983 
984 static ssize_t i915_ipc_status_write(struct file *file, const char __user *ubuf,
985 				     size_t len, loff_t *offp)
986 {
987 	struct seq_file *m = file->private_data;
988 	struct drm_i915_private *dev_priv = m->private;
989 	intel_wakeref_t wakeref;
990 	bool enable;
991 	int ret;
992 
993 	ret = kstrtobool_from_user(ubuf, len, &enable);
994 	if (ret < 0)
995 		return ret;
996 
997 	with_intel_runtime_pm(&dev_priv->runtime_pm, wakeref) {
998 		if (!dev_priv->ipc_enabled && enable)
999 			drm_info(&dev_priv->drm,
1000 				 "Enabling IPC: WM will be proper only after next commit\n");
1001 		dev_priv->wm.distrust_bios_wm = true;
1002 		dev_priv->ipc_enabled = enable;
1003 		intel_enable_ipc(dev_priv);
1004 	}
1005 
1006 	return len;
1007 }
1008 
1009 static const struct file_operations i915_ipc_status_fops = {
1010 	.owner = THIS_MODULE,
1011 	.open = i915_ipc_status_open,
1012 	.read = seq_read,
1013 	.llseek = seq_lseek,
1014 	.release = single_release,
1015 	.write = i915_ipc_status_write
1016 };
1017 
1018 static int i915_ddb_info(struct seq_file *m, void *unused)
1019 {
1020 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
1021 	struct drm_device *dev = &dev_priv->drm;
1022 	struct skl_ddb_entry *entry;
1023 	struct intel_crtc *crtc;
1024 
1025 	if (INTEL_GEN(dev_priv) < 9)
1026 		return -ENODEV;
1027 
1028 	drm_modeset_lock_all(dev);
1029 
1030 	seq_printf(m, "%-15s%8s%8s%8s\n", "", "Start", "End", "Size");
1031 
1032 	for_each_intel_crtc(&dev_priv->drm, crtc) {
1033 		struct intel_crtc_state *crtc_state =
1034 			to_intel_crtc_state(crtc->base.state);
1035 		enum pipe pipe = crtc->pipe;
1036 		enum plane_id plane_id;
1037 
1038 		seq_printf(m, "Pipe %c\n", pipe_name(pipe));
1039 
1040 		for_each_plane_id_on_crtc(crtc, plane_id) {
1041 			entry = &crtc_state->wm.skl.plane_ddb_y[plane_id];
1042 			seq_printf(m, "  Plane%-8d%8u%8u%8u\n", plane_id + 1,
1043 				   entry->start, entry->end,
1044 				   skl_ddb_entry_size(entry));
1045 		}
1046 
1047 		entry = &crtc_state->wm.skl.plane_ddb_y[PLANE_CURSOR];
1048 		seq_printf(m, "  %-13s%8u%8u%8u\n", "Cursor", entry->start,
1049 			   entry->end, skl_ddb_entry_size(entry));
1050 	}
1051 
1052 	drm_modeset_unlock_all(dev);
1053 
1054 	return 0;
1055 }
1056 
1057 static void drrs_status_per_crtc(struct seq_file *m,
1058 				 struct drm_device *dev,
1059 				 struct intel_crtc *intel_crtc)
1060 {
1061 	struct drm_i915_private *dev_priv = to_i915(dev);
1062 	struct i915_drrs *drrs = &dev_priv->drrs;
1063 	int vrefresh = 0;
1064 	struct drm_connector *connector;
1065 	struct drm_connector_list_iter conn_iter;
1066 
1067 	drm_connector_list_iter_begin(dev, &conn_iter);
1068 	drm_for_each_connector_iter(connector, &conn_iter) {
1069 		if (connector->state->crtc != &intel_crtc->base)
1070 			continue;
1071 
1072 		seq_printf(m, "%s:\n", connector->name);
1073 	}
1074 	drm_connector_list_iter_end(&conn_iter);
1075 
1076 	seq_puts(m, "\n");
1077 
1078 	if (to_intel_crtc_state(intel_crtc->base.state)->has_drrs) {
1079 		struct intel_panel *panel;
1080 
1081 		mutex_lock(&drrs->mutex);
1082 		/* DRRS Supported */
1083 		seq_puts(m, "\tDRRS Supported: Yes\n");
1084 
1085 		/* disable_drrs() will make drrs->dp NULL */
1086 		if (!drrs->dp) {
1087 			seq_puts(m, "Idleness DRRS: Disabled\n");
1088 			if (dev_priv->psr.enabled)
1089 				seq_puts(m,
1090 				"\tAs PSR is enabled, DRRS is not enabled\n");
1091 			mutex_unlock(&drrs->mutex);
1092 			return;
1093 		}
1094 
1095 		panel = &drrs->dp->attached_connector->panel;
1096 		seq_printf(m, "\t\tBusy_frontbuffer_bits: 0x%X",
1097 					drrs->busy_frontbuffer_bits);
1098 
1099 		seq_puts(m, "\n\t\t");
1100 		if (drrs->refresh_rate_type == DRRS_HIGH_RR) {
1101 			seq_puts(m, "DRRS_State: DRRS_HIGH_RR\n");
1102 			vrefresh = drm_mode_vrefresh(panel->fixed_mode);
1103 		} else if (drrs->refresh_rate_type == DRRS_LOW_RR) {
1104 			seq_puts(m, "DRRS_State: DRRS_LOW_RR\n");
1105 			vrefresh = drm_mode_vrefresh(panel->downclock_mode);
1106 		} else {
1107 			seq_printf(m, "DRRS_State: Unknown(%d)\n",
1108 						drrs->refresh_rate_type);
1109 			mutex_unlock(&drrs->mutex);
1110 			return;
1111 		}
1112 		seq_printf(m, "\t\tVrefresh: %d", vrefresh);
1113 
1114 		seq_puts(m, "\n\t\t");
1115 		mutex_unlock(&drrs->mutex);
1116 	} else {
1117 		/* DRRS not supported. Print the VBT parameter*/
1118 		seq_puts(m, "\tDRRS Supported : No");
1119 	}
1120 	seq_puts(m, "\n");
1121 }
1122 
1123 static int i915_drrs_status(struct seq_file *m, void *unused)
1124 {
1125 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
1126 	struct drm_device *dev = &dev_priv->drm;
1127 	struct intel_crtc *intel_crtc;
1128 	int active_crtc_cnt = 0;
1129 
1130 	drm_modeset_lock_all(dev);
1131 	for_each_intel_crtc(dev, intel_crtc) {
1132 		if (intel_crtc->base.state->active) {
1133 			active_crtc_cnt++;
1134 			seq_printf(m, "\nCRTC %d:  ", active_crtc_cnt);
1135 
1136 			drrs_status_per_crtc(m, dev, intel_crtc);
1137 		}
1138 	}
1139 	drm_modeset_unlock_all(dev);
1140 
1141 	if (!active_crtc_cnt)
1142 		seq_puts(m, "No active crtc found\n");
1143 
1144 	return 0;
1145 }
1146 
1147 #define LPSP_STATUS(COND) (COND ? seq_puts(m, "LPSP: enabled\n") : \
1148 				seq_puts(m, "LPSP: disabled\n"))
1149 
1150 static bool
1151 intel_lpsp_power_well_enabled(struct drm_i915_private *i915,
1152 			      enum i915_power_well_id power_well_id)
1153 {
1154 	intel_wakeref_t wakeref;
1155 	bool is_enabled;
1156 
1157 	wakeref = intel_runtime_pm_get(&i915->runtime_pm);
1158 	is_enabled = intel_display_power_well_is_enabled(i915,
1159 							 power_well_id);
1160 	intel_runtime_pm_put(&i915->runtime_pm, wakeref);
1161 
1162 	return is_enabled;
1163 }
1164 
1165 static int i915_lpsp_status(struct seq_file *m, void *unused)
1166 {
1167 	struct drm_i915_private *i915 = node_to_i915(m->private);
1168 
1169 	switch (INTEL_GEN(i915)) {
1170 	case 12:
1171 	case 11:
1172 		LPSP_STATUS(!intel_lpsp_power_well_enabled(i915, ICL_DISP_PW_3));
1173 		break;
1174 	case 10:
1175 	case 9:
1176 		LPSP_STATUS(!intel_lpsp_power_well_enabled(i915, SKL_DISP_PW_2));
1177 		break;
1178 	default:
1179 		/*
1180 		 * Apart from HASWELL/BROADWELL other legacy platform doesn't
1181 		 * support lpsp.
1182 		 */
1183 		if (IS_HASWELL(i915) || IS_BROADWELL(i915))
1184 			LPSP_STATUS(!intel_lpsp_power_well_enabled(i915, HSW_DISP_PW_GLOBAL));
1185 		else
1186 			seq_puts(m, "LPSP: not supported\n");
1187 	}
1188 
1189 	return 0;
1190 }
1191 
1192 static int i915_dp_mst_info(struct seq_file *m, void *unused)
1193 {
1194 	struct drm_i915_private *dev_priv = node_to_i915(m->private);
1195 	struct drm_device *dev = &dev_priv->drm;
1196 	struct intel_encoder *intel_encoder;
1197 	struct intel_digital_port *dig_port;
1198 	struct drm_connector *connector;
1199 	struct drm_connector_list_iter conn_iter;
1200 
1201 	drm_connector_list_iter_begin(dev, &conn_iter);
1202 	drm_for_each_connector_iter(connector, &conn_iter) {
1203 		if (connector->connector_type != DRM_MODE_CONNECTOR_DisplayPort)
1204 			continue;
1205 
1206 		intel_encoder = intel_attached_encoder(to_intel_connector(connector));
1207 		if (!intel_encoder || intel_encoder->type == INTEL_OUTPUT_DP_MST)
1208 			continue;
1209 
1210 		dig_port = enc_to_dig_port(intel_encoder);
1211 		if (!dig_port->dp.can_mst)
1212 			continue;
1213 
1214 		seq_printf(m, "MST Source Port [ENCODER:%d:%s]\n",
1215 			   dig_port->base.base.base.id,
1216 			   dig_port->base.base.name);
1217 		drm_dp_mst_dump_topology(m, &dig_port->dp.mst_mgr);
1218 	}
1219 	drm_connector_list_iter_end(&conn_iter);
1220 
1221 	return 0;
1222 }
1223 
1224 static ssize_t i915_displayport_test_active_write(struct file *file,
1225 						  const char __user *ubuf,
1226 						  size_t len, loff_t *offp)
1227 {
1228 	char *input_buffer;
1229 	int status = 0;
1230 	struct drm_device *dev;
1231 	struct drm_connector *connector;
1232 	struct drm_connector_list_iter conn_iter;
1233 	struct intel_dp *intel_dp;
1234 	int val = 0;
1235 
1236 	dev = ((struct seq_file *)file->private_data)->private;
1237 
1238 	if (len == 0)
1239 		return 0;
1240 
1241 	input_buffer = memdup_user_nul(ubuf, len);
1242 	if (IS_ERR(input_buffer))
1243 		return PTR_ERR(input_buffer);
1244 
1245 	drm_dbg(&to_i915(dev)->drm,
1246 		"Copied %d bytes from user\n", (unsigned int)len);
1247 
1248 	drm_connector_list_iter_begin(dev, &conn_iter);
1249 	drm_for_each_connector_iter(connector, &conn_iter) {
1250 		struct intel_encoder *encoder;
1251 
1252 		if (connector->connector_type !=
1253 		    DRM_MODE_CONNECTOR_DisplayPort)
1254 			continue;
1255 
1256 		encoder = to_intel_encoder(connector->encoder);
1257 		if (encoder && encoder->type == INTEL_OUTPUT_DP_MST)
1258 			continue;
1259 
1260 		if (encoder && connector->status == connector_status_connected) {
1261 			intel_dp = enc_to_intel_dp(encoder);
1262 			status = kstrtoint(input_buffer, 10, &val);
1263 			if (status < 0)
1264 				break;
1265 			drm_dbg(&to_i915(dev)->drm,
1266 				"Got %d for test active\n", val);
1267 			/* To prevent erroneous activation of the compliance
1268 			 * testing code, only accept an actual value of 1 here
1269 			 */
1270 			if (val == 1)
1271 				intel_dp->compliance.test_active = true;
1272 			else
1273 				intel_dp->compliance.test_active = false;
1274 		}
1275 	}
1276 	drm_connector_list_iter_end(&conn_iter);
1277 	kfree(input_buffer);
1278 	if (status < 0)
1279 		return status;
1280 
1281 	*offp += len;
1282 	return len;
1283 }
1284 
1285 static int i915_displayport_test_active_show(struct seq_file *m, void *data)
1286 {
1287 	struct drm_i915_private *dev_priv = m->private;
1288 	struct drm_device *dev = &dev_priv->drm;
1289 	struct drm_connector *connector;
1290 	struct drm_connector_list_iter conn_iter;
1291 	struct intel_dp *intel_dp;
1292 
1293 	drm_connector_list_iter_begin(dev, &conn_iter);
1294 	drm_for_each_connector_iter(connector, &conn_iter) {
1295 		struct intel_encoder *encoder;
1296 
1297 		if (connector->connector_type !=
1298 		    DRM_MODE_CONNECTOR_DisplayPort)
1299 			continue;
1300 
1301 		encoder = to_intel_encoder(connector->encoder);
1302 		if (encoder && encoder->type == INTEL_OUTPUT_DP_MST)
1303 			continue;
1304 
1305 		if (encoder && connector->status == connector_status_connected) {
1306 			intel_dp = enc_to_intel_dp(encoder);
1307 			if (intel_dp->compliance.test_active)
1308 				seq_puts(m, "1");
1309 			else
1310 				seq_puts(m, "0");
1311 		} else
1312 			seq_puts(m, "0");
1313 	}
1314 	drm_connector_list_iter_end(&conn_iter);
1315 
1316 	return 0;
1317 }
1318 
1319 static int i915_displayport_test_active_open(struct inode *inode,
1320 					     struct file *file)
1321 {
1322 	return single_open(file, i915_displayport_test_active_show,
1323 			   inode->i_private);
1324 }
1325 
1326 static const struct file_operations i915_displayport_test_active_fops = {
1327 	.owner = THIS_MODULE,
1328 	.open = i915_displayport_test_active_open,
1329 	.read = seq_read,
1330 	.llseek = seq_lseek,
1331 	.release = single_release,
1332 	.write = i915_displayport_test_active_write
1333 };
1334 
1335 static int i915_displayport_test_data_show(struct seq_file *m, void *data)
1336 {
1337 	struct drm_i915_private *dev_priv = m->private;
1338 	struct drm_device *dev = &dev_priv->drm;
1339 	struct drm_connector *connector;
1340 	struct drm_connector_list_iter conn_iter;
1341 	struct intel_dp *intel_dp;
1342 
1343 	drm_connector_list_iter_begin(dev, &conn_iter);
1344 	drm_for_each_connector_iter(connector, &conn_iter) {
1345 		struct intel_encoder *encoder;
1346 
1347 		if (connector->connector_type !=
1348 		    DRM_MODE_CONNECTOR_DisplayPort)
1349 			continue;
1350 
1351 		encoder = to_intel_encoder(connector->encoder);
1352 		if (encoder && encoder->type == INTEL_OUTPUT_DP_MST)
1353 			continue;
1354 
1355 		if (encoder && connector->status == connector_status_connected) {
1356 			intel_dp = enc_to_intel_dp(encoder);
1357 			if (intel_dp->compliance.test_type ==
1358 			    DP_TEST_LINK_EDID_READ)
1359 				seq_printf(m, "%lx",
1360 					   intel_dp->compliance.test_data.edid);
1361 			else if (intel_dp->compliance.test_type ==
1362 				 DP_TEST_LINK_VIDEO_PATTERN) {
1363 				seq_printf(m, "hdisplay: %d\n",
1364 					   intel_dp->compliance.test_data.hdisplay);
1365 				seq_printf(m, "vdisplay: %d\n",
1366 					   intel_dp->compliance.test_data.vdisplay);
1367 				seq_printf(m, "bpc: %u\n",
1368 					   intel_dp->compliance.test_data.bpc);
1369 			} else if (intel_dp->compliance.test_type ==
1370 				   DP_TEST_LINK_PHY_TEST_PATTERN) {
1371 				seq_printf(m, "pattern: %d\n",
1372 					   intel_dp->compliance.test_data.phytest.phy_pattern);
1373 				seq_printf(m, "Number of lanes: %d\n",
1374 					   intel_dp->compliance.test_data.phytest.num_lanes);
1375 				seq_printf(m, "Link Rate: %d\n",
1376 					   intel_dp->compliance.test_data.phytest.link_rate);
1377 				seq_printf(m, "level: %02x\n",
1378 					   intel_dp->train_set[0]);
1379 			}
1380 		} else
1381 			seq_puts(m, "0");
1382 	}
1383 	drm_connector_list_iter_end(&conn_iter);
1384 
1385 	return 0;
1386 }
1387 DEFINE_SHOW_ATTRIBUTE(i915_displayport_test_data);
1388 
1389 static int i915_displayport_test_type_show(struct seq_file *m, void *data)
1390 {
1391 	struct drm_i915_private *dev_priv = m->private;
1392 	struct drm_device *dev = &dev_priv->drm;
1393 	struct drm_connector *connector;
1394 	struct drm_connector_list_iter conn_iter;
1395 	struct intel_dp *intel_dp;
1396 
1397 	drm_connector_list_iter_begin(dev, &conn_iter);
1398 	drm_for_each_connector_iter(connector, &conn_iter) {
1399 		struct intel_encoder *encoder;
1400 
1401 		if (connector->connector_type !=
1402 		    DRM_MODE_CONNECTOR_DisplayPort)
1403 			continue;
1404 
1405 		encoder = to_intel_encoder(connector->encoder);
1406 		if (encoder && encoder->type == INTEL_OUTPUT_DP_MST)
1407 			continue;
1408 
1409 		if (encoder && connector->status == connector_status_connected) {
1410 			intel_dp = enc_to_intel_dp(encoder);
1411 			seq_printf(m, "%02lx\n", intel_dp->compliance.test_type);
1412 		} else
1413 			seq_puts(m, "0");
1414 	}
1415 	drm_connector_list_iter_end(&conn_iter);
1416 
1417 	return 0;
1418 }
1419 DEFINE_SHOW_ATTRIBUTE(i915_displayport_test_type);
1420 
1421 static void wm_latency_show(struct seq_file *m, const u16 wm[8])
1422 {
1423 	struct drm_i915_private *dev_priv = m->private;
1424 	struct drm_device *dev = &dev_priv->drm;
1425 	int level;
1426 	int num_levels;
1427 
1428 	if (IS_CHERRYVIEW(dev_priv))
1429 		num_levels = 3;
1430 	else if (IS_VALLEYVIEW(dev_priv))
1431 		num_levels = 1;
1432 	else if (IS_G4X(dev_priv))
1433 		num_levels = 3;
1434 	else
1435 		num_levels = ilk_wm_max_level(dev_priv) + 1;
1436 
1437 	drm_modeset_lock_all(dev);
1438 
1439 	for (level = 0; level < num_levels; level++) {
1440 		unsigned int latency = wm[level];
1441 
1442 		/*
1443 		 * - WM1+ latency values in 0.5us units
1444 		 * - latencies are in us on gen9/vlv/chv
1445 		 */
1446 		if (INTEL_GEN(dev_priv) >= 9 ||
1447 		    IS_VALLEYVIEW(dev_priv) ||
1448 		    IS_CHERRYVIEW(dev_priv) ||
1449 		    IS_G4X(dev_priv))
1450 			latency *= 10;
1451 		else if (level > 0)
1452 			latency *= 5;
1453 
1454 		seq_printf(m, "WM%d %u (%u.%u usec)\n",
1455 			   level, wm[level], latency / 10, latency % 10);
1456 	}
1457 
1458 	drm_modeset_unlock_all(dev);
1459 }
1460 
1461 static int pri_wm_latency_show(struct seq_file *m, void *data)
1462 {
1463 	struct drm_i915_private *dev_priv = m->private;
1464 	const u16 *latencies;
1465 
1466 	if (INTEL_GEN(dev_priv) >= 9)
1467 		latencies = dev_priv->wm.skl_latency;
1468 	else
1469 		latencies = dev_priv->wm.pri_latency;
1470 
1471 	wm_latency_show(m, latencies);
1472 
1473 	return 0;
1474 }
1475 
1476 static int spr_wm_latency_show(struct seq_file *m, void *data)
1477 {
1478 	struct drm_i915_private *dev_priv = m->private;
1479 	const u16 *latencies;
1480 
1481 	if (INTEL_GEN(dev_priv) >= 9)
1482 		latencies = dev_priv->wm.skl_latency;
1483 	else
1484 		latencies = dev_priv->wm.spr_latency;
1485 
1486 	wm_latency_show(m, latencies);
1487 
1488 	return 0;
1489 }
1490 
1491 static int cur_wm_latency_show(struct seq_file *m, void *data)
1492 {
1493 	struct drm_i915_private *dev_priv = m->private;
1494 	const u16 *latencies;
1495 
1496 	if (INTEL_GEN(dev_priv) >= 9)
1497 		latencies = dev_priv->wm.skl_latency;
1498 	else
1499 		latencies = dev_priv->wm.cur_latency;
1500 
1501 	wm_latency_show(m, latencies);
1502 
1503 	return 0;
1504 }
1505 
1506 static int pri_wm_latency_open(struct inode *inode, struct file *file)
1507 {
1508 	struct drm_i915_private *dev_priv = inode->i_private;
1509 
1510 	if (INTEL_GEN(dev_priv) < 5 && !IS_G4X(dev_priv))
1511 		return -ENODEV;
1512 
1513 	return single_open(file, pri_wm_latency_show, dev_priv);
1514 }
1515 
1516 static int spr_wm_latency_open(struct inode *inode, struct file *file)
1517 {
1518 	struct drm_i915_private *dev_priv = inode->i_private;
1519 
1520 	if (HAS_GMCH(dev_priv))
1521 		return -ENODEV;
1522 
1523 	return single_open(file, spr_wm_latency_show, dev_priv);
1524 }
1525 
1526 static int cur_wm_latency_open(struct inode *inode, struct file *file)
1527 {
1528 	struct drm_i915_private *dev_priv = inode->i_private;
1529 
1530 	if (HAS_GMCH(dev_priv))
1531 		return -ENODEV;
1532 
1533 	return single_open(file, cur_wm_latency_show, dev_priv);
1534 }
1535 
1536 static ssize_t wm_latency_write(struct file *file, const char __user *ubuf,
1537 				size_t len, loff_t *offp, u16 wm[8])
1538 {
1539 	struct seq_file *m = file->private_data;
1540 	struct drm_i915_private *dev_priv = m->private;
1541 	struct drm_device *dev = &dev_priv->drm;
1542 	u16 new[8] = { 0 };
1543 	int num_levels;
1544 	int level;
1545 	int ret;
1546 	char tmp[32];
1547 
1548 	if (IS_CHERRYVIEW(dev_priv))
1549 		num_levels = 3;
1550 	else if (IS_VALLEYVIEW(dev_priv))
1551 		num_levels = 1;
1552 	else if (IS_G4X(dev_priv))
1553 		num_levels = 3;
1554 	else
1555 		num_levels = ilk_wm_max_level(dev_priv) + 1;
1556 
1557 	if (len >= sizeof(tmp))
1558 		return -EINVAL;
1559 
1560 	if (copy_from_user(tmp, ubuf, len))
1561 		return -EFAULT;
1562 
1563 	tmp[len] = '\0';
1564 
1565 	ret = sscanf(tmp, "%hu %hu %hu %hu %hu %hu %hu %hu",
1566 		     &new[0], &new[1], &new[2], &new[3],
1567 		     &new[4], &new[5], &new[6], &new[7]);
1568 	if (ret != num_levels)
1569 		return -EINVAL;
1570 
1571 	drm_modeset_lock_all(dev);
1572 
1573 	for (level = 0; level < num_levels; level++)
1574 		wm[level] = new[level];
1575 
1576 	drm_modeset_unlock_all(dev);
1577 
1578 	return len;
1579 }
1580 
1581 
1582 static ssize_t pri_wm_latency_write(struct file *file, const char __user *ubuf,
1583 				    size_t len, loff_t *offp)
1584 {
1585 	struct seq_file *m = file->private_data;
1586 	struct drm_i915_private *dev_priv = m->private;
1587 	u16 *latencies;
1588 
1589 	if (INTEL_GEN(dev_priv) >= 9)
1590 		latencies = dev_priv->wm.skl_latency;
1591 	else
1592 		latencies = dev_priv->wm.pri_latency;
1593 
1594 	return wm_latency_write(file, ubuf, len, offp, latencies);
1595 }
1596 
1597 static ssize_t spr_wm_latency_write(struct file *file, const char __user *ubuf,
1598 				    size_t len, loff_t *offp)
1599 {
1600 	struct seq_file *m = file->private_data;
1601 	struct drm_i915_private *dev_priv = m->private;
1602 	u16 *latencies;
1603 
1604 	if (INTEL_GEN(dev_priv) >= 9)
1605 		latencies = dev_priv->wm.skl_latency;
1606 	else
1607 		latencies = dev_priv->wm.spr_latency;
1608 
1609 	return wm_latency_write(file, ubuf, len, offp, latencies);
1610 }
1611 
1612 static ssize_t cur_wm_latency_write(struct file *file, const char __user *ubuf,
1613 				    size_t len, loff_t *offp)
1614 {
1615 	struct seq_file *m = file->private_data;
1616 	struct drm_i915_private *dev_priv = m->private;
1617 	u16 *latencies;
1618 
1619 	if (INTEL_GEN(dev_priv) >= 9)
1620 		latencies = dev_priv->wm.skl_latency;
1621 	else
1622 		latencies = dev_priv->wm.cur_latency;
1623 
1624 	return wm_latency_write(file, ubuf, len, offp, latencies);
1625 }
1626 
1627 static const struct file_operations i915_pri_wm_latency_fops = {
1628 	.owner = THIS_MODULE,
1629 	.open = pri_wm_latency_open,
1630 	.read = seq_read,
1631 	.llseek = seq_lseek,
1632 	.release = single_release,
1633 	.write = pri_wm_latency_write
1634 };
1635 
1636 static const struct file_operations i915_spr_wm_latency_fops = {
1637 	.owner = THIS_MODULE,
1638 	.open = spr_wm_latency_open,
1639 	.read = seq_read,
1640 	.llseek = seq_lseek,
1641 	.release = single_release,
1642 	.write = spr_wm_latency_write
1643 };
1644 
1645 static const struct file_operations i915_cur_wm_latency_fops = {
1646 	.owner = THIS_MODULE,
1647 	.open = cur_wm_latency_open,
1648 	.read = seq_read,
1649 	.llseek = seq_lseek,
1650 	.release = single_release,
1651 	.write = cur_wm_latency_write
1652 };
1653 
1654 static int i915_hpd_storm_ctl_show(struct seq_file *m, void *data)
1655 {
1656 	struct drm_i915_private *dev_priv = m->private;
1657 	struct i915_hotplug *hotplug = &dev_priv->hotplug;
1658 
1659 	/* Synchronize with everything first in case there's been an HPD
1660 	 * storm, but we haven't finished handling it in the kernel yet
1661 	 */
1662 	intel_synchronize_irq(dev_priv);
1663 	flush_work(&dev_priv->hotplug.dig_port_work);
1664 	flush_delayed_work(&dev_priv->hotplug.hotplug_work);
1665 
1666 	seq_printf(m, "Threshold: %d\n", hotplug->hpd_storm_threshold);
1667 	seq_printf(m, "Detected: %s\n",
1668 		   yesno(delayed_work_pending(&hotplug->reenable_work)));
1669 
1670 	return 0;
1671 }
1672 
1673 static ssize_t i915_hpd_storm_ctl_write(struct file *file,
1674 					const char __user *ubuf, size_t len,
1675 					loff_t *offp)
1676 {
1677 	struct seq_file *m = file->private_data;
1678 	struct drm_i915_private *dev_priv = m->private;
1679 	struct i915_hotplug *hotplug = &dev_priv->hotplug;
1680 	unsigned int new_threshold;
1681 	int i;
1682 	char *newline;
1683 	char tmp[16];
1684 
1685 	if (len >= sizeof(tmp))
1686 		return -EINVAL;
1687 
1688 	if (copy_from_user(tmp, ubuf, len))
1689 		return -EFAULT;
1690 
1691 	tmp[len] = '\0';
1692 
1693 	/* Strip newline, if any */
1694 	newline = strchr(tmp, '\n');
1695 	if (newline)
1696 		*newline = '\0';
1697 
1698 	if (strcmp(tmp, "reset") == 0)
1699 		new_threshold = HPD_STORM_DEFAULT_THRESHOLD;
1700 	else if (kstrtouint(tmp, 10, &new_threshold) != 0)
1701 		return -EINVAL;
1702 
1703 	if (new_threshold > 0)
1704 		drm_dbg_kms(&dev_priv->drm,
1705 			    "Setting HPD storm detection threshold to %d\n",
1706 			    new_threshold);
1707 	else
1708 		drm_dbg_kms(&dev_priv->drm, "Disabling HPD storm detection\n");
1709 
1710 	spin_lock_irq(&dev_priv->irq_lock);
1711 	hotplug->hpd_storm_threshold = new_threshold;
1712 	/* Reset the HPD storm stats so we don't accidentally trigger a storm */
1713 	for_each_hpd_pin(i)
1714 		hotplug->stats[i].count = 0;
1715 	spin_unlock_irq(&dev_priv->irq_lock);
1716 
1717 	/* Re-enable hpd immediately if we were in an irq storm */
1718 	flush_delayed_work(&dev_priv->hotplug.reenable_work);
1719 
1720 	return len;
1721 }
1722 
1723 static int i915_hpd_storm_ctl_open(struct inode *inode, struct file *file)
1724 {
1725 	return single_open(file, i915_hpd_storm_ctl_show, inode->i_private);
1726 }
1727 
1728 static const struct file_operations i915_hpd_storm_ctl_fops = {
1729 	.owner = THIS_MODULE,
1730 	.open = i915_hpd_storm_ctl_open,
1731 	.read = seq_read,
1732 	.llseek = seq_lseek,
1733 	.release = single_release,
1734 	.write = i915_hpd_storm_ctl_write
1735 };
1736 
1737 static int i915_hpd_short_storm_ctl_show(struct seq_file *m, void *data)
1738 {
1739 	struct drm_i915_private *dev_priv = m->private;
1740 
1741 	seq_printf(m, "Enabled: %s\n",
1742 		   yesno(dev_priv->hotplug.hpd_short_storm_enabled));
1743 
1744 	return 0;
1745 }
1746 
1747 static int
1748 i915_hpd_short_storm_ctl_open(struct inode *inode, struct file *file)
1749 {
1750 	return single_open(file, i915_hpd_short_storm_ctl_show,
1751 			   inode->i_private);
1752 }
1753 
1754 static ssize_t i915_hpd_short_storm_ctl_write(struct file *file,
1755 					      const char __user *ubuf,
1756 					      size_t len, loff_t *offp)
1757 {
1758 	struct seq_file *m = file->private_data;
1759 	struct drm_i915_private *dev_priv = m->private;
1760 	struct i915_hotplug *hotplug = &dev_priv->hotplug;
1761 	char *newline;
1762 	char tmp[16];
1763 	int i;
1764 	bool new_state;
1765 
1766 	if (len >= sizeof(tmp))
1767 		return -EINVAL;
1768 
1769 	if (copy_from_user(tmp, ubuf, len))
1770 		return -EFAULT;
1771 
1772 	tmp[len] = '\0';
1773 
1774 	/* Strip newline, if any */
1775 	newline = strchr(tmp, '\n');
1776 	if (newline)
1777 		*newline = '\0';
1778 
1779 	/* Reset to the "default" state for this system */
1780 	if (strcmp(tmp, "reset") == 0)
1781 		new_state = !HAS_DP_MST(dev_priv);
1782 	else if (kstrtobool(tmp, &new_state) != 0)
1783 		return -EINVAL;
1784 
1785 	drm_dbg_kms(&dev_priv->drm, "%sabling HPD short storm detection\n",
1786 		    new_state ? "En" : "Dis");
1787 
1788 	spin_lock_irq(&dev_priv->irq_lock);
1789 	hotplug->hpd_short_storm_enabled = new_state;
1790 	/* Reset the HPD storm stats so we don't accidentally trigger a storm */
1791 	for_each_hpd_pin(i)
1792 		hotplug->stats[i].count = 0;
1793 	spin_unlock_irq(&dev_priv->irq_lock);
1794 
1795 	/* Re-enable hpd immediately if we were in an irq storm */
1796 	flush_delayed_work(&dev_priv->hotplug.reenable_work);
1797 
1798 	return len;
1799 }
1800 
1801 static const struct file_operations i915_hpd_short_storm_ctl_fops = {
1802 	.owner = THIS_MODULE,
1803 	.open = i915_hpd_short_storm_ctl_open,
1804 	.read = seq_read,
1805 	.llseek = seq_lseek,
1806 	.release = single_release,
1807 	.write = i915_hpd_short_storm_ctl_write,
1808 };
1809 
1810 static int i915_drrs_ctl_set(void *data, u64 val)
1811 {
1812 	struct drm_i915_private *dev_priv = data;
1813 	struct drm_device *dev = &dev_priv->drm;
1814 	struct intel_crtc *crtc;
1815 
1816 	if (INTEL_GEN(dev_priv) < 7)
1817 		return -ENODEV;
1818 
1819 	for_each_intel_crtc(dev, crtc) {
1820 		struct drm_connector_list_iter conn_iter;
1821 		struct intel_crtc_state *crtc_state;
1822 		struct drm_connector *connector;
1823 		struct drm_crtc_commit *commit;
1824 		int ret;
1825 
1826 		ret = drm_modeset_lock_single_interruptible(&crtc->base.mutex);
1827 		if (ret)
1828 			return ret;
1829 
1830 		crtc_state = to_intel_crtc_state(crtc->base.state);
1831 
1832 		if (!crtc_state->hw.active ||
1833 		    !crtc_state->has_drrs)
1834 			goto out;
1835 
1836 		commit = crtc_state->uapi.commit;
1837 		if (commit) {
1838 			ret = wait_for_completion_interruptible(&commit->hw_done);
1839 			if (ret)
1840 				goto out;
1841 		}
1842 
1843 		drm_connector_list_iter_begin(dev, &conn_iter);
1844 		drm_for_each_connector_iter(connector, &conn_iter) {
1845 			struct intel_encoder *encoder;
1846 			struct intel_dp *intel_dp;
1847 
1848 			if (!(crtc_state->uapi.connector_mask &
1849 			      drm_connector_mask(connector)))
1850 				continue;
1851 
1852 			encoder = intel_attached_encoder(to_intel_connector(connector));
1853 			if (encoder->type != INTEL_OUTPUT_EDP)
1854 				continue;
1855 
1856 			drm_dbg(&dev_priv->drm,
1857 				"Manually %sabling DRRS. %llu\n",
1858 				val ? "en" : "dis", val);
1859 
1860 			intel_dp = enc_to_intel_dp(encoder);
1861 			if (val)
1862 				intel_edp_drrs_enable(intel_dp,
1863 						      crtc_state);
1864 			else
1865 				intel_edp_drrs_disable(intel_dp,
1866 						       crtc_state);
1867 		}
1868 		drm_connector_list_iter_end(&conn_iter);
1869 
1870 out:
1871 		drm_modeset_unlock(&crtc->base.mutex);
1872 		if (ret)
1873 			return ret;
1874 	}
1875 
1876 	return 0;
1877 }
1878 
1879 DEFINE_SIMPLE_ATTRIBUTE(i915_drrs_ctl_fops, NULL, i915_drrs_ctl_set, "%llu\n");
1880 
1881 static ssize_t
1882 i915_fifo_underrun_reset_write(struct file *filp,
1883 			       const char __user *ubuf,
1884 			       size_t cnt, loff_t *ppos)
1885 {
1886 	struct drm_i915_private *dev_priv = filp->private_data;
1887 	struct intel_crtc *intel_crtc;
1888 	struct drm_device *dev = &dev_priv->drm;
1889 	int ret;
1890 	bool reset;
1891 
1892 	ret = kstrtobool_from_user(ubuf, cnt, &reset);
1893 	if (ret)
1894 		return ret;
1895 
1896 	if (!reset)
1897 		return cnt;
1898 
1899 	for_each_intel_crtc(dev, intel_crtc) {
1900 		struct drm_crtc_commit *commit;
1901 		struct intel_crtc_state *crtc_state;
1902 
1903 		ret = drm_modeset_lock_single_interruptible(&intel_crtc->base.mutex);
1904 		if (ret)
1905 			return ret;
1906 
1907 		crtc_state = to_intel_crtc_state(intel_crtc->base.state);
1908 		commit = crtc_state->uapi.commit;
1909 		if (commit) {
1910 			ret = wait_for_completion_interruptible(&commit->hw_done);
1911 			if (!ret)
1912 				ret = wait_for_completion_interruptible(&commit->flip_done);
1913 		}
1914 
1915 		if (!ret && crtc_state->hw.active) {
1916 			drm_dbg_kms(&dev_priv->drm,
1917 				    "Re-arming FIFO underruns on pipe %c\n",
1918 				    pipe_name(intel_crtc->pipe));
1919 
1920 			intel_crtc_arm_fifo_underrun(intel_crtc, crtc_state);
1921 		}
1922 
1923 		drm_modeset_unlock(&intel_crtc->base.mutex);
1924 
1925 		if (ret)
1926 			return ret;
1927 	}
1928 
1929 	ret = intel_fbc_reset_underrun(dev_priv);
1930 	if (ret)
1931 		return ret;
1932 
1933 	return cnt;
1934 }
1935 
1936 static const struct file_operations i915_fifo_underrun_reset_ops = {
1937 	.owner = THIS_MODULE,
1938 	.open = simple_open,
1939 	.write = i915_fifo_underrun_reset_write,
1940 	.llseek = default_llseek,
1941 };
1942 
1943 static const struct drm_info_list intel_display_debugfs_list[] = {
1944 	{"i915_frontbuffer_tracking", i915_frontbuffer_tracking, 0},
1945 	{"i915_fbc_status", i915_fbc_status, 0},
1946 	{"i915_ips_status", i915_ips_status, 0},
1947 	{"i915_sr_status", i915_sr_status, 0},
1948 	{"i915_opregion", i915_opregion, 0},
1949 	{"i915_vbt", i915_vbt, 0},
1950 	{"i915_gem_framebuffer", i915_gem_framebuffer_info, 0},
1951 	{"i915_edp_psr_status", i915_edp_psr_status, 0},
1952 	{"i915_power_domain_info", i915_power_domain_info, 0},
1953 	{"i915_dmc_info", i915_dmc_info, 0},
1954 	{"i915_display_info", i915_display_info, 0},
1955 	{"i915_shared_dplls_info", i915_shared_dplls_info, 0},
1956 	{"i915_dp_mst_info", i915_dp_mst_info, 0},
1957 	{"i915_ddb_info", i915_ddb_info, 0},
1958 	{"i915_drrs_status", i915_drrs_status, 0},
1959 	{"i915_lpsp_status", i915_lpsp_status, 0},
1960 };
1961 
1962 static const struct {
1963 	const char *name;
1964 	const struct file_operations *fops;
1965 } intel_display_debugfs_files[] = {
1966 	{"i915_fifo_underrun_reset", &i915_fifo_underrun_reset_ops},
1967 	{"i915_pri_wm_latency", &i915_pri_wm_latency_fops},
1968 	{"i915_spr_wm_latency", &i915_spr_wm_latency_fops},
1969 	{"i915_cur_wm_latency", &i915_cur_wm_latency_fops},
1970 	{"i915_fbc_false_color", &i915_fbc_false_color_fops},
1971 	{"i915_dp_test_data", &i915_displayport_test_data_fops},
1972 	{"i915_dp_test_type", &i915_displayport_test_type_fops},
1973 	{"i915_dp_test_active", &i915_displayport_test_active_fops},
1974 	{"i915_hpd_storm_ctl", &i915_hpd_storm_ctl_fops},
1975 	{"i915_hpd_short_storm_ctl", &i915_hpd_short_storm_ctl_fops},
1976 	{"i915_ipc_status", &i915_ipc_status_fops},
1977 	{"i915_drrs_ctl", &i915_drrs_ctl_fops},
1978 	{"i915_edp_psr_debug", &i915_edp_psr_debug_fops},
1979 };
1980 
1981 void intel_display_debugfs_register(struct drm_i915_private *i915)
1982 {
1983 	struct drm_minor *minor = i915->drm.primary;
1984 	int i;
1985 
1986 	for (i = 0; i < ARRAY_SIZE(intel_display_debugfs_files); i++) {
1987 		debugfs_create_file(intel_display_debugfs_files[i].name,
1988 				    S_IRUGO | S_IWUSR,
1989 				    minor->debugfs_root,
1990 				    to_i915(minor->dev),
1991 				    intel_display_debugfs_files[i].fops);
1992 	}
1993 
1994 	drm_debugfs_create_files(intel_display_debugfs_list,
1995 				 ARRAY_SIZE(intel_display_debugfs_list),
1996 				 minor->debugfs_root, minor);
1997 }
1998 
1999 static int i915_panel_show(struct seq_file *m, void *data)
2000 {
2001 	struct drm_connector *connector = m->private;
2002 	struct intel_dp *intel_dp =
2003 		intel_attached_dp(to_intel_connector(connector));
2004 
2005 	if (connector->status != connector_status_connected)
2006 		return -ENODEV;
2007 
2008 	seq_printf(m, "Panel power up delay: %d\n",
2009 		   intel_dp->panel_power_up_delay);
2010 	seq_printf(m, "Panel power down delay: %d\n",
2011 		   intel_dp->panel_power_down_delay);
2012 	seq_printf(m, "Backlight on delay: %d\n",
2013 		   intel_dp->backlight_on_delay);
2014 	seq_printf(m, "Backlight off delay: %d\n",
2015 		   intel_dp->backlight_off_delay);
2016 
2017 	return 0;
2018 }
2019 DEFINE_SHOW_ATTRIBUTE(i915_panel);
2020 
2021 static int i915_hdcp_sink_capability_show(struct seq_file *m, void *data)
2022 {
2023 	struct drm_connector *connector = m->private;
2024 	struct intel_connector *intel_connector = to_intel_connector(connector);
2025 
2026 	if (connector->status != connector_status_connected)
2027 		return -ENODEV;
2028 
2029 	/* HDCP is supported by connector */
2030 	if (!intel_connector->hdcp.shim)
2031 		return -EINVAL;
2032 
2033 	seq_printf(m, "%s:%d HDCP version: ", connector->name,
2034 		   connector->base.id);
2035 	intel_hdcp_info(m, intel_connector);
2036 
2037 	return 0;
2038 }
2039 DEFINE_SHOW_ATTRIBUTE(i915_hdcp_sink_capability);
2040 
2041 #define LPSP_CAPABLE(COND) (COND ? seq_puts(m, "LPSP: capable\n") : \
2042 				seq_puts(m, "LPSP: incapable\n"))
2043 
2044 static int i915_lpsp_capability_show(struct seq_file *m, void *data)
2045 {
2046 	struct drm_connector *connector = m->private;
2047 	struct drm_i915_private *i915 = to_i915(connector->dev);
2048 	struct intel_encoder *encoder;
2049 
2050 	encoder = intel_attached_encoder(to_intel_connector(connector));
2051 	if (!encoder)
2052 		return -ENODEV;
2053 
2054 	if (connector->status != connector_status_connected)
2055 		return -ENODEV;
2056 
2057 	switch (INTEL_GEN(i915)) {
2058 	case 12:
2059 		/*
2060 		 * Actually TGL can drive LPSP on port till DDI_C
2061 		 * but there is no physical connected DDI_C on TGL sku's,
2062 		 * even driver is not initilizing DDI_C port for gen12.
2063 		 */
2064 		LPSP_CAPABLE(encoder->port <= PORT_B);
2065 		break;
2066 	case 11:
2067 		LPSP_CAPABLE(connector->connector_type == DRM_MODE_CONNECTOR_DSI ||
2068 			     connector->connector_type == DRM_MODE_CONNECTOR_eDP);
2069 		break;
2070 	case 10:
2071 	case 9:
2072 		LPSP_CAPABLE(encoder->port == PORT_A &&
2073 			     (connector->connector_type == DRM_MODE_CONNECTOR_DSI ||
2074 			     connector->connector_type == DRM_MODE_CONNECTOR_eDP  ||
2075 			     connector->connector_type == DRM_MODE_CONNECTOR_DisplayPort));
2076 		break;
2077 	default:
2078 		if (IS_HASWELL(i915) || IS_BROADWELL(i915))
2079 			LPSP_CAPABLE(connector->connector_type == DRM_MODE_CONNECTOR_eDP);
2080 	}
2081 
2082 	return 0;
2083 }
2084 DEFINE_SHOW_ATTRIBUTE(i915_lpsp_capability);
2085 
2086 static int i915_dsc_fec_support_show(struct seq_file *m, void *data)
2087 {
2088 	struct drm_connector *connector = m->private;
2089 	struct drm_device *dev = connector->dev;
2090 	struct drm_crtc *crtc;
2091 	struct intel_dp *intel_dp;
2092 	struct drm_modeset_acquire_ctx ctx;
2093 	struct intel_crtc_state *crtc_state = NULL;
2094 	int ret = 0;
2095 	bool try_again = false;
2096 
2097 	drm_modeset_acquire_init(&ctx, DRM_MODESET_ACQUIRE_INTERRUPTIBLE);
2098 
2099 	do {
2100 		try_again = false;
2101 		ret = drm_modeset_lock(&dev->mode_config.connection_mutex,
2102 				       &ctx);
2103 		if (ret) {
2104 			if (ret == -EDEADLK && !drm_modeset_backoff(&ctx)) {
2105 				try_again = true;
2106 				continue;
2107 			}
2108 			break;
2109 		}
2110 		crtc = connector->state->crtc;
2111 		if (connector->status != connector_status_connected || !crtc) {
2112 			ret = -ENODEV;
2113 			break;
2114 		}
2115 		ret = drm_modeset_lock(&crtc->mutex, &ctx);
2116 		if (ret == -EDEADLK) {
2117 			ret = drm_modeset_backoff(&ctx);
2118 			if (!ret) {
2119 				try_again = true;
2120 				continue;
2121 			}
2122 			break;
2123 		} else if (ret) {
2124 			break;
2125 		}
2126 		intel_dp = intel_attached_dp(to_intel_connector(connector));
2127 		crtc_state = to_intel_crtc_state(crtc->state);
2128 		seq_printf(m, "DSC_Enabled: %s\n",
2129 			   yesno(crtc_state->dsc.compression_enable));
2130 		seq_printf(m, "DSC_Sink_Support: %s\n",
2131 			   yesno(drm_dp_sink_supports_dsc(intel_dp->dsc_dpcd)));
2132 		seq_printf(m, "Force_DSC_Enable: %s\n",
2133 			   yesno(intel_dp->force_dsc_en));
2134 		if (!intel_dp_is_edp(intel_dp))
2135 			seq_printf(m, "FEC_Sink_Support: %s\n",
2136 				   yesno(drm_dp_sink_supports_fec(intel_dp->fec_capable)));
2137 	} while (try_again);
2138 
2139 	drm_modeset_drop_locks(&ctx);
2140 	drm_modeset_acquire_fini(&ctx);
2141 
2142 	return ret;
2143 }
2144 
2145 static ssize_t i915_dsc_fec_support_write(struct file *file,
2146 					  const char __user *ubuf,
2147 					  size_t len, loff_t *offp)
2148 {
2149 	bool dsc_enable = false;
2150 	int ret;
2151 	struct drm_connector *connector =
2152 		((struct seq_file *)file->private_data)->private;
2153 	struct intel_encoder *encoder = intel_attached_encoder(to_intel_connector(connector));
2154 	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2155 	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2156 
2157 	if (len == 0)
2158 		return 0;
2159 
2160 	drm_dbg(&i915->drm,
2161 		"Copied %zu bytes from user to force DSC\n", len);
2162 
2163 	ret = kstrtobool_from_user(ubuf, len, &dsc_enable);
2164 	if (ret < 0)
2165 		return ret;
2166 
2167 	drm_dbg(&i915->drm, "Got %s for DSC Enable\n",
2168 		(dsc_enable) ? "true" : "false");
2169 	intel_dp->force_dsc_en = dsc_enable;
2170 
2171 	*offp += len;
2172 	return len;
2173 }
2174 
2175 static int i915_dsc_fec_support_open(struct inode *inode,
2176 				     struct file *file)
2177 {
2178 	return single_open(file, i915_dsc_fec_support_show,
2179 			   inode->i_private);
2180 }
2181 
2182 static const struct file_operations i915_dsc_fec_support_fops = {
2183 	.owner = THIS_MODULE,
2184 	.open = i915_dsc_fec_support_open,
2185 	.read = seq_read,
2186 	.llseek = seq_lseek,
2187 	.release = single_release,
2188 	.write = i915_dsc_fec_support_write
2189 };
2190 
2191 /**
2192  * intel_connector_debugfs_add - add i915 specific connector debugfs files
2193  * @connector: pointer to a registered drm_connector
2194  *
2195  * Cleanup will be done by drm_connector_unregister() through a call to
2196  * drm_debugfs_connector_remove().
2197  *
2198  * Returns 0 on success, negative error codes on error.
2199  */
2200 int intel_connector_debugfs_add(struct drm_connector *connector)
2201 {
2202 	struct dentry *root = connector->debugfs_entry;
2203 	struct drm_i915_private *dev_priv = to_i915(connector->dev);
2204 
2205 	/* The connector must have been registered beforehands. */
2206 	if (!root)
2207 		return -ENODEV;
2208 
2209 	if (connector->connector_type == DRM_MODE_CONNECTOR_eDP) {
2210 		debugfs_create_file("i915_panel_timings", S_IRUGO, root,
2211 				    connector, &i915_panel_fops);
2212 		debugfs_create_file("i915_psr_sink_status", S_IRUGO, root,
2213 				    connector, &i915_psr_sink_status_fops);
2214 	}
2215 
2216 	if (connector->connector_type == DRM_MODE_CONNECTOR_DisplayPort ||
2217 	    connector->connector_type == DRM_MODE_CONNECTOR_HDMIA ||
2218 	    connector->connector_type == DRM_MODE_CONNECTOR_HDMIB) {
2219 		debugfs_create_file("i915_hdcp_sink_capability", S_IRUGO, root,
2220 				    connector, &i915_hdcp_sink_capability_fops);
2221 	}
2222 
2223 	if (INTEL_GEN(dev_priv) >= 10 &&
2224 	    ((connector->connector_type == DRM_MODE_CONNECTOR_DisplayPort &&
2225 	      !to_intel_connector(connector)->mst_port) ||
2226 	     connector->connector_type == DRM_MODE_CONNECTOR_eDP))
2227 		debugfs_create_file("i915_dsc_fec_support", S_IRUGO, root,
2228 				    connector, &i915_dsc_fec_support_fops);
2229 
2230 	/* Legacy panels doesn't lpsp on any platform */
2231 	if ((INTEL_GEN(dev_priv) >= 9 || IS_HASWELL(dev_priv) ||
2232 	     IS_BROADWELL(dev_priv)) &&
2233 	     (connector->connector_type == DRM_MODE_CONNECTOR_DSI ||
2234 	     connector->connector_type == DRM_MODE_CONNECTOR_eDP ||
2235 	     connector->connector_type == DRM_MODE_CONNECTOR_DisplayPort ||
2236 	     connector->connector_type == DRM_MODE_CONNECTOR_HDMIA ||
2237 	     connector->connector_type == DRM_MODE_CONNECTOR_HDMIB))
2238 		debugfs_create_file("i915_lpsp_capability", 0444, root,
2239 				    connector, &i915_lpsp_capability_fops);
2240 
2241 	return 0;
2242 }
2243