]> git.baikalelectronics.ru Git - kernel.git/commit
drm/i915: Declare the swizzling unknown for L-shaped configurations
authorChris Wilson <chris@chris-wilson.co.uk>
Mon, 29 Jun 2015 13:01:19 +0000 (14:01 +0100)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Thu, 9 Jul 2015 07:36:44 +0000 (09:36 +0200)
commit8fe661cc490b72a98a7beca2d707befb78a1c4c0
tree7fac6c795d3c0fb87ccf235dd7eea63d2a801780
parent3fc9e1207603b6b1f1a16a5a23cbabed17ea63ea
drm/i915: Declare the swizzling unknown for L-shaped configurations

The old style of memory interleaving swizzled upto the end of the
first even bank of memory, and then used the remainder as unswizzled on
the unpaired bank - i.e. swizzling is not constant for all memory. This
causes problems when we try to migrate memory and so the kernel prevents
migration at all when we detect L-shaped inconsistent swizzling.
However, this issue also extends to userspace who try to manually detile
into memory as the swizzling for an individual page is unknown (it
depends on its physical address only known to the kernel), userspace
cannot correctly swizzle objects.

v2: Mark the global swizzling as unknown rather than adjust the value
reported to userspace.

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=91105
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
Cc: stable@vger.kernel.org
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
drivers/gpu/drm/i915/i915_gem_tiling.c