From 02d5ba849197e19843dad164239b51f18fb16faf Mon Sep 17 00:00:00 2001 From: Eric Anholt Date: Fri, 18 Jan 2008 11:39:35 -0800 Subject: [intel] Fix memory leak with fake bufmgr. --- src/mesa/drivers/dri/common/dri_bufmgr_fake.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/mesa/drivers/dri/common/dri_bufmgr_fake.c b/src/mesa/drivers/dri/common/dri_bufmgr_fake.c index ae7154daa2..a6598c1a96 100644 --- a/src/mesa/drivers/dri/common/dri_bufmgr_fake.c +++ b/src/mesa/drivers/dri/common/dri_bufmgr_fake.c @@ -631,6 +631,7 @@ dri_fake_bo_unreference(dri_bo *bo) { dri_bufmgr_fake *bufmgr_fake = (dri_bufmgr_fake *)bo->bufmgr; dri_bo_fake *bo_fake = (dri_bo_fake *)bo; + int i; if (!bo) return; @@ -641,7 +642,11 @@ dri_fake_bo_unreference(dri_bo *bo) if (bo_fake->block) free_block(bufmgr_fake, bo_fake->block); free_backing_store(bo); + + for (i = 0; i < bo_fake->nr_relocs; i++) + dri_bo_unreference(bo_fake->relocs[i].target_buf); free(bo_fake->relocs); + free(bo); DBG("drm_bo_unreference: free %s\n", bo_fake->name); return; @@ -942,7 +947,7 @@ dri_fake_calculate_validate_flags(dri_bo *bo) /* Do the same for the tree of buffers we depend on */ dri_fake_calculate_validate_flags(r->target_buf); - if (target_fake->flags == 0) { + if (target_fake->validate_flags == 0) { target_fake->validate_flags = r->validate_flags; } else { /* Mask the memory location to the intersection of all the memory -- cgit v1.2.3