summaryrefslogtreecommitdiff
path: root/include/xen
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2015-07-16 14:37:56 +0300
committerDaniel Vetter <daniel.vetter@ffwll.ch>2015-07-21 12:49:13 +0300
commit648a9bc5308d952f2c80772301b339f73026f013 (patch)
tree009210e7ebeb563ada53f3b36bc9b176aa25ce74 /include/xen
parent52721d9d3334c1cb1f76219a161084094ec634dc (diff)
downloadlinux-648a9bc5308d952f2c80772301b339f73026f013.tar.xz
drm/i915: Use two 32bit reads for select 64bit REG_READ ioctls
Since the hardware sometimes mysteriously totally flummoxes the 64bit read of a 64bit register when read using a single instruction, split the read into two instructions. Since the read here is of automatically incrementing timestamp counters, we also have to be very careful in order to make sure that it does not increment between the two instructions. However, since userspace tried to workaround this issue and so enshrined this ABI for a broken hardware read and in the process neglected that the read only fails in some environments, we have to introduce a new uABI flag for userspace to request the 2x32 bit accurate read of the timestamp. v2: Fix alignment check and include details of the workaround for userspace. Reported-by: Karol Herbst <freedesktop@karolherbst.de> Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=91317 Testcase: igt/gem_reg_read Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk> Cc: Michał Winiarski <michal.winiarski@intel.com> Cc: stable@vger.kernel.org Tested-by: Michał Winiarski <michal.winiarski@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'include/xen')
0 files changed, 0 insertions, 0 deletions