mirror of https://gitee.com/openkylin/linux.git
Merge branch 'drm-fixes' of git://people.freedesktop.org/~airlied/linux
Pull drm fixes from Dave Airlie: "A bunch of i915 fixes, one revert a VBT fix that was a bit premature, and some braswell feature removal that the hw actually didn't support. One radeon race fix at boot, and one hlcdc build fix, one fix from Russell that fixes build as well with new audio features. This is hopefully all I have until -next" * 'drm-fixes' of git://people.freedesktop.org/~airlied/linux: drm/radeon: fix hotplug race at startup drm/edid: add function to help find SADs drm/i915: Avoid TP3 on CHV drm/i915: remove HBR2 from chv supported list Revert "drm/i915: Add eDP intermediate frequencies for CHV" Revert "drm/i915: Allow parsing of variable size child device entries from VBT" drm/atmel-hlcdc: Compile suspend/resume for PM_SLEEP only drm/i915: Flag the execlists context object as dirty after every use
This commit is contained in:
commit
dc9c12f46f
|
@ -559,7 +559,7 @@ static int atmel_hlcdc_dc_drm_remove(struct platform_device *pdev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
#ifdef CONFIG_PM_SLEEP
|
||||||
static int atmel_hlcdc_dc_drm_suspend(struct device *dev)
|
static int atmel_hlcdc_dc_drm_suspend(struct device *dev)
|
||||||
{
|
{
|
||||||
struct drm_device *drm_dev = dev_get_drvdata(dev);
|
struct drm_device *drm_dev = dev_get_drvdata(dev);
|
||||||
|
|
|
@ -1075,34 +1075,15 @@ parse_device_mapping(struct drm_i915_private *dev_priv,
|
||||||
const union child_device_config *p_child;
|
const union child_device_config *p_child;
|
||||||
union child_device_config *child_dev_ptr;
|
union child_device_config *child_dev_ptr;
|
||||||
int i, child_device_num, count;
|
int i, child_device_num, count;
|
||||||
u8 expected_size;
|
u16 block_size;
|
||||||
u16 block_size;
|
|
||||||
|
|
||||||
p_defs = find_section(bdb, BDB_GENERAL_DEFINITIONS);
|
p_defs = find_section(bdb, BDB_GENERAL_DEFINITIONS);
|
||||||
if (!p_defs) {
|
if (!p_defs) {
|
||||||
DRM_DEBUG_KMS("No general definition block is found, no devices defined.\n");
|
DRM_DEBUG_KMS("No general definition block is found, no devices defined.\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (bdb->version < 195) {
|
if (p_defs->child_dev_size < sizeof(*p_child)) {
|
||||||
expected_size = 33;
|
DRM_ERROR("General definiton block child device size is too small.\n");
|
||||||
} else if (bdb->version == 195) {
|
|
||||||
expected_size = 37;
|
|
||||||
} else if (bdb->version <= 197) {
|
|
||||||
expected_size = 38;
|
|
||||||
} else {
|
|
||||||
expected_size = 38;
|
|
||||||
DRM_DEBUG_DRIVER("Expected child_device_config size for BDB version %u not known; assuming %u\n",
|
|
||||||
expected_size, bdb->version);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (expected_size > sizeof(*p_child)) {
|
|
||||||
DRM_ERROR("child_device_config cannot fit in p_child\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (p_defs->child_dev_size != expected_size) {
|
|
||||||
DRM_ERROR("Size mismatch; child_device_config size=%u (expected %u); bdb->version: %u\n",
|
|
||||||
p_defs->child_dev_size, expected_size, bdb->version);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* get the block size of general definitions */
|
/* get the block size of general definitions */
|
||||||
|
@ -1149,7 +1130,7 @@ parse_device_mapping(struct drm_i915_private *dev_priv,
|
||||||
|
|
||||||
child_dev_ptr = dev_priv->vbt.child_dev + count;
|
child_dev_ptr = dev_priv->vbt.child_dev + count;
|
||||||
count++;
|
count++;
|
||||||
memcpy(child_dev_ptr, p_child, p_defs->child_dev_size);
|
memcpy(child_dev_ptr, p_child, sizeof(*p_child));
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -93,9 +93,6 @@ static const struct dp_link_dpll chv_dpll[] = {
|
||||||
|
|
||||||
static const int skl_rates[] = { 162000, 216000, 270000,
|
static const int skl_rates[] = { 162000, 216000, 270000,
|
||||||
324000, 432000, 540000 };
|
324000, 432000, 540000 };
|
||||||
static const int chv_rates[] = { 162000, 202500, 210000, 216000,
|
|
||||||
243000, 270000, 324000, 405000,
|
|
||||||
420000, 432000, 540000 };
|
|
||||||
static const int default_rates[] = { 162000, 270000, 540000 };
|
static const int default_rates[] = { 162000, 270000, 540000 };
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1169,24 +1166,31 @@ intel_dp_sink_rates(struct intel_dp *intel_dp, const int **sink_rates)
|
||||||
return (intel_dp_max_link_bw(intel_dp) >> 3) + 1;
|
return (intel_dp_max_link_bw(intel_dp) >> 3) + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool intel_dp_source_supports_hbr2(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
/* WaDisableHBR2:skl */
|
||||||
|
if (IS_SKYLAKE(dev) && INTEL_REVID(dev) <= SKL_REVID_B0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if ((IS_HASWELL(dev) && !IS_HSW_ULX(dev)) || IS_BROADWELL(dev) ||
|
||||||
|
(INTEL_INFO(dev)->gen >= 9))
|
||||||
|
return true;
|
||||||
|
else
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
intel_dp_source_rates(struct drm_device *dev, const int **source_rates)
|
intel_dp_source_rates(struct drm_device *dev, const int **source_rates)
|
||||||
{
|
{
|
||||||
if (IS_SKYLAKE(dev)) {
|
if (IS_SKYLAKE(dev)) {
|
||||||
*source_rates = skl_rates;
|
*source_rates = skl_rates;
|
||||||
return ARRAY_SIZE(skl_rates);
|
return ARRAY_SIZE(skl_rates);
|
||||||
} else if (IS_CHERRYVIEW(dev)) {
|
|
||||||
*source_rates = chv_rates;
|
|
||||||
return ARRAY_SIZE(chv_rates);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
*source_rates = default_rates;
|
*source_rates = default_rates;
|
||||||
|
|
||||||
if (IS_SKYLAKE(dev) && INTEL_REVID(dev) <= SKL_REVID_B0)
|
/* This depends on the fact that 5.4 is last value in the array */
|
||||||
/* WaDisableHBR2:skl */
|
if (intel_dp_source_supports_hbr2(dev))
|
||||||
return (DP_LINK_BW_2_7 >> 3) + 1;
|
|
||||||
else if (INTEL_INFO(dev)->gen >= 8 ||
|
|
||||||
(IS_HASWELL(dev) && !IS_HSW_ULX(dev)))
|
|
||||||
return (DP_LINK_BW_5_4 >> 3) + 1;
|
return (DP_LINK_BW_5_4 >> 3) + 1;
|
||||||
else
|
else
|
||||||
return (DP_LINK_BW_2_7 >> 3) + 1;
|
return (DP_LINK_BW_2_7 >> 3) + 1;
|
||||||
|
@ -3941,10 +3945,15 @@ intel_dp_get_dpcd(struct intel_dp *intel_dp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Training Pattern 3 support, both source and sink */
|
/* Training Pattern 3 support, Intel platforms that support HBR2 alone
|
||||||
|
* have support for TP3 hence that check is used along with dpcd check
|
||||||
|
* to ensure TP3 can be enabled.
|
||||||
|
* SKL < B0: due it's WaDisableHBR2 is the only exception where TP3 is
|
||||||
|
* supported but still not enabled.
|
||||||
|
*/
|
||||||
if (intel_dp->dpcd[DP_DPCD_REV] >= 0x12 &&
|
if (intel_dp->dpcd[DP_DPCD_REV] >= 0x12 &&
|
||||||
intel_dp->dpcd[DP_MAX_LANE_COUNT] & DP_TPS3_SUPPORTED &&
|
intel_dp->dpcd[DP_MAX_LANE_COUNT] & DP_TPS3_SUPPORTED &&
|
||||||
(IS_HASWELL(dev_priv) || INTEL_INFO(dev_priv)->gen >= 8)) {
|
intel_dp_source_supports_hbr2(dev)) {
|
||||||
intel_dp->use_tps3 = true;
|
intel_dp->use_tps3 = true;
|
||||||
DRM_DEBUG_KMS("Displayport TPS3 supported\n");
|
DRM_DEBUG_KMS("Displayport TPS3 supported\n");
|
||||||
} else
|
} else
|
||||||
|
|
|
@ -1012,6 +1012,8 @@ static int intel_lr_context_pin(struct intel_engine_cs *ring,
|
||||||
ret = intel_pin_and_map_ringbuffer_obj(ring->dev, ringbuf);
|
ret = intel_pin_and_map_ringbuffer_obj(ring->dev, ringbuf);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto unpin_ctx_obj;
|
goto unpin_ctx_obj;
|
||||||
|
|
||||||
|
ctx_obj->dirty = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
|
|
@ -79,6 +79,11 @@ static void radeon_hotplug_work_func(struct work_struct *work)
|
||||||
struct drm_mode_config *mode_config = &dev->mode_config;
|
struct drm_mode_config *mode_config = &dev->mode_config;
|
||||||
struct drm_connector *connector;
|
struct drm_connector *connector;
|
||||||
|
|
||||||
|
/* we can race here at startup, some boards seem to trigger
|
||||||
|
* hotplug irqs when they shouldn't. */
|
||||||
|
if (!rdev->mode_info.mode_config_initialized)
|
||||||
|
return;
|
||||||
|
|
||||||
mutex_lock(&mode_config->mutex);
|
mutex_lock(&mode_config->mutex);
|
||||||
if (mode_config->num_connector) {
|
if (mode_config->num_connector) {
|
||||||
list_for_each_entry(connector, &mode_config->connector_list, head)
|
list_for_each_entry(connector, &mode_config->connector_list, head)
|
||||||
|
|
|
@ -347,6 +347,25 @@ static inline int drm_eld_mnl(const uint8_t *eld)
|
||||||
return (eld[DRM_ELD_CEA_EDID_VER_MNL] & DRM_ELD_MNL_MASK) >> DRM_ELD_MNL_SHIFT;
|
return (eld[DRM_ELD_CEA_EDID_VER_MNL] & DRM_ELD_MNL_MASK) >> DRM_ELD_MNL_SHIFT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* drm_eld_sad - Get ELD SAD structures.
|
||||||
|
* @eld: pointer to an eld memory structure with sad_count set
|
||||||
|
*/
|
||||||
|
static inline const uint8_t *drm_eld_sad(const uint8_t *eld)
|
||||||
|
{
|
||||||
|
unsigned int ver, mnl;
|
||||||
|
|
||||||
|
ver = (eld[DRM_ELD_VER] & DRM_ELD_VER_MASK) >> DRM_ELD_VER_SHIFT;
|
||||||
|
if (ver != 2 && ver != 31)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
mnl = drm_eld_mnl(eld);
|
||||||
|
if (mnl > 16)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return eld + DRM_ELD_CEA_SAD(mnl, 0);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* drm_eld_sad_count - Get ELD SAD count.
|
* drm_eld_sad_count - Get ELD SAD count.
|
||||||
* @eld: pointer to an eld memory structure with sad_count set
|
* @eld: pointer to an eld memory structure with sad_count set
|
||||||
|
|
Loading…
Reference in New Issue