2 * Copyright © 2013 Intel Corporation
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:
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
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
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
23 * Author: Damien Lespiau <damien.lespiau@intel.com>
27 #include <linux/circ_buf.h>
28 #include <linux/ctype.h>
29 #include <linux/debugfs.h>
30 #include <linux/seq_file.h>
32 #include "intel_atomic.h"
33 #include "intel_display_types.h"
34 #include "intel_pipe_crc.h"
36 static const char * const pipe_crc_sources
[] = {
37 [INTEL_PIPE_CRC_SOURCE_NONE
] = "none",
38 [INTEL_PIPE_CRC_SOURCE_PLANE1
] = "plane1",
39 [INTEL_PIPE_CRC_SOURCE_PLANE2
] = "plane2",
40 [INTEL_PIPE_CRC_SOURCE_PLANE3
] = "plane3",
41 [INTEL_PIPE_CRC_SOURCE_PLANE4
] = "plane4",
42 [INTEL_PIPE_CRC_SOURCE_PLANE5
] = "plane5",
43 [INTEL_PIPE_CRC_SOURCE_PLANE6
] = "plane6",
44 [INTEL_PIPE_CRC_SOURCE_PLANE7
] = "plane7",
45 [INTEL_PIPE_CRC_SOURCE_PIPE
] = "pipe",
46 [INTEL_PIPE_CRC_SOURCE_TV
] = "TV",
47 [INTEL_PIPE_CRC_SOURCE_DP_B
] = "DP-B",
48 [INTEL_PIPE_CRC_SOURCE_DP_C
] = "DP-C",
49 [INTEL_PIPE_CRC_SOURCE_DP_D
] = "DP-D",
50 [INTEL_PIPE_CRC_SOURCE_AUTO
] = "auto",
53 static int i8xx_pipe_crc_ctl_reg(enum intel_pipe_crc_source
*source
,
56 if (*source
== INTEL_PIPE_CRC_SOURCE_AUTO
)
57 *source
= INTEL_PIPE_CRC_SOURCE_PIPE
;
60 case INTEL_PIPE_CRC_SOURCE_PIPE
:
61 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_INCLUDE_BORDER_I8XX
;
63 case INTEL_PIPE_CRC_SOURCE_NONE
:
73 static int i9xx_pipe_crc_auto_source(struct drm_i915_private
*dev_priv
,
75 enum intel_pipe_crc_source
*source
)
77 struct drm_device
*dev
= &dev_priv
->drm
;
78 struct intel_encoder
*encoder
;
79 struct intel_crtc
*crtc
;
80 struct intel_digital_port
*dig_port
;
83 *source
= INTEL_PIPE_CRC_SOURCE_PIPE
;
85 drm_modeset_lock_all(dev
);
86 for_each_intel_encoder(dev
, encoder
) {
87 if (!encoder
->base
.crtc
)
90 crtc
= to_intel_crtc(encoder
->base
.crtc
);
92 if (crtc
->pipe
!= pipe
)
95 switch (encoder
->type
) {
96 case INTEL_OUTPUT_TVOUT
:
97 *source
= INTEL_PIPE_CRC_SOURCE_TV
;
100 case INTEL_OUTPUT_EDP
:
101 dig_port
= enc_to_dig_port(encoder
);
102 switch (dig_port
->base
.port
) {
104 *source
= INTEL_PIPE_CRC_SOURCE_DP_B
;
107 *source
= INTEL_PIPE_CRC_SOURCE_DP_C
;
110 *source
= INTEL_PIPE_CRC_SOURCE_DP_D
;
113 WARN(1, "nonexisting DP port %c\n",
114 port_name(dig_port
->base
.port
));
122 drm_modeset_unlock_all(dev
);
127 static int vlv_pipe_crc_ctl_reg(struct drm_i915_private
*dev_priv
,
129 enum intel_pipe_crc_source
*source
,
132 bool need_stable_symbols
= false;
134 if (*source
== INTEL_PIPE_CRC_SOURCE_AUTO
) {
135 int ret
= i9xx_pipe_crc_auto_source(dev_priv
, pipe
, source
);
141 case INTEL_PIPE_CRC_SOURCE_PIPE
:
142 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PIPE_VLV
;
144 case INTEL_PIPE_CRC_SOURCE_DP_B
:
145 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_DP_B_VLV
;
146 need_stable_symbols
= true;
148 case INTEL_PIPE_CRC_SOURCE_DP_C
:
149 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_DP_C_VLV
;
150 need_stable_symbols
= true;
152 case INTEL_PIPE_CRC_SOURCE_DP_D
:
153 if (!IS_CHERRYVIEW(dev_priv
))
155 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_DP_D_VLV
;
156 need_stable_symbols
= true;
158 case INTEL_PIPE_CRC_SOURCE_NONE
:
166 * When the pipe CRC tap point is after the transcoders we need
167 * to tweak symbol-level features to produce a deterministic series of
168 * symbols for a given frame. We need to reset those features only once
169 * a frame (instead of every nth symbol):
170 * - DC-balance: used to ensure a better clock recovery from the data
172 * - DisplayPort scrambling: used for EMI reduction
174 if (need_stable_symbols
) {
175 u32 tmp
= I915_READ(PORT_DFT2_G4X
);
177 tmp
|= DC_BALANCE_RESET_VLV
;
180 tmp
|= PIPE_A_SCRAMBLE_RESET
;
183 tmp
|= PIPE_B_SCRAMBLE_RESET
;
186 tmp
|= PIPE_C_SCRAMBLE_RESET
;
191 I915_WRITE(PORT_DFT2_G4X
, tmp
);
197 static int i9xx_pipe_crc_ctl_reg(struct drm_i915_private
*dev_priv
,
199 enum intel_pipe_crc_source
*source
,
202 if (*source
== INTEL_PIPE_CRC_SOURCE_AUTO
) {
203 int ret
= i9xx_pipe_crc_auto_source(dev_priv
, pipe
, source
);
209 case INTEL_PIPE_CRC_SOURCE_PIPE
:
210 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PIPE_I9XX
;
212 case INTEL_PIPE_CRC_SOURCE_TV
:
213 if (!SUPPORTS_TV(dev_priv
))
215 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_TV_PRE
;
217 case INTEL_PIPE_CRC_SOURCE_NONE
:
222 * The DP CRC source doesn't work on g4x.
223 * It can be made to work to some degree by selecting
224 * the correct CRC source before the port is enabled,
225 * and not touching the CRC source bits again until
226 * the port is disabled. But even then the bits
227 * eventually get stuck and a reboot is needed to get
228 * working CRCs on the pipe again. Let's simply
229 * refuse to use DP CRCs on g4x.
237 static void vlv_undo_pipe_scramble_reset(struct drm_i915_private
*dev_priv
,
240 u32 tmp
= I915_READ(PORT_DFT2_G4X
);
244 tmp
&= ~PIPE_A_SCRAMBLE_RESET
;
247 tmp
&= ~PIPE_B_SCRAMBLE_RESET
;
250 tmp
&= ~PIPE_C_SCRAMBLE_RESET
;
255 if (!(tmp
& PIPE_SCRAMBLE_RESET_MASK
))
256 tmp
&= ~DC_BALANCE_RESET_VLV
;
257 I915_WRITE(PORT_DFT2_G4X
, tmp
);
260 static int ilk_pipe_crc_ctl_reg(enum intel_pipe_crc_source
*source
,
263 if (*source
== INTEL_PIPE_CRC_SOURCE_AUTO
)
264 *source
= INTEL_PIPE_CRC_SOURCE_PIPE
;
267 case INTEL_PIPE_CRC_SOURCE_PLANE1
:
268 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PRIMARY_ILK
;
270 case INTEL_PIPE_CRC_SOURCE_PLANE2
:
271 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_SPRITE_ILK
;
273 case INTEL_PIPE_CRC_SOURCE_PIPE
:
274 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PIPE_ILK
;
276 case INTEL_PIPE_CRC_SOURCE_NONE
:
287 intel_crtc_crc_setup_workarounds(struct intel_crtc
*crtc
, bool enable
)
289 struct drm_i915_private
*dev_priv
= to_i915(crtc
->base
.dev
);
290 struct intel_crtc_state
*pipe_config
;
291 struct drm_atomic_state
*state
;
292 struct drm_modeset_acquire_ctx ctx
;
295 drm_modeset_acquire_init(&ctx
, 0);
297 state
= drm_atomic_state_alloc(&dev_priv
->drm
);
303 state
->acquire_ctx
= &ctx
;
306 pipe_config
= intel_atomic_get_crtc_state(state
, crtc
);
307 if (IS_ERR(pipe_config
)) {
308 ret
= PTR_ERR(pipe_config
);
312 pipe_config
->uapi
.mode_changed
= pipe_config
->has_psr
;
313 pipe_config
->crc_enabled
= enable
;
315 if (IS_HASWELL(dev_priv
) &&
316 pipe_config
->hw
.active
&& crtc
->pipe
== PIPE_A
&&
317 pipe_config
->cpu_transcoder
== TRANSCODER_EDP
)
318 pipe_config
->uapi
.mode_changed
= true;
320 ret
= drm_atomic_commit(state
);
323 if (ret
== -EDEADLK
) {
324 drm_atomic_state_clear(state
);
325 drm_modeset_backoff(&ctx
);
329 drm_atomic_state_put(state
);
331 WARN(ret
, "Toggling workaround to %i returns %i\n", enable
, ret
);
332 drm_modeset_drop_locks(&ctx
);
333 drm_modeset_acquire_fini(&ctx
);
336 static int ivb_pipe_crc_ctl_reg(struct drm_i915_private
*dev_priv
,
338 enum intel_pipe_crc_source
*source
,
341 if (*source
== INTEL_PIPE_CRC_SOURCE_AUTO
)
342 *source
= INTEL_PIPE_CRC_SOURCE_PIPE
;
345 case INTEL_PIPE_CRC_SOURCE_PLANE1
:
346 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PRIMARY_IVB
;
348 case INTEL_PIPE_CRC_SOURCE_PLANE2
:
349 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_SPRITE_IVB
;
351 case INTEL_PIPE_CRC_SOURCE_PIPE
:
352 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PF_IVB
;
354 case INTEL_PIPE_CRC_SOURCE_NONE
:
364 static int skl_pipe_crc_ctl_reg(struct drm_i915_private
*dev_priv
,
366 enum intel_pipe_crc_source
*source
,
369 if (*source
== INTEL_PIPE_CRC_SOURCE_AUTO
)
370 *source
= INTEL_PIPE_CRC_SOURCE_PIPE
;
373 case INTEL_PIPE_CRC_SOURCE_PLANE1
:
374 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PLANE_1_SKL
;
376 case INTEL_PIPE_CRC_SOURCE_PLANE2
:
377 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PLANE_2_SKL
;
379 case INTEL_PIPE_CRC_SOURCE_PLANE3
:
380 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PLANE_3_SKL
;
382 case INTEL_PIPE_CRC_SOURCE_PLANE4
:
383 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PLANE_4_SKL
;
385 case INTEL_PIPE_CRC_SOURCE_PLANE5
:
386 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PLANE_5_SKL
;
388 case INTEL_PIPE_CRC_SOURCE_PLANE6
:
389 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PLANE_6_SKL
;
391 case INTEL_PIPE_CRC_SOURCE_PLANE7
:
392 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_PLANE_7_SKL
;
394 case INTEL_PIPE_CRC_SOURCE_PIPE
:
395 *val
= PIPE_CRC_ENABLE
| PIPE_CRC_SOURCE_DMUX_SKL
;
397 case INTEL_PIPE_CRC_SOURCE_NONE
:
407 static int get_new_crc_ctl_reg(struct drm_i915_private
*dev_priv
,
409 enum intel_pipe_crc_source
*source
, u32
*val
)
411 if (IS_GEN(dev_priv
, 2))
412 return i8xx_pipe_crc_ctl_reg(source
, val
);
413 else if (INTEL_GEN(dev_priv
) < 5)
414 return i9xx_pipe_crc_ctl_reg(dev_priv
, pipe
, source
, val
);
415 else if (IS_VALLEYVIEW(dev_priv
) || IS_CHERRYVIEW(dev_priv
))
416 return vlv_pipe_crc_ctl_reg(dev_priv
, pipe
, source
, val
);
417 else if (IS_GEN_RANGE(dev_priv
, 5, 6))
418 return ilk_pipe_crc_ctl_reg(source
, val
);
419 else if (INTEL_GEN(dev_priv
) < 9)
420 return ivb_pipe_crc_ctl_reg(dev_priv
, pipe
, source
, val
);
422 return skl_pipe_crc_ctl_reg(dev_priv
, pipe
, source
, val
);
426 display_crc_ctl_parse_source(const char *buf
, enum intel_pipe_crc_source
*s
)
431 *s
= INTEL_PIPE_CRC_SOURCE_NONE
;
435 i
= match_string(pipe_crc_sources
, ARRAY_SIZE(pipe_crc_sources
), buf
);
443 void intel_display_crc_init(struct drm_i915_private
*dev_priv
)
447 for_each_pipe(dev_priv
, pipe
) {
448 struct intel_pipe_crc
*pipe_crc
= &dev_priv
->pipe_crc
[pipe
];
450 spin_lock_init(&pipe_crc
->lock
);
454 static int i8xx_crc_source_valid(struct drm_i915_private
*dev_priv
,
455 const enum intel_pipe_crc_source source
)
458 case INTEL_PIPE_CRC_SOURCE_PIPE
:
459 case INTEL_PIPE_CRC_SOURCE_NONE
:
466 static int i9xx_crc_source_valid(struct drm_i915_private
*dev_priv
,
467 const enum intel_pipe_crc_source source
)
470 case INTEL_PIPE_CRC_SOURCE_PIPE
:
471 case INTEL_PIPE_CRC_SOURCE_TV
:
472 case INTEL_PIPE_CRC_SOURCE_NONE
:
479 static int vlv_crc_source_valid(struct drm_i915_private
*dev_priv
,
480 const enum intel_pipe_crc_source source
)
483 case INTEL_PIPE_CRC_SOURCE_PIPE
:
484 case INTEL_PIPE_CRC_SOURCE_DP_B
:
485 case INTEL_PIPE_CRC_SOURCE_DP_C
:
486 case INTEL_PIPE_CRC_SOURCE_DP_D
:
487 case INTEL_PIPE_CRC_SOURCE_NONE
:
494 static int ilk_crc_source_valid(struct drm_i915_private
*dev_priv
,
495 const enum intel_pipe_crc_source source
)
498 case INTEL_PIPE_CRC_SOURCE_PIPE
:
499 case INTEL_PIPE_CRC_SOURCE_PLANE1
:
500 case INTEL_PIPE_CRC_SOURCE_PLANE2
:
501 case INTEL_PIPE_CRC_SOURCE_NONE
:
508 static int ivb_crc_source_valid(struct drm_i915_private
*dev_priv
,
509 const enum intel_pipe_crc_source source
)
512 case INTEL_PIPE_CRC_SOURCE_PIPE
:
513 case INTEL_PIPE_CRC_SOURCE_PLANE1
:
514 case INTEL_PIPE_CRC_SOURCE_PLANE2
:
515 case INTEL_PIPE_CRC_SOURCE_NONE
:
522 static int skl_crc_source_valid(struct drm_i915_private
*dev_priv
,
523 const enum intel_pipe_crc_source source
)
526 case INTEL_PIPE_CRC_SOURCE_PIPE
:
527 case INTEL_PIPE_CRC_SOURCE_PLANE1
:
528 case INTEL_PIPE_CRC_SOURCE_PLANE2
:
529 case INTEL_PIPE_CRC_SOURCE_PLANE3
:
530 case INTEL_PIPE_CRC_SOURCE_PLANE4
:
531 case INTEL_PIPE_CRC_SOURCE_PLANE5
:
532 case INTEL_PIPE_CRC_SOURCE_PLANE6
:
533 case INTEL_PIPE_CRC_SOURCE_PLANE7
:
534 case INTEL_PIPE_CRC_SOURCE_NONE
:
542 intel_is_valid_crc_source(struct drm_i915_private
*dev_priv
,
543 const enum intel_pipe_crc_source source
)
545 if (IS_GEN(dev_priv
, 2))
546 return i8xx_crc_source_valid(dev_priv
, source
);
547 else if (INTEL_GEN(dev_priv
) < 5)
548 return i9xx_crc_source_valid(dev_priv
, source
);
549 else if (IS_VALLEYVIEW(dev_priv
) || IS_CHERRYVIEW(dev_priv
))
550 return vlv_crc_source_valid(dev_priv
, source
);
551 else if (IS_GEN_RANGE(dev_priv
, 5, 6))
552 return ilk_crc_source_valid(dev_priv
, source
);
553 else if (INTEL_GEN(dev_priv
) < 9)
554 return ivb_crc_source_valid(dev_priv
, source
);
556 return skl_crc_source_valid(dev_priv
, source
);
559 const char *const *intel_crtc_get_crc_sources(struct drm_crtc
*crtc
,
562 *count
= ARRAY_SIZE(pipe_crc_sources
);
563 return pipe_crc_sources
;
566 int intel_crtc_verify_crc_source(struct drm_crtc
*crtc
, const char *source_name
,
569 struct drm_i915_private
*dev_priv
= to_i915(crtc
->dev
);
570 enum intel_pipe_crc_source source
;
572 if (display_crc_ctl_parse_source(source_name
, &source
) < 0) {
573 DRM_DEBUG_DRIVER("unknown source %s\n", source_name
);
577 if (source
== INTEL_PIPE_CRC_SOURCE_AUTO
||
578 intel_is_valid_crc_source(dev_priv
, source
) == 0) {
586 int intel_crtc_set_crc_source(struct drm_crtc
*crtc
, const char *source_name
)
588 struct drm_i915_private
*dev_priv
= to_i915(crtc
->dev
);
589 struct intel_pipe_crc
*pipe_crc
= &dev_priv
->pipe_crc
[crtc
->index
];
590 enum intel_display_power_domain power_domain
;
591 enum intel_pipe_crc_source source
;
592 intel_wakeref_t wakeref
;
593 u32 val
= 0; /* shut up gcc */
597 if (display_crc_ctl_parse_source(source_name
, &source
) < 0) {
598 DRM_DEBUG_DRIVER("unknown source %s\n", source_name
);
602 power_domain
= POWER_DOMAIN_PIPE(crtc
->index
);
603 wakeref
= intel_display_power_get_if_enabled(dev_priv
, power_domain
);
605 DRM_DEBUG_KMS("Trying to capture CRC while pipe is off\n");
609 enable
= source
!= INTEL_PIPE_CRC_SOURCE_NONE
;
611 intel_crtc_crc_setup_workarounds(to_intel_crtc(crtc
), true);
613 ret
= get_new_crc_ctl_reg(dev_priv
, crtc
->index
, &source
, &val
);
617 pipe_crc
->source
= source
;
618 I915_WRITE(PIPE_CRC_CTL(crtc
->index
), val
);
619 POSTING_READ(PIPE_CRC_CTL(crtc
->index
));
622 if (IS_VALLEYVIEW(dev_priv
) || IS_CHERRYVIEW(dev_priv
))
623 vlv_undo_pipe_scramble_reset(dev_priv
, crtc
->index
);
626 pipe_crc
->skipped
= 0;
630 intel_crtc_crc_setup_workarounds(to_intel_crtc(crtc
), false);
632 intel_display_power_put(dev_priv
, power_domain
, wakeref
);
637 void intel_crtc_enable_pipe_crc(struct intel_crtc
*intel_crtc
)
639 struct drm_crtc
*crtc
= &intel_crtc
->base
;
640 struct drm_i915_private
*dev_priv
= to_i915(crtc
->dev
);
641 struct intel_pipe_crc
*pipe_crc
= &dev_priv
->pipe_crc
[crtc
->index
];
644 if (!crtc
->crc
.opened
)
647 if (get_new_crc_ctl_reg(dev_priv
, crtc
->index
, &pipe_crc
->source
, &val
) < 0)
650 /* Don't need pipe_crc->lock here, IRQs are not generated. */
651 pipe_crc
->skipped
= 0;
653 I915_WRITE(PIPE_CRC_CTL(crtc
->index
), val
);
654 POSTING_READ(PIPE_CRC_CTL(crtc
->index
));
657 void intel_crtc_disable_pipe_crc(struct intel_crtc
*intel_crtc
)
659 struct drm_crtc
*crtc
= &intel_crtc
->base
;
660 struct drm_i915_private
*dev_priv
= to_i915(crtc
->dev
);
661 struct intel_pipe_crc
*pipe_crc
= &dev_priv
->pipe_crc
[crtc
->index
];
663 /* Swallow crc's until we stop generating them. */
664 spin_lock_irq(&pipe_crc
->lock
);
665 pipe_crc
->skipped
= INT_MIN
;
666 spin_unlock_irq(&pipe_crc
->lock
);
668 I915_WRITE(PIPE_CRC_CTL(crtc
->index
), 0);
669 POSTING_READ(PIPE_CRC_CTL(crtc
->index
));
670 intel_synchronize_irq(dev_priv
);