diff options
author | Dave Airlie <airlied@redhat.com> | 2018-09-27 19:37:51 -0400 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2018-09-27 19:37:55 -0400 |
commit | db9825c95498280718c4687fcf712016f5b6f5f6 (patch) | |
tree | 01661a811bcd16a7b6f3ee9790e77da75fd178b0 /drivers/gpu/drm/i915/i915_request.c | |
parent | 156e60bc71aa31a3b42b1d66a822c2999bd0994c (diff) | |
parent | 448626103dad54ec5d06722e955586b5d557625d (diff) |
Merge tag 'drm-intel-next-2018-09-21' of git://anongit.freedesktop.org/drm/drm-intel into drm-next
Driver Changes:
- Bugzilla 107600: Fix stuttering video playback on MythTV on old hardware (Chris)
- Avoid black screen when using CSC coefficient matrix (Raviraj)
- Hammer PDs on Baytrail to make sure they reload (Chris)
- Capture some objects if unable to capture all, on error (Chris)
- Add W/A for 16 GB DIMMs on SKL+ (Mahesh)
- Only enable IPC for symmetric memory configurations on KBL+ (Mahesh)
- Assume pipe A to have maximum stride limits (Ville)
- Always update update OA contexts via context image (Tvrtko)
- Icelake enabling patches (Madhav, Dhinakaran)
- Add Icelake DMC firmware (Anusha)
- Fixes for CI found corner cases (Chris)
- Limit the backpressure for request allocation (Chris)
- Park GPU on module load so usage starts from known state (Chris)
- Flush tasklet when checking for idle (Chris)
- Use coherent write into the context image on BSW+ (Chris)
- Fix possible integer overflow for framebuffers that get aligned past 4GiB (Ville)
- Downgrade fence timeout from warn to notice and add debug hint (Chris)
- Fixes to multi function encoder code (Ville)
- Fix sprite plane check logic (Dan, Ville)
- PAGE_SIZE vs. I915_GTT_PAGE_SIZE fixes (Ville)
- Decode memory bandwidth and parameters for BXT and SKL+ (Mahesh)
- Overwrite BIOS set IPC value from KMS (Mahesh)
- Multiple pipe handling code cleanups/restructurings/optimizations (Ville)
- Spare low 4G address for non-48bit objects (Chris)
- Free context_setparam of struct_mutex (Chris)
- Delay updating ring register state on resume (Chris)
- Avoid unnecessarily copying overlay IOCTL parameters (Chris)
- Update GuC power domain states even without submission (Michal)
- Restore GuC preempt-context across S3/S4 (Chris)
- Add kernel selftest for rapid context switching (Chris)
- Keep runtime power management ref for live selftests (Chris)
- GEM code cleanups (Matt)
Signed-off-by: Dave Airlie <airlied@redhat.com>
From: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20180927095933.GA11458@jlahtine-desk.ger.corp.intel.com
Diffstat (limited to 'drivers/gpu/drm/i915/i915_request.c')
-rw-r--r-- | drivers/gpu/drm/i915/i915_request.c | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/drivers/gpu/drm/i915/i915_request.c b/drivers/gpu/drm/i915/i915_request.c index 09ed48833b54..a492385b2089 100644 --- a/drivers/gpu/drm/i915/i915_request.c +++ b/drivers/gpu/drm/i915/i915_request.c | |||
@@ -732,13 +732,13 @@ i915_request_alloc(struct intel_engine_cs *engine, struct i915_gem_context *ctx) | |||
732 | rq = kmem_cache_alloc(i915->requests, | 732 | rq = kmem_cache_alloc(i915->requests, |
733 | GFP_KERNEL | __GFP_RETRY_MAYFAIL | __GFP_NOWARN); | 733 | GFP_KERNEL | __GFP_RETRY_MAYFAIL | __GFP_NOWARN); |
734 | if (unlikely(!rq)) { | 734 | if (unlikely(!rq)) { |
735 | i915_retire_requests(i915); | ||
736 | |||
735 | /* Ratelimit ourselves to prevent oom from malicious clients */ | 737 | /* Ratelimit ourselves to prevent oom from malicious clients */ |
736 | ret = i915_gem_wait_for_idle(i915, | 738 | rq = i915_gem_active_raw(&ce->ring->timeline->last_request, |
737 | I915_WAIT_LOCKED | | 739 | &i915->drm.struct_mutex); |
738 | I915_WAIT_INTERRUPTIBLE, | 740 | if (rq) |
739 | MAX_SCHEDULE_TIMEOUT); | 741 | cond_synchronize_rcu(rq->rcustate); |
740 | if (ret) | ||
741 | goto err_unreserve; | ||
742 | 742 | ||
743 | /* | 743 | /* |
744 | * We've forced the client to stall and catch up with whatever | 744 | * We've forced the client to stall and catch up with whatever |
@@ -758,6 +758,8 @@ i915_request_alloc(struct intel_engine_cs *engine, struct i915_gem_context *ctx) | |||
758 | } | 758 | } |
759 | } | 759 | } |
760 | 760 | ||
761 | rq->rcustate = get_state_synchronize_rcu(); | ||
762 | |||
761 | INIT_LIST_HEAD(&rq->active_list); | 763 | INIT_LIST_HEAD(&rq->active_list); |
762 | rq->i915 = i915; | 764 | rq->i915 = i915; |
763 | rq->engine = engine; | 765 | rq->engine = engine; |