summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2013-07-19 10:59:03 +0100
committerChris Wilson <chris@chris-wilson.co.uk>2013-07-19 11:04:46 +0100
commite9831b50b58c36af3d2dd196b3abbfaa8e9a22c6 (patch)
tree1d5029dd839d95a4d56602b182ba38af58f26231
parent6c8b15d321044d4a81cb187cc5e1ac094eb82367 (diff)
sna/dri: Expose the refcnts in DBG before we hit the assertions
Useful to try and explain some failures. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
-rw-r--r--src/sna/sna_dri.c27
1 files changed, 25 insertions, 2 deletions
diff --git a/src/sna/sna_dri.c b/src/sna/sna_dri.c
index b65ebffe..54ad0fed 100644
--- a/src/sna/sna_dri.c
+++ b/src/sna/sna_dri.c
@@ -215,6 +215,11 @@ sna_dri_pixmap_update_bo(struct sna *sna, PixmapPtr pixmap)
if (buffer == NULL)
return;
+ DBG(("%s: pixmap=%ld, old handle=%d, new handle=%d\n", __FUNCTION__,
+ pixmap->drawable.serialNumber,
+ get_private(buffer)->bo->handle,
+ sna_pixmap(pixmap)->gpu_bo->handle));
+
private = get_private(buffer);
assert(private->pixmap == pixmap);
@@ -951,11 +956,17 @@ sna_dri_copy_region(DrawablePtr draw,
void (*copy)(struct sna *, DrawablePtr, RegionPtr,
struct kgem_bo *, struct kgem_bo *, bool) = sna_dri_copy;
- DBG(("%s: pixmap=%ld, src=%u, dst=%u\n",
+ DBG(("%s: pixmap=%ld, src=%u (refs=%d/%d, flush=%d) , dst=%u (refs=%d/%d, flush=%d)\n",
__FUNCTION__,
pixmap->drawable.serialNumber,
get_private(src_buffer)->bo->handle,
- get_private(dst_buffer)->bo->handle));
+ get_private(src_buffer)->refcnt,
+ get_private(src_buffer)->bo->refcnt,
+ get_private(src_buffer)->bo->flush,
+ get_private(dst_buffer)->bo->handle,
+ get_private(dst_buffer)->refcnt,
+ get_private(dst_buffer)->bo->refcnt,
+ get_private(dst_buffer)->bo->flush));
assert(get_private(src_buffer)->refcnt);
assert(get_private(dst_buffer)->refcnt);
@@ -2051,6 +2062,18 @@ sna_dri_schedule_swap(ClientPtr client, DrawablePtr draw, DRI2BufferPtr front,
enum frame_event_type swap_type = DRI2_SWAP;
CARD64 current_msc;
+ DBG(("%s: pixmap=%ld, back=%u (refs=%d/%d, flush=%d) , fron=%u (refs=%d/%d, flush=%d)\n",
+ __FUNCTION__,
+ get_drawable_pixmap(draw)->drawable.serialNumber,
+ get_private(back)->bo->handle,
+ get_private(back)->refcnt,
+ get_private(back)->bo->refcnt,
+ get_private(back)->bo->flush,
+ get_private(front)->bo->handle,
+ get_private(front)->refcnt,
+ get_private(front)->bo->refcnt,
+ get_private(front)->bo->flush));
+
DBG(("%s(target_msc=%llu, divisor=%llu, remainder=%llu)\n",
__FUNCTION__,
(long long)*target_msc,