Commit e5a1ad03 authored by Matthew Brost's avatar Matthew Brost Committed by John Harrison

drm/i915/guc: Add disable interrupts to guc sanitize

Add disable GuC interrupts to intel_guc_sanitize(). Part of this
requires moving the guc_*_interrupt wrapper function into header file
intel_guc.h.
Signed-off-by: default avatarMatthew Brost <matthew.brost@intel.com>
Cc: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Reviewed-by: default avatarJohn Harrison <John.C.Harrison@Intel.com>
Signed-off-by: default avatarJohn Harrison <John.C.Harrison@Intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210727002348.97202-11-matthew.brost@intel.com
parent c41ee287
...@@ -224,9 +224,25 @@ static inline bool intel_guc_is_ready(struct intel_guc *guc) ...@@ -224,9 +224,25 @@ static inline bool intel_guc_is_ready(struct intel_guc *guc)
return intel_guc_is_fw_running(guc) && intel_guc_ct_enabled(&guc->ct); return intel_guc_is_fw_running(guc) && intel_guc_ct_enabled(&guc->ct);
} }
static inline void intel_guc_reset_interrupts(struct intel_guc *guc)
{
guc->interrupts.reset(guc);
}
static inline void intel_guc_enable_interrupts(struct intel_guc *guc)
{
guc->interrupts.enable(guc);
}
static inline void intel_guc_disable_interrupts(struct intel_guc *guc)
{
guc->interrupts.disable(guc);
}
static inline int intel_guc_sanitize(struct intel_guc *guc) static inline int intel_guc_sanitize(struct intel_guc *guc)
{ {
intel_uc_fw_sanitize(&guc->fw); intel_uc_fw_sanitize(&guc->fw);
intel_guc_disable_interrupts(guc);
intel_guc_ct_sanitize(&guc->ct); intel_guc_ct_sanitize(&guc->ct);
guc->mmio_msg = 0; guc->mmio_msg = 0;
......
...@@ -207,21 +207,6 @@ static void guc_handle_mmio_msg(struct intel_guc *guc) ...@@ -207,21 +207,6 @@ static void guc_handle_mmio_msg(struct intel_guc *guc)
spin_unlock_irq(&guc->irq_lock); spin_unlock_irq(&guc->irq_lock);
} }
static void guc_reset_interrupts(struct intel_guc *guc)
{
guc->interrupts.reset(guc);
}
static void guc_enable_interrupts(struct intel_guc *guc)
{
guc->interrupts.enable(guc);
}
static void guc_disable_interrupts(struct intel_guc *guc)
{
guc->interrupts.disable(guc);
}
static int guc_enable_communication(struct intel_guc *guc) static int guc_enable_communication(struct intel_guc *guc)
{ {
struct intel_gt *gt = guc_to_gt(guc); struct intel_gt *gt = guc_to_gt(guc);
...@@ -242,7 +227,7 @@ static int guc_enable_communication(struct intel_guc *guc) ...@@ -242,7 +227,7 @@ static int guc_enable_communication(struct intel_guc *guc)
guc_get_mmio_msg(guc); guc_get_mmio_msg(guc);
guc_handle_mmio_msg(guc); guc_handle_mmio_msg(guc);
guc_enable_interrupts(guc); intel_guc_enable_interrupts(guc);
/* check for CT messages received before we enabled interrupts */ /* check for CT messages received before we enabled interrupts */
spin_lock_irq(&gt->irq_lock); spin_lock_irq(&gt->irq_lock);
...@@ -265,7 +250,7 @@ static void guc_disable_communication(struct intel_guc *guc) ...@@ -265,7 +250,7 @@ static void guc_disable_communication(struct intel_guc *guc)
*/ */
guc_clear_mmio_msg(guc); guc_clear_mmio_msg(guc);
guc_disable_interrupts(guc); intel_guc_disable_interrupts(guc);
intel_guc_ct_disable(&guc->ct); intel_guc_ct_disable(&guc->ct);
...@@ -463,7 +448,7 @@ static int __uc_init_hw(struct intel_uc *uc) ...@@ -463,7 +448,7 @@ static int __uc_init_hw(struct intel_uc *uc)
if (ret) if (ret)
goto err_out; goto err_out;
guc_reset_interrupts(guc); intel_guc_reset_interrupts(guc);
/* WaEnableuKernelHeaderValidFix:skl */ /* WaEnableuKernelHeaderValidFix:skl */
/* WaEnableGuCBootHashCheckNotSet:skl,bxt,kbl */ /* WaEnableGuCBootHashCheckNotSet:skl,bxt,kbl */
......
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