aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/i915_gem_execbuffer.c
diff options
context:
space:
mode:
authorZhipeng Gong <zhipeng.gong@intel.com>2015-01-12 19:48:24 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2015-01-27 03:51:05 -0500
commit8d360dffd6d8634868e433128d5178bea14cc42c (patch)
tree46ab29a3b0c824c346ebb939203b1c6fb7c82646 /drivers/gpu/drm/i915/i915_gem_execbuffer.c
parent5724dbd1678e2f573b13f0688277941fad66cb88 (diff)
drm/i915: Specify bsd rings through exec flag
On Skylake GT3 we have 2 Video Command Streamers (VCS), which is asymmetrical. For example, HEVC GPU commands can be only dispatched to VCS1 ring. But userspace has no control when using VCS1 or VCS2. This patch introduces a mechanism to avoid the default ping-pong mode and use one specific ring through execution flag. This mechanism is usable for all the platforms with 2 VCS rings. The open source usage is from these two commits in vaapi/intel: commit 702050f04131a44ef8ac16651708ce8a8d98e4b8 Author: Zhao, Yakui <yakui.zhao@intel.com> Date: Mon Nov 17 12:44:19 2014 +0800 Allow the batchbuffer to be submitted with override flag commit a56efcdf27d11ad9b21664b4a2cda72d7f90f5a8 Author: Zhao Yakui <yakui.zhao@intel.com> Date: Mon Nov 17 12:44:22 2014 +0800 Add the override flag to assure that HEVC video command always uses BSD ring0 for SKL GT3 machine v2: fix whitespace (Rodrigo) v3: remove incorrect chunk that came on -collector rebase. (Rodrigo) v4: change the comment (Zhipeng) v5: address Daniel's comment (Zhipeng) Signed-off-by: Zhipeng Gong <zhipeng.gong@intel.com> Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/i915_gem_execbuffer.c')
-rw-r--r--drivers/gpu/drm/i915/i915_gem_execbuffer.c26
1 files changed, 24 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/i915_gem_execbuffer.c b/drivers/gpu/drm/i915/i915_gem_execbuffer.c
index e3ef17783765..b773368fc62c 100644
--- a/drivers/gpu/drm/i915/i915_gem_execbuffer.c
+++ b/drivers/gpu/drm/i915/i915_gem_execbuffer.c
@@ -1380,13 +1380,35 @@ i915_gem_do_execbuffer(struct drm_device *dev, void *data,
1380 return -EINVAL; 1380 return -EINVAL;
1381 } 1381 }
1382 1382
1383 if (((args->flags & I915_EXEC_RING_MASK) != I915_EXEC_BSD) &&
1384 ((args->flags & I915_EXEC_BSD_MASK) != 0)) {
1385 DRM_DEBUG("execbuf with non bsd ring but with invalid "
1386 "bsd dispatch flags: %d\n", (int)(args->flags));
1387 return -EINVAL;
1388 }
1389
1383 if ((args->flags & I915_EXEC_RING_MASK) == I915_EXEC_DEFAULT) 1390 if ((args->flags & I915_EXEC_RING_MASK) == I915_EXEC_DEFAULT)
1384 ring = &dev_priv->ring[RCS]; 1391 ring = &dev_priv->ring[RCS];
1385 else if ((args->flags & I915_EXEC_RING_MASK) == I915_EXEC_BSD) { 1392 else if ((args->flags & I915_EXEC_RING_MASK) == I915_EXEC_BSD) {
1386 if (HAS_BSD2(dev)) { 1393 if (HAS_BSD2(dev)) {
1387 int ring_id; 1394 int ring_id;
1388 ring_id = gen8_dispatch_bsd_ring(dev, file); 1395
1389 ring = &dev_priv->ring[ring_id]; 1396 switch (args->flags & I915_EXEC_BSD_MASK) {
1397 case I915_EXEC_BSD_DEFAULT:
1398 ring_id = gen8_dispatch_bsd_ring(dev, file);
1399 ring = &dev_priv->ring[ring_id];
1400 break;
1401 case I915_EXEC_BSD_RING1:
1402 ring = &dev_priv->ring[VCS];
1403 break;
1404 case I915_EXEC_BSD_RING2:
1405 ring = &dev_priv->ring[VCS2];
1406 break;
1407 default:
1408 DRM_DEBUG("execbuf with unknown bsd ring: %d\n",
1409 (int)(args->flags & I915_EXEC_BSD_MASK));
1410 return -EINVAL;
1411 }
1390 } else 1412 } else
1391 ring = &dev_priv->ring[VCS]; 1413 ring = &dev_priv->ring[VCS];
1392 } else 1414 } else