[Mesa-dev] [PATCH 2/2] gallium/postprocess: Just to be safe, reference all buffers from outside
Lauri Kasanen
cand at gmx.com
Tue Jan 24 11:37:56 PST 2012
Even though it should be safe to use them for one frame, better be sure.
Suggested by Michael Dänzer.
NOTE: This is a candidate for the 8.0 stable branch.
Signed-off-by: Lauri Kasanen <cand at gmx.com>
---
src/gallium/auxiliary/postprocess/pp_run.c | 10 ++++++++++
1 files changed, 10 insertions(+), 0 deletions(-)
diff --git a/src/gallium/auxiliary/postprocess/pp_run.c b/src/gallium/auxiliary/postprocess/pp_run.c
index be52051..aa1badc 100644
--- a/src/gallium/auxiliary/postprocess/pp_run.c
+++ b/src/gallium/auxiliary/postprocess/pp_run.c
@@ -64,6 +64,12 @@ pp_run(struct pp_queue_t *ppq, struct pipe_resource *in,
in = ppq->tmp[0];
}
+ // Kept only for this frame.
+ struct pipe_resource *refin = NULL, *refout = NULL;
+ pipe_resource_reference(&ppq->depth, indepth);
+ pipe_resource_reference(&refin, in);
+ pipe_resource_reference(&refout, out);
+
switch (ppq->n_filters) {
case 1: /* No temp buf */
ppq->pp_queue[0] (ppq, in, out, 0);
@@ -93,6 +99,10 @@ pp_run(struct pp_queue_t *ppq, struct pipe_resource *in,
break;
}
+
+ pipe_resource_reference(&ppq->depth, NULL);
+ pipe_resource_reference(&refin, NULL);
+ pipe_resource_reference(&refout, NULL);
}
--
1.7.2.1
More information about the mesa-dev
mailing list