summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2013-03-03 15:25:01 +0000
committerChris Wilson <chris@chris-wilson.co.uk>2013-03-03 15:25:01 +0000
commit2583232773f1fa505e0676f07b029b29b90c8ea7 (patch)
tree1a5e6aefbac35e61a2d65d8ce041baf66751ade5 /src
parent4dec895b69c2e545b142a3646646e13f7fb06507 (diff)
sna: Nullify cache pointers upon server regen
To make sure we don't chase dangling pointers on the next pass. Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src')
-rw-r--r--src/sna/sna_composite.c3
-rw-r--r--src/sna/sna_gradient.c8
2 files changed, 8 insertions, 3 deletions
diff --git a/src/sna/sna_composite.c b/src/sna/sna_composite.c
index e0677998..916d6da5 100644
--- a/src/sna/sna_composite.c
+++ b/src/sna/sna_composite.c
@@ -43,7 +43,7 @@
bool sna_composite_create(struct sna *sna)
{
- xRenderColor color ={ 0 };
+ xRenderColor color = { 0 };
int error;
if (!can_render(sna))
@@ -56,6 +56,7 @@ bool sna_composite_create(struct sna *sna)
void sna_composite_close(struct sna *sna)
{
FreePicture(sna->clear, 0);
+ sna->clear = NULL;
}
static inline bool
diff --git a/src/sna/sna_gradient.c b/src/sna/sna_gradient.c
index 237cf57b..3f0d7a5a 100644
--- a/src/sna/sna_gradient.c
+++ b/src/sna/sna_gradient.c
@@ -447,11 +447,15 @@ void sna_gradients_close(struct sna *sna)
DBG(("%s\n", __FUNCTION__));
for (i = 0; i < 256; i++) {
- if (sna->render.alpha_cache.bo[i])
+ if (sna->render.alpha_cache.bo[i]) {
kgem_bo_destroy(&sna->kgem, sna->render.alpha_cache.bo[i]);
+ sna->render.alpha_cache.bo[i] = NULL;
+ }
}
- if (sna->render.alpha_cache.cache_bo)
+ if (sna->render.alpha_cache.cache_bo) {
kgem_bo_destroy(&sna->kgem, sna->render.alpha_cache.cache_bo);
+ sna->render.alpha_cache.cache_bo = NULL;
+ }
if (sna->render.solid_cache.cache_bo)
kgem_bo_destroy(&sna->kgem, sna->render.solid_cache.cache_bo);