aboutsummaryrefslogtreecommitdiffstats
path: root/lib/debugobjects.c
diff options
context:
space:
mode:
authorDave Gordon <david.s.gordon@intel.com>2016-05-20 11:54:07 +0100
committerChris Wilson <chris@chris-wilson.co.uk>2016-05-20 13:43:00 +0100
commit63d15326168d54cfef082f6899c86f8260db4037 (patch)
tree572c3a0e87f9f1b1c4ec0a551d8e5518f2893317 /lib/debugobjects.c
parentdrm/i915: Introduce & use new lightweight SGL iterators (diff)
downloadlinux-rng-63d15326168d54cfef082f6899c86f8260db4037.tar.xz
linux-rng-63d15326168d54cfef082f6899c86f8260db4037.zip
drm/i915: Inline sg_next() for the optimised SGL iterator
Avoiding the out-of-line call to sg_next() reduces the kernel execution overhead by 10% in some workloads (for example the Unreal Engine 4 demo Atlantis on 2GiB GTTs) which are dominated by the cost of inserting PTEs due to texture thrashing. We can demonstrate this in a microbenchmark that forces us to rebind the object on every execbuf, where we can measure a 25% improvement, in the time required to execute an execbuf requiring a texture to be rebound, for inlining the sg_next() for large texture sizes. Benchmark: igt/benchmarks/gem_exec_fault Benchmark: igt/benchmarks/gem_exec_trace/Atlantis Signed-off-by: Dave Gordon <david.s.gordon@intel.com> Cc: Chris Wilson <chris@chris-wilson.co.uk> Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk> Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Link: http://patchwork.freedesktop.org/patch/msgid/1463741647-15666-5-git-send-email-chris@chris-wilson.co.uk
Diffstat (limited to 'lib/debugobjects.c')
0 files changed, 0 insertions, 0 deletions