diff options
author | Eric Anholt <eric@anholt.net> | 2008-11-07 12:58:52 -0800 |
---|---|---|
committer | Eric Anholt <eric@anholt.net> | 2008-11-07 12:59:43 -0800 |
commit | 930c0e7cf4f4776f7a69e7acc6fedeed7addb235 (patch) | |
tree | 6ef94d20a2cf1e9462c82982e00e47cc374cbd8d /libdrm | |
parent | 87e90c73620b88005fcca5fd40aaaad0b08932e1 (diff) |
intel: Restart on interrupt of bo_wait_rendering instead of complaining.
Diffstat (limited to 'libdrm')
-rw-r--r-- | libdrm/intel/intel_bufmgr_gem.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/libdrm/intel/intel_bufmgr_gem.c b/libdrm/intel/intel_bufmgr_gem.c index 5eaf5f5a..9cb33598 100644 --- a/libdrm/intel/intel_bufmgr_gem.c +++ b/libdrm/intel/intel_bufmgr_gem.c @@ -658,7 +658,9 @@ drm_intel_gem_bo_wait_rendering(drm_intel_bo *bo) set_domain.handle = bo_gem->gem_handle; set_domain.read_domains = I915_GEM_DOMAIN_GTT; set_domain.write_domain = 0; - ret = ioctl (bufmgr_gem->fd, DRM_IOCTL_I915_GEM_SET_DOMAIN, &set_domain); + do { + ret = ioctl(bufmgr_gem->fd, DRM_IOCTL_I915_GEM_SET_DOMAIN, &set_domain); + } while (ret == -1 && errno == EINTR); if (ret != 0) { fprintf (stderr, "%s:%d: Error setting memory domains %d (%08x %08x): %s .\n", __FILE__, __LINE__, |