mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-01-07 19:30:12 +01:00
glx/drisw: add getImageShm2 path
This adds return values to the get image path, so the caller can fallback.
Fixes: 02c3dad0f3 ("Call shmget() with permission 0600 instead of 0777")
Reviewed-by: Michel Dänzer <mdaenzer@redhat.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/merge_requests/3823>
This commit is contained in:
parent
466a0b2e49
commit
8d0bab8a93
1 changed files with 16 additions and 6 deletions
|
|
@ -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[] = {
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue