Skip to content

Commit faf578e

Browse files
catayloxgregkh
authored andcommitted
drm/i915/glk: Add Quirk for GLK NUC HDMI port issues.
commit 0ca9488 upstream. On GLK NUC platforms the HDMI retiming buffer needs additional disabled time to correctly sync to a faster incoming signal. When measured on a scope the highspeed lines of the HDMI clock turn off for ~400uS during a normal resolution change. The HDMI retimer on the GLK NUC appears to require at least a full frame of quiet time before a new faster clock can be correctly sync'd. Wait 100ms due to msleep inaccuracies while waiting for a completed frame. Add a quirk to the driver for GLK boards that use ITE66317 HDMI retimers. V2: Add more devices to the quirk list V3: Delay increased to 100ms, check to confirm crtc type is HDMI. V4: crtc type check extended to include _DDI and whitespace fixes v5: Fix white spaces, remove the macro for delay. Revert the crtc type check introduced in v4. Cc: Imre Deak <imre.deak@intel.com> Cc: <stable@vger.kernel.org> # v4.14+ Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=105887 Signed-off-by: Clint Taylor <clinton.a.taylor@intel.com> Tested-by: Daniel Scheller <d.scheller.oss@gmail.com> Signed-off-by: Radhakrishna Sripada <radhakrishna.sripada@intel.com> Signed-off-by: Imre Deak <imre.deak@intel.com> Reviewed-by: Imre Deak <imre.deak@intel.com> Link: https://patchwork.freedesktop.org/patch/msgid/20180710200205.1478-1-radhakrishna.sripada@intel.com (cherry picked from commit 90c3e21) Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com> Signed-off-by: Sudip Mukherjee <sudipm.mukherjee@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent 2a797fd commit faf578e

4 files changed

Lines changed: 33 additions & 5 deletions

File tree

drivers/gpu/drm/i915/i915_drv.h

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1183,6 +1183,7 @@ enum intel_sbi_destination {
11831183
#define QUIRK_BACKLIGHT_PRESENT (1<<3)
11841184
#define QUIRK_PIN_SWIZZLED_PAGES (1<<5)
11851185
#define QUIRK_INCREASE_T12_DELAY (1<<6)
1186+
#define QUIRK_INCREASE_DDI_DISABLED_TIME (1<<7)
11861187

11871188
struct intel_fbdev;
11881189
struct intel_fbc_work;

drivers/gpu/drm/i915/intel_ddi.c

Lines changed: 11 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1526,15 +1526,24 @@ void intel_ddi_enable_transcoder_func(const struct intel_crtc_state *crtc_state)
15261526
I915_WRITE(TRANS_DDI_FUNC_CTL(cpu_transcoder), temp);
15271527
}
15281528

1529-
void intel_ddi_disable_transcoder_func(struct drm_i915_private *dev_priv,
1530-
enum transcoder cpu_transcoder)
1529+
void intel_ddi_disable_transcoder_func(const struct intel_crtc_state *crtc_state)
15311530
{
1531+
struct intel_crtc *crtc = to_intel_crtc(crtc_state->base.crtc);
1532+
struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
1533+
enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
15321534
i915_reg_t reg = TRANS_DDI_FUNC_CTL(cpu_transcoder);
15331535
uint32_t val = I915_READ(reg);
15341536

15351537
val &= ~(TRANS_DDI_FUNC_ENABLE | TRANS_DDI_PORT_MASK | TRANS_DDI_DP_VC_PAYLOAD_ALLOC);
15361538
val |= TRANS_DDI_PORT_NONE;
15371539
I915_WRITE(reg, val);
1540+
1541+
if (dev_priv->quirks & QUIRK_INCREASE_DDI_DISABLED_TIME &&
1542+
intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
1543+
DRM_DEBUG_KMS("Quirk Increase DDI disabled time\n");
1544+
/* Quirk time at 100ms for reliable operation */
1545+
msleep(100);
1546+
}
15381547
}
15391548

15401549
bool intel_ddi_connector_get_hw_state(struct intel_connector *intel_connector)

drivers/gpu/drm/i915/intel_display.c

Lines changed: 20 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5653,7 +5653,7 @@ static void haswell_crtc_disable(struct intel_crtc_state *old_crtc_state,
56535653
intel_ddi_set_vc_payload_alloc(intel_crtc->config, false);
56545654

56555655
if (!transcoder_is_dsi(cpu_transcoder))
5656-
intel_ddi_disable_transcoder_func(dev_priv, cpu_transcoder);
5656+
intel_ddi_disable_transcoder_func(old_crtc_state);
56575657

56585658
if (INTEL_GEN(dev_priv) >= 9)
56595659
skylake_scaler_disable(intel_crtc);
@@ -14286,6 +14286,18 @@ static void quirk_increase_t12_delay(struct drm_device *dev)
1428614286
DRM_INFO("Applying T12 delay quirk\n");
1428714287
}
1428814288

14289+
/*
14290+
* GeminiLake NUC HDMI outputs require additional off time
14291+
* this allows the onboard retimer to correctly sync to signal
14292+
*/
14293+
static void quirk_increase_ddi_disabled_time(struct drm_device *dev)
14294+
{
14295+
struct drm_i915_private *dev_priv = to_i915(dev);
14296+
14297+
dev_priv->quirks |= QUIRK_INCREASE_DDI_DISABLED_TIME;
14298+
DRM_INFO("Applying Increase DDI Disabled quirk\n");
14299+
}
14300+
1428914301
struct intel_quirk {
1429014302
int device;
1429114303
int subsystem_vendor;
@@ -14372,6 +14384,13 @@ static struct intel_quirk intel_quirks[] = {
1437214384

1437314385
/* Toshiba Satellite P50-C-18C */
1437414386
{ 0x191B, 0x1179, 0xF840, quirk_increase_t12_delay },
14387+
14388+
/* GeminiLake NUC */
14389+
{ 0x3185, 0x8086, 0x2072, quirk_increase_ddi_disabled_time },
14390+
{ 0x3184, 0x8086, 0x2072, quirk_increase_ddi_disabled_time },
14391+
/* ASRock ITX*/
14392+
{ 0x3185, 0x1849, 0x2212, quirk_increase_ddi_disabled_time },
14393+
{ 0x3184, 0x1849, 0x2212, quirk_increase_ddi_disabled_time },
1437514394
};
1437614395

1437714396
static void intel_init_quirks(struct drm_device *dev)

drivers/gpu/drm/i915/intel_drv.h

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1254,8 +1254,7 @@ void intel_ddi_init(struct drm_i915_private *dev_priv, enum port port);
12541254
enum port intel_ddi_get_encoder_port(struct intel_encoder *intel_encoder);
12551255
bool intel_ddi_get_hw_state(struct intel_encoder *encoder, enum pipe *pipe);
12561256
void intel_ddi_enable_transcoder_func(const struct intel_crtc_state *crtc_state);
1257-
void intel_ddi_disable_transcoder_func(struct drm_i915_private *dev_priv,
1258-
enum transcoder cpu_transcoder);
1257+
void intel_ddi_disable_transcoder_func(const struct intel_crtc_state *crtc_state);
12591258
void intel_ddi_enable_pipe_clock(const struct intel_crtc_state *crtc_state);
12601259
void intel_ddi_disable_pipe_clock(const struct intel_crtc_state *crtc_state);
12611260
struct intel_encoder *

0 commit comments

Comments
 (0)