diff options
author | Lauri Kasanen <[email protected]> | 2012-01-24 21:37:56 +0200 |
---|---|---|
committer | Alex Deucher <[email protected]> | 2012-02-02 16:42:09 -0500 |
commit | 81938d2137a7a65521ca5a3cd7180902d063c5c0 (patch) | |
tree | e633d40320c661893f7386673a566300a0202041 /src/gallium/auxiliary/postprocess/pp_run.c | |
parent | c5976017e31828dd67fb54e8c11b863fffcac70b (diff) |
gallium/postprocess: Just to be safe, reference all buffers from outside
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 <[email protected]>
Diffstat (limited to 'src/gallium/auxiliary/postprocess/pp_run.c')
-rw-r--r-- | 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 be52051ed65..aa1badc72aa 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); } |