Commit a54569b1 authored by Dave Airlie's avatar Dave Airlie

Merge tag 'drm-intel-fixes-2022-08-26' of...

Merge tag 'drm-intel-fixes-2022-08-26' of git://anongit.freedesktop.org/drm/drm-intel into drm-fixes

- GVT fixes including fix for a CommetLake regression in mmio table
  and misc doc and typo fixes
- Fix CCS handling (Matt)
- Fix for guc requests after reset (Daniele)
- Display DSI related fixes (Jani)
- Display backlight related fixes (Arun, Jouni)
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>

From: Rodrigo Vivi <rodrigo.vivi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/YwjCTDFm7clXPgEu@intel.com
parents b90cb105 6067c82c
...@@ -2070,7 +2070,14 @@ void icl_dsi_init(struct drm_i915_private *dev_priv) ...@@ -2070,7 +2070,14 @@ void icl_dsi_init(struct drm_i915_private *dev_priv)
else else
intel_dsi->ports = BIT(port); intel_dsi->ports = BIT(port);
if (drm_WARN_ON(&dev_priv->drm, intel_connector->panel.vbt.dsi.bl_ports & ~intel_dsi->ports))
intel_connector->panel.vbt.dsi.bl_ports &= intel_dsi->ports;
intel_dsi->dcs_backlight_ports = intel_connector->panel.vbt.dsi.bl_ports; intel_dsi->dcs_backlight_ports = intel_connector->panel.vbt.dsi.bl_ports;
if (drm_WARN_ON(&dev_priv->drm, intel_connector->panel.vbt.dsi.cabc_ports & ~intel_dsi->ports))
intel_connector->panel.vbt.dsi.cabc_ports &= intel_dsi->ports;
intel_dsi->dcs_cabc_ports = intel_connector->panel.vbt.dsi.cabc_ports; intel_dsi->dcs_cabc_ports = intel_connector->panel.vbt.dsi.cabc_ports;
for_each_dsi_port(port, intel_dsi->ports) { for_each_dsi_port(port, intel_dsi->ports) {
......
...@@ -16,6 +16,7 @@ ...@@ -16,6 +16,7 @@
#include "intel_dsi_dcs_backlight.h" #include "intel_dsi_dcs_backlight.h"
#include "intel_panel.h" #include "intel_panel.h"
#include "intel_pci_config.h" #include "intel_pci_config.h"
#include "intel_pps.h"
/** /**
* scale - scale values from one range to another * scale - scale values from one range to another
...@@ -971,9 +972,9 @@ int intel_backlight_device_register(struct intel_connector *connector) ...@@ -971,9 +972,9 @@ int intel_backlight_device_register(struct intel_connector *connector)
if (!name) if (!name)
return -ENOMEM; return -ENOMEM;
bd = backlight_device_register(name, connector->base.kdev, connector, bd = backlight_device_get_by_name(name);
&intel_backlight_device_ops, &props); if (bd) {
put_device(&bd->dev);
/* /*
* Using the same name independent of the drm device or connector * Using the same name independent of the drm device or connector
* prevents registration of multiple backlight devices in the * prevents registration of multiple backlight devices in the
...@@ -981,16 +982,14 @@ int intel_backlight_device_register(struct intel_connector *connector) ...@@ -981,16 +982,14 @@ int intel_backlight_device_register(struct intel_connector *connector)
* compatibility. Use unique names for subsequent backlight devices as a * compatibility. Use unique names for subsequent backlight devices as a
* fallback when the default name already exists. * fallback when the default name already exists.
*/ */
if (IS_ERR(bd) && PTR_ERR(bd) == -EEXIST) {
kfree(name); kfree(name);
name = kasprintf(GFP_KERNEL, "card%d-%s-backlight", name = kasprintf(GFP_KERNEL, "card%d-%s-backlight",
i915->drm.primary->index, connector->base.name); i915->drm.primary->index, connector->base.name);
if (!name) if (!name)
return -ENOMEM; return -ENOMEM;
}
bd = backlight_device_register(name, connector->base.kdev, connector, bd = backlight_device_register(name, connector->base.kdev, connector,
&intel_backlight_device_ops, &props); &intel_backlight_device_ops, &props);
}
if (IS_ERR(bd)) { if (IS_ERR(bd)) {
drm_err(&i915->drm, drm_err(&i915->drm,
...@@ -1773,10 +1772,14 @@ void intel_backlight_init_funcs(struct intel_panel *panel) ...@@ -1773,10 +1772,14 @@ void intel_backlight_init_funcs(struct intel_panel *panel)
panel->backlight.pwm_funcs = &i9xx_pwm_funcs; panel->backlight.pwm_funcs = &i9xx_pwm_funcs;
} }
if (connector->base.connector_type == DRM_MODE_CONNECTOR_eDP && if (connector->base.connector_type == DRM_MODE_CONNECTOR_eDP) {
intel_dp_aux_init_backlight_funcs(connector) == 0) if (intel_dp_aux_init_backlight_funcs(connector) == 0)
return; return;
if (!(dev_priv->quirks & QUIRK_NO_PPS_BACKLIGHT_POWER_HOOK))
connector->panel.backlight.power = intel_pps_backlight_power;
}
/* We're using a standard PWM backlight interface */ /* We're using a standard PWM backlight interface */
panel->backlight.funcs = &pwm_bl_funcs; panel->backlight.funcs = &pwm_bl_funcs;
} }
...@@ -1596,6 +1596,8 @@ static void parse_dsi_backlight_ports(struct drm_i915_private *i915, ...@@ -1596,6 +1596,8 @@ static void parse_dsi_backlight_ports(struct drm_i915_private *i915,
struct intel_panel *panel, struct intel_panel *panel,
enum port port) enum port port)
{ {
enum port port_bc = DISPLAY_VER(i915) >= 11 ? PORT_B : PORT_C;
if (!panel->vbt.dsi.config->dual_link || i915->vbt.version < 197) { if (!panel->vbt.dsi.config->dual_link || i915->vbt.version < 197) {
panel->vbt.dsi.bl_ports = BIT(port); panel->vbt.dsi.bl_ports = BIT(port);
if (panel->vbt.dsi.config->cabc_supported) if (panel->vbt.dsi.config->cabc_supported)
...@@ -1609,11 +1611,11 @@ static void parse_dsi_backlight_ports(struct drm_i915_private *i915, ...@@ -1609,11 +1611,11 @@ static void parse_dsi_backlight_ports(struct drm_i915_private *i915,
panel->vbt.dsi.bl_ports = BIT(PORT_A); panel->vbt.dsi.bl_ports = BIT(PORT_A);
break; break;
case DL_DCS_PORT_C: case DL_DCS_PORT_C:
panel->vbt.dsi.bl_ports = BIT(PORT_C); panel->vbt.dsi.bl_ports = BIT(port_bc);
break; break;
default: default:
case DL_DCS_PORT_A_AND_C: case DL_DCS_PORT_A_AND_C:
panel->vbt.dsi.bl_ports = BIT(PORT_A) | BIT(PORT_C); panel->vbt.dsi.bl_ports = BIT(PORT_A) | BIT(port_bc);
break; break;
} }
...@@ -1625,12 +1627,12 @@ static void parse_dsi_backlight_ports(struct drm_i915_private *i915, ...@@ -1625,12 +1627,12 @@ static void parse_dsi_backlight_ports(struct drm_i915_private *i915,
panel->vbt.dsi.cabc_ports = BIT(PORT_A); panel->vbt.dsi.cabc_ports = BIT(PORT_A);
break; break;
case DL_DCS_PORT_C: case DL_DCS_PORT_C:
panel->vbt.dsi.cabc_ports = BIT(PORT_C); panel->vbt.dsi.cabc_ports = BIT(port_bc);
break; break;
default: default:
case DL_DCS_PORT_A_AND_C: case DL_DCS_PORT_A_AND_C:
panel->vbt.dsi.cabc_ports = panel->vbt.dsi.cabc_ports =
BIT(PORT_A) | BIT(PORT_C); BIT(PORT_A) | BIT(port_bc);
break; break;
} }
} }
......
...@@ -5293,8 +5293,6 @@ static bool intel_edp_init_connector(struct intel_dp *intel_dp, ...@@ -5293,8 +5293,6 @@ static bool intel_edp_init_connector(struct intel_dp *intel_dp,
intel_panel_init(intel_connector); intel_panel_init(intel_connector);
if (!(dev_priv->quirks & QUIRK_NO_PPS_BACKLIGHT_POWER_HOOK))
intel_connector->panel.backlight.power = intel_pps_backlight_power;
intel_backlight_setup(intel_connector, pipe); intel_backlight_setup(intel_connector, pipe);
intel_edp_add_properties(intel_dp); intel_edp_add_properties(intel_dp);
......
...@@ -1933,7 +1933,14 @@ void vlv_dsi_init(struct drm_i915_private *dev_priv) ...@@ -1933,7 +1933,14 @@ void vlv_dsi_init(struct drm_i915_private *dev_priv)
else else
intel_dsi->ports = BIT(port); intel_dsi->ports = BIT(port);
if (drm_WARN_ON(&dev_priv->drm, intel_connector->panel.vbt.dsi.bl_ports & ~intel_dsi->ports))
intel_connector->panel.vbt.dsi.bl_ports &= intel_dsi->ports;
intel_dsi->dcs_backlight_ports = intel_connector->panel.vbt.dsi.bl_ports; intel_dsi->dcs_backlight_ports = intel_connector->panel.vbt.dsi.bl_ports;
if (drm_WARN_ON(&dev_priv->drm, intel_connector->panel.vbt.dsi.cabc_ports & ~intel_dsi->ports))
intel_connector->panel.vbt.dsi.cabc_ports &= intel_dsi->ports;
intel_dsi->dcs_cabc_ports = intel_connector->panel.vbt.dsi.cabc_ports; intel_dsi->dcs_cabc_ports = intel_connector->panel.vbt.dsi.cabc_ports;
/* Create a DSI host (and a device) for each port. */ /* Create a DSI host (and a device) for each port. */
......
...@@ -638,9 +638,9 @@ static int emit_copy(struct i915_request *rq, ...@@ -638,9 +638,9 @@ static int emit_copy(struct i915_request *rq,
return 0; return 0;
} }
static int scatter_list_length(struct scatterlist *sg) static u64 scatter_list_length(struct scatterlist *sg)
{ {
int len = 0; u64 len = 0;
while (sg && sg_dma_len(sg)) { while (sg && sg_dma_len(sg)) {
len += sg_dma_len(sg); len += sg_dma_len(sg);
...@@ -650,12 +650,11 @@ static int scatter_list_length(struct scatterlist *sg) ...@@ -650,12 +650,11 @@ static int scatter_list_length(struct scatterlist *sg)
return len; return len;
} }
static void static int
calculate_chunk_sz(struct drm_i915_private *i915, bool src_is_lmem, calculate_chunk_sz(struct drm_i915_private *i915, bool src_is_lmem,
int *src_sz, u32 bytes_to_cpy, u32 ccs_bytes_to_cpy) u64 bytes_to_cpy, u64 ccs_bytes_to_cpy)
{ {
if (ccs_bytes_to_cpy) { if (ccs_bytes_to_cpy && !src_is_lmem)
if (!src_is_lmem)
/* /*
* When CHUNK_SZ is passed all the pages upto CHUNK_SZ * When CHUNK_SZ is passed all the pages upto CHUNK_SZ
* will be taken for the blt. in Flat-ccs supported * will be taken for the blt. in Flat-ccs supported
...@@ -663,15 +662,14 @@ calculate_chunk_sz(struct drm_i915_private *i915, bool src_is_lmem, ...@@ -663,15 +662,14 @@ calculate_chunk_sz(struct drm_i915_private *i915, bool src_is_lmem,
* for main meory hence limit it to the required size * for main meory hence limit it to the required size
* for main memory * for main memory
*/ */
*src_sz = min_t(int, bytes_to_cpy, CHUNK_SZ); return min_t(u64, bytes_to_cpy, CHUNK_SZ);
} else { /* ccs handling is not required */ else
*src_sz = CHUNK_SZ; return CHUNK_SZ;
}
} }
static void get_ccs_sg_sgt(struct sgt_dma *it, u32 bytes_to_cpy) static void get_ccs_sg_sgt(struct sgt_dma *it, u64 bytes_to_cpy)
{ {
u32 len; u64 len;
do { do {
GEM_BUG_ON(!it->sg || !sg_dma_len(it->sg)); GEM_BUG_ON(!it->sg || !sg_dma_len(it->sg));
...@@ -702,12 +700,12 @@ intel_context_migrate_copy(struct intel_context *ce, ...@@ -702,12 +700,12 @@ intel_context_migrate_copy(struct intel_context *ce,
{ {
struct sgt_dma it_src = sg_sgt(src), it_dst = sg_sgt(dst), it_ccs; struct sgt_dma it_src = sg_sgt(src), it_dst = sg_sgt(dst), it_ccs;
struct drm_i915_private *i915 = ce->engine->i915; struct drm_i915_private *i915 = ce->engine->i915;
u32 ccs_bytes_to_cpy = 0, bytes_to_cpy; u64 ccs_bytes_to_cpy = 0, bytes_to_cpy;
enum i915_cache_level ccs_cache_level; enum i915_cache_level ccs_cache_level;
u32 src_offset, dst_offset; u32 src_offset, dst_offset;
u8 src_access, dst_access; u8 src_access, dst_access;
struct i915_request *rq; struct i915_request *rq;
int src_sz, dst_sz; u64 src_sz, dst_sz;
bool ccs_is_src, overwrite_ccs; bool ccs_is_src, overwrite_ccs;
int err; int err;
...@@ -790,7 +788,7 @@ intel_context_migrate_copy(struct intel_context *ce, ...@@ -790,7 +788,7 @@ intel_context_migrate_copy(struct intel_context *ce,
if (err) if (err)
goto out_rq; goto out_rq;
calculate_chunk_sz(i915, src_is_lmem, &src_sz, src_sz = calculate_chunk_sz(i915, src_is_lmem,
bytes_to_cpy, ccs_bytes_to_cpy); bytes_to_cpy, ccs_bytes_to_cpy);
len = emit_pte(rq, &it_src, src_cache_level, src_is_lmem, len = emit_pte(rq, &it_src, src_cache_level, src_is_lmem,
......
...@@ -4026,6 +4026,13 @@ static inline void guc_init_lrc_mapping(struct intel_guc *guc) ...@@ -4026,6 +4026,13 @@ static inline void guc_init_lrc_mapping(struct intel_guc *guc)
/* make sure all descriptors are clean... */ /* make sure all descriptors are clean... */
xa_destroy(&guc->context_lookup); xa_destroy(&guc->context_lookup);
/*
* A reset might have occurred while we had a pending stalled request,
* so make sure we clean that up.
*/
guc->stalled_request = NULL;
guc->submission_stall_reason = STALL_NONE;
/* /*
* Some contexts might have been pinned before we enabled GuC * Some contexts might have been pinned before we enabled GuC
* submission, so we need to add them to the GuC bookeeping. * submission, so we need to add them to the GuC bookeeping.
......
...@@ -298,7 +298,7 @@ static int alloc_resource(struct intel_vgpu *vgpu, ...@@ -298,7 +298,7 @@ static int alloc_resource(struct intel_vgpu *vgpu,
} }
/** /**
* inte_gvt_free_vgpu_resource - free HW resource owned by a vGPU * intel_vgpu_free_resource() - free HW resource owned by a vGPU
* @vgpu: a vGPU * @vgpu: a vGPU
* *
* This function is used to free the HW resource owned by a vGPU. * This function is used to free the HW resource owned by a vGPU.
...@@ -328,7 +328,7 @@ void intel_vgpu_reset_resource(struct intel_vgpu *vgpu) ...@@ -328,7 +328,7 @@ void intel_vgpu_reset_resource(struct intel_vgpu *vgpu)
} }
/** /**
* intel_alloc_vgpu_resource - allocate HW resource for a vGPU * intel_vgpu_alloc_resource() - allocate HW resource for a vGPU
* @vgpu: vGPU * @vgpu: vGPU
* @param: vGPU creation params * @param: vGPU creation params
* *
......
...@@ -2341,7 +2341,7 @@ static int emulate_ggtt_mmio_write(struct intel_vgpu *vgpu, unsigned int off, ...@@ -2341,7 +2341,7 @@ static int emulate_ggtt_mmio_write(struct intel_vgpu *vgpu, unsigned int off,
gvt_vgpu_err("fail to populate guest ggtt entry\n"); gvt_vgpu_err("fail to populate guest ggtt entry\n");
/* guest driver may read/write the entry when partial /* guest driver may read/write the entry when partial
* update the entry in this situation p2m will fail * update the entry in this situation p2m will fail
* settting the shadow entry to point to a scratch page * setting the shadow entry to point to a scratch page
*/ */
ops->set_pfn(&m, gvt->gtt.scratch_mfn); ops->set_pfn(&m, gvt->gtt.scratch_mfn);
} else } else
......
...@@ -905,7 +905,7 @@ static int update_fdi_rx_iir_status(struct intel_vgpu *vgpu, ...@@ -905,7 +905,7 @@ static int update_fdi_rx_iir_status(struct intel_vgpu *vgpu,
else if (FDI_RX_IMR_TO_PIPE(offset) != INVALID_INDEX) else if (FDI_RX_IMR_TO_PIPE(offset) != INVALID_INDEX)
index = FDI_RX_IMR_TO_PIPE(offset); index = FDI_RX_IMR_TO_PIPE(offset);
else { else {
gvt_vgpu_err("Unsupport registers %x\n", offset); gvt_vgpu_err("Unsupported registers %x\n", offset);
return -EINVAL; return -EINVAL;
} }
...@@ -3052,7 +3052,7 @@ int intel_vgpu_default_mmio_read(struct intel_vgpu *vgpu, unsigned int offset, ...@@ -3052,7 +3052,7 @@ int intel_vgpu_default_mmio_read(struct intel_vgpu *vgpu, unsigned int offset,
} }
/** /**
* intel_t_default_mmio_write - default MMIO write handler * intel_vgpu_default_mmio_write() - default MMIO write handler
* @vgpu: a vGPU * @vgpu: a vGPU
* @offset: access offset * @offset: access offset
* @p_data: write data buffer * @p_data: write data buffer
......
...@@ -546,7 +546,7 @@ static void switch_mmio(struct intel_vgpu *pre, ...@@ -546,7 +546,7 @@ static void switch_mmio(struct intel_vgpu *pre,
} }
/** /**
* intel_gvt_switch_render_mmio - switch mmio context of specific engine * intel_gvt_switch_mmio - switch mmio context of specific engine
* @pre: the last vGPU that own the engine * @pre: the last vGPU that own the engine
* @next: the vGPU to switch to * @next: the vGPU to switch to
* @engine: the engine * @engine: the engine
......
...@@ -1076,7 +1076,8 @@ static int iterate_skl_plus_mmio(struct intel_gvt_mmio_table_iter *iter) ...@@ -1076,7 +1076,8 @@ static int iterate_skl_plus_mmio(struct intel_gvt_mmio_table_iter *iter)
MMIO_D(GEN8_HDC_CHICKEN1); MMIO_D(GEN8_HDC_CHICKEN1);
MMIO_D(GEN9_WM_CHICKEN3); MMIO_D(GEN9_WM_CHICKEN3);
if (IS_KABYLAKE(dev_priv) || IS_COFFEELAKE(dev_priv)) if (IS_KABYLAKE(dev_priv) ||
IS_COFFEELAKE(dev_priv) || IS_COMETLAKE(dev_priv))
MMIO_D(GAMT_CHKN_BIT_REG); MMIO_D(GAMT_CHKN_BIT_REG);
if (!IS_BROXTON(dev_priv)) if (!IS_BROXTON(dev_priv))
MMIO_D(GEN9_CTX_PREEMPT_REG); MMIO_D(GEN9_CTX_PREEMPT_REG);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment