summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDave Airlie <airlied@gmail.com>2016-05-06 10:46:14 +1000
committerAdam Jackson <ajax@redhat.com>2016-06-08 12:51:51 -0400
commita6b6e8ba026acedef6336b17adf06aebddd5f22f (patch)
tree17087dc2c6efbc2551382ff27761524bb800a541
parentaa5390aa83be55f887e3b4f78681b4f3d3386eb5 (diff)
prime: clean up slave bo properly. (v3)
This is an ABI break, in that we now pass NULL to a function that hasn't accepted it before. Alex Goins had a different patch for this but it wasn't symmetrical, it freed something in a very different place than it allocated it, this attempts to retain symmetry in the releasing of the backing bo. v2: use a new toplevel API, though it still passes NULL to something that wasn't expecting it. v3: pass -1 instead of 0. Signed-off-by: Dave Airlie <airlied@redhat.com> Tested-by: Hans de Goede <hdegoede@redhat.com> Reviewed-by: Hans de Goede <hdegoede@redhat.com> Reviewed-by: Alex Goins <agoins at nvidia.com>
-rw-r--r--dix/pixmap.c7
-rw-r--r--hw/xfree86/dri2/dri2.c1
-rw-r--r--hw/xfree86/drivers/modesetting/driver.c4
-rw-r--r--hw/xfree86/drivers/modesetting/drmmode_display.c6
-rw-r--r--include/pixmap.h3
-rw-r--r--randr/rrcrtc.c2
6 files changed, 23 insertions, 0 deletions
diff --git a/dix/pixmap.c b/dix/pixmap.c
index 11d83fe00..49267a19b 100644
--- a/dix/pixmap.c
+++ b/dix/pixmap.c
@@ -132,6 +132,13 @@ FreePixmap(PixmapPtr pPixmap)
free(pPixmap);
}
+void PixmapUnshareSlavePixmap(PixmapPtr slave_pixmap)
+{
+ int ihandle = -1;
+ ScreenPtr pScreen = slave_pixmap->drawable.pScreen;
+ pScreen->SetSharedPixmapBacking(slave_pixmap, ((void *)(long)ihandle));
+}
+
PixmapPtr PixmapShareToSlave(PixmapPtr pixmap, ScreenPtr slave)
{
PixmapPtr spix;
diff --git a/hw/xfree86/dri2/dri2.c b/hw/xfree86/dri2/dri2.c
index d55be1913..f80599fb7 100644
--- a/hw/xfree86/dri2/dri2.c
+++ b/hw/xfree86/dri2/dri2.c
@@ -859,6 +859,7 @@ DrawablePtr DRI2UpdatePrime(DrawablePtr pDraw, DRI2BufferPtr pDest)
if (pPriv->prime_slave_pixmap->master_pixmap == mpix)
return &pPriv->prime_slave_pixmap->drawable;
else {
+ PixmapUnshareSlavePixmap(pPriv->prime_slave_pixmap);
(*pPriv->prime_slave_pixmap->master_pixmap->drawable.pScreen->DestroyPixmap)(pPriv->prime_slave_pixmap->master_pixmap);
(*slave->DestroyPixmap)(pPriv->prime_slave_pixmap);
pPriv->prime_slave_pixmap = NULL;
diff --git a/hw/xfree86/drivers/modesetting/driver.c b/hw/xfree86/drivers/modesetting/driver.c
index cd59c066d..1604044b2 100644
--- a/hw/xfree86/drivers/modesetting/driver.c
+++ b/hw/xfree86/drivers/modesetting/driver.c
@@ -1074,6 +1074,10 @@ msSetSharedPixmapBacking(PixmapPtr ppix, void *fd_handle)
Bool ret;
int ihandle = (int) (long) fd_handle;
+ if (ihandle == -1)
+ if (!ms->drmmode.reverse_prime_offload_mode)
+ return drmmode_SetSlaveBO(ppix, &ms->drmmode, ihandle, 0, 0);
+
if (ms->drmmode.reverse_prime_offload_mode) {
ret = glamor_back_pixmap_from_fd(ppix, ihandle,
ppix->drawable.width,
diff --git a/hw/xfree86/drivers/modesetting/drmmode_display.c b/hw/xfree86/drivers/modesetting/drmmode_display.c
index bf21320ce..d192d0537 100644
--- a/hw/xfree86/drivers/modesetting/drmmode_display.c
+++ b/hw/xfree86/drivers/modesetting/drmmode_display.c
@@ -214,6 +214,12 @@ drmmode_SetSlaveBO(PixmapPtr ppix,
{
msPixmapPrivPtr ppriv = msGetPixmapPriv(drmmode, ppix);
+ if (fd_handle == -1) {
+ dumb_bo_destroy(drmmode->fd, ppriv->backing_bo);
+ ppriv->backing_bo = NULL;
+ return TRUE;
+ }
+
ppriv->backing_bo =
dumb_get_bo_from_fd(drmmode->fd, fd_handle, pitch, size);
if (!ppriv->backing_bo)
diff --git a/include/pixmap.h b/include/pixmap.h
index c6a773649..86b513d47 100644
--- a/include/pixmap.h
+++ b/include/pixmap.h
@@ -115,6 +115,9 @@ extern _X_EXPORT void FreePixmap(PixmapPtr /*pPixmap */ );
extern _X_EXPORT PixmapPtr
PixmapShareToSlave(PixmapPtr pixmap, ScreenPtr slave);
+extern _X_EXPORT void
+PixmapUnshareSlavePixmap(PixmapPtr slave_pixmap);
+
#define HAS_DIRTYTRACKING_ROTATION 1
extern _X_EXPORT Bool
PixmapStartDirtyTracking(PixmapPtr src,
diff --git a/randr/rrcrtc.c b/randr/rrcrtc.c
index 566a3dbc6..54471332d 100644
--- a/randr/rrcrtc.c
+++ b/randr/rrcrtc.c
@@ -373,6 +373,8 @@ rrDestroySharedPixmap(RRCrtcPtr crtc, PixmapPtr pPixmap) {
* Unref the pixmap twice: once for the original reference, and once
* for the reference implicitly added by PixmapShareToSlave.
*/
+ PixmapUnshareSlavePixmap(pPixmap);
+
master->DestroyPixmap(pPixmap->master_pixmap);
master->DestroyPixmap(pPixmap->master_pixmap);
}