diff options
author | Dave Airlie <[email protected]> | 2020-02-14 15:03:24 +1000 |
---|---|---|
committer | Marge Bot <[email protected]> | 2020-02-25 01:23:01 +0000 |
commit | 8d0bab8a9352bbb780bae6e7a432e73f7204f66a (patch) | |
tree | 86098f3ec42781e838ed33786cd340457a7af2bc /src/glx | |
parent | 466a0b2e4953018646ee344f5f6f6e9e84b66a1a (diff) |
glx/drisw: add getImageShm2 path
This adds return values to the get image path, so the caller can fallback.
Fixes: 02c3dad0f3b4 ("Call shmget() with permission 0600 instead of 0777")
Reviewed-by: Michel Dänzer <[email protected]>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/merge_requests/3823>
Diffstat (limited to 'src/glx')
-rw-r--r-- | src/glx/drisw_glx.c | 22 |
1 files changed, 16 insertions, 6 deletions
diff --git a/src/glx/drisw_glx.c b/src/glx/drisw_glx.c index 069f64d5216..6e37f0274b0 100644 --- a/src/glx/drisw_glx.c +++ b/src/glx/drisw_glx.c @@ -288,10 +288,10 @@ swrastGetImage(__DRIdrawable * read, swrastGetImage2(read, x, y, w, h, 0, data, loaderPrivate); } -static void -swrastGetImageShm(__DRIdrawable * read, - int x, int y, int w, int h, - int shmid, void *loaderPrivate) +static GLboolean +swrastGetImageShm2(__DRIdrawable * read, + int x, int y, int w, int h, + int shmid, void *loaderPrivate) { struct drisw_drawable *prp = loaderPrivate; __GLXDRIdrawable *pread = &(prp->base); @@ -301,7 +301,7 @@ swrastGetImageShm(__DRIdrawable * read, if (!prp->ximage || shmid != prp->shminfo.shmid) { if (!XCreateDrawable(prp, shmid, dpy)) - return; + return GL_FALSE; } readable = pread->xDrawable; @@ -312,10 +312,19 @@ swrastGetImageShm(__DRIdrawable * read, ximage->bytes_per_line = bytes_per_line(w * ximage->bits_per_pixel, 32); XShmGetImage(dpy, readable, ximage, x, y, ~0L); + return GL_TRUE; +} + +static void +swrastGetImageShm(__DRIdrawable * read, + int x, int y, int w, int h, + int shmid, void *loaderPrivate) +{ + swrastGetImageShm2(read, x, y, w, h, shmid, loaderPrivate); } static const __DRIswrastLoaderExtension swrastLoaderExtension_shm = { - .base = {__DRI_SWRAST_LOADER, 5 }, + .base = {__DRI_SWRAST_LOADER, 6 }, .getDrawableInfo = swrastGetDrawableInfo, .putImage = swrastPutImage, @@ -325,6 +334,7 @@ static const __DRIswrastLoaderExtension swrastLoaderExtension_shm = { .putImageShm = swrastPutImageShm, .getImageShm = swrastGetImageShm, .putImageShm2 = swrastPutImageShm2, + .getImageShm2 = swrastGetImageShm2, }; static const __DRIextension *loader_extensions_shm[] = { |