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:
parent
df7ee10d98
commit
dfd51be3ca
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue