summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarek Olšák <[email protected]>2013-01-14 06:45:50 +0100
committerMarek Olšák <[email protected]>2013-01-15 16:47:18 +0100
commit16a30e201e10278049b6464d21556f59d892ecf0 (patch)
tree9e93b18ee536a0344ae57cb8a1ad98f42f3b0713
parent77dd50d020da587445e8ccd38a0cc3d0484c8065 (diff)
softpipe: implement separate depth-stencil clear
The CAP is going away. Reviewed-by: Brian Paul <[email protected]>
-rw-r--r--src/gallium/drivers/softpipe/sp_clear.c15
1 files changed, 12 insertions, 3 deletions
diff --git a/src/gallium/drivers/softpipe/sp_clear.c b/src/gallium/drivers/softpipe/sp_clear.c
index dd6bd833e61..f040903ecfc 100644
--- a/src/gallium/drivers/softpipe/sp_clear.c
+++ b/src/gallium/drivers/softpipe/sp_clear.c
@@ -34,6 +34,7 @@
#include "pipe/p_defines.h"
#include "util/u_pack_color.h"
+#include "util/u_surface.h"
#include "sp_clear.h"
#include "sp_context.h"
#include "sp_query.h"
@@ -50,6 +51,8 @@ softpipe_clear(struct pipe_context *pipe, unsigned buffers,
double depth, unsigned stencil)
{
struct softpipe_context *softpipe = softpipe_context(pipe);
+ struct pipe_surface *zsbuf = softpipe->framebuffer.zsbuf;
+ unsigned zs_buffers = buffers & PIPE_CLEAR_DEPTHSTENCIL;
uint64_t cv;
uint i;
@@ -69,11 +72,17 @@ softpipe_clear(struct pipe_context *pipe, unsigned buffers,
}
}
- if (buffers & PIPE_CLEAR_DEPTHSTENCIL) {
+ if (zs_buffers &&
+ util_format_is_depth_and_stencil(zsbuf->texture->format) &&
+ zs_buffers != PIPE_CLEAR_DEPTHSTENCIL) {
+ /* Clearing only depth or stencil in a combined depth-stencil buffer. */
+ util_clear_depth_stencil(pipe, zsbuf, zs_buffers, depth, stencil,
+ 0, 0, zsbuf->width, zsbuf->height);
+ }
+ else if (zs_buffers) {
static const union pipe_color_union zero;
- struct pipe_surface *ps = softpipe->framebuffer.zsbuf;
- cv = util_pack64_z_stencil(ps->format, depth, stencil);
+ cv = util_pack64_z_stencil(zsbuf->format, depth, stencil);
sp_tile_cache_clear(softpipe->zsbuf_cache, &zero, cv);
}