xwayland: Do not free a NULL GBM bo

Both `gbm_bo_create()` and `gbm_bo_create_with_modifiers()` can fail and
return `NULL`.

If that occurs, `xwl_glamor_gbm_create_pixmap()` will not create a
pixmap for the (NULL) GBM bo, but would still try to free the bo which
leads to a crash in mesa:

  [...]
  #7  <signal handler called>
  #8  in gbm_bo_destroy (bo=0x0) at ../src/gbm/main/gbm.c:439
  #9  in xwl_glamor_gbm_create_pixmap () at xwayland-glamor-gbm.c:245
  #10 in ProcCreatePixmap () at dispatch.c:1440
  #11 in Dispatch () at dispatch.c:478
  #12 in dix_main () at main.c:276

To avoid the crash, only free the GBM bo if not `NULL`.

Signed-off-by: Olivier Fourdan <ofourdan@redhat.com>
Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
Bugzilla: https://bugzilla.redhat.com/1729925
(cherry picked from commit d9ec525059)
This commit is contained in:
Olivier Fourdan 2019-07-23 11:01:47 +02:00 committed by Adam Jackson
parent df7ee10d98
commit dfd51be3ca

View File

@ -238,12 +238,13 @@ xwl_glamor_gbm_create_pixmap(ScreenPtr screen,
GBM_BO_USE_SCANOUT | GBM_BO_USE_RENDERING); GBM_BO_USE_SCANOUT | GBM_BO_USE_RENDERING);
} }
if (bo) if (bo) {
pixmap = xwl_glamor_gbm_create_pixmap_for_bo(screen, bo, depth); pixmap = xwl_glamor_gbm_create_pixmap_for_bo(screen, bo, depth);
if (!pixmap) if (!pixmap)
gbm_bo_destroy(bo); gbm_bo_destroy(bo);
} }
}
if (!pixmap) if (!pixmap)
pixmap = glamor_create_pixmap(screen, width, height, depth, hint); pixmap = glamor_create_pixmap(screen, width, height, depth, hint);