radeon_drm_bo: explicitly check return value of drmCommandWriteRead
authorJulien Isorce <jisorce@oblong.com>
Wed, 15 Mar 2017 17:40:25 +0000 (17:40 +0000)
committerJulien Isorce <jisorce@oblong.com>
Mon, 20 Mar 2017 18:01:51 +0000 (18:01 +0000)
CID 1313492

Signed-off-by: Julien Isorce <jisorce@oblong.com>
Reviewed-by: Marek Olšák <marek.olsak@amd.com>
src/gallium/winsys/radeon/drm/radeon_drm_bo.c

index f4ed3ce632bc8b22a278b60346c9ebeba88133ba..f6d5c8a51c3308b73fc16336b14c1bc393d433c5 100644 (file)
@@ -186,8 +186,13 @@ static enum radeon_bo_domain radeon_bo_get_initial_domain(
     args.handle = bo->handle;
     args.op = RADEON_GEM_OP_GET_INITIAL_DOMAIN;
 
-    drmCommandWriteRead(bo->rws->fd, DRM_RADEON_GEM_OP,
-                        &args, sizeof(args));
+    if (drmCommandWriteRead(bo->rws->fd, DRM_RADEON_GEM_OP,
+                            &args, sizeof(args))) {
+        fprintf(stderr, "radeon: failed to get initial domain: %p 0x%08X\n",
+                bo, bo->handle);
+        /* Default domain as returned by get_valid_domain. */
+        return RADEON_DOMAIN_VRAM_GTT;
+    }
 
     /* GEM domains and winsys domains are defined the same. */
     return get_valid_domain(args.value);