diff options
author | Mathias Fröhlich <[email protected]> | 2016-05-22 14:10:19 +0200 |
---|---|---|
committer | Mathias Fröhlich <[email protected]> | 2016-06-16 05:50:55 +0200 |
commit | b670f0d1d741d176c155df062e861c2f2a9e4ee6 (patch) | |
tree | a8590d0bb03b0d54e6c0200812a32445fcf26235 /src | |
parent | a0fe569e53f779b5a8497ff669c1b277d1c13796 (diff) |
i965: Use bitmask/ffs to iterate enabled clip planes.
Replaces an iterate and test bit in a bitmask loop by a
loop only iterating over the bits set in the bitmask.
v2: Use _mesa_bit_scan{,64} instead of open coding.
v3: Use u_bit_scan{,64} instead of _mesa_bit_scan{,64}.
Reviewed-by: Brian Paul <[email protected]>
Signed-off-by: Mathias Fröhlich <[email protected]>
Diffstat (limited to 'src')
-rw-r--r-- | src/mesa/drivers/dri/i965/brw_curbe.c | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/src/mesa/drivers/dri/i965/brw_curbe.c b/src/mesa/drivers/dri/i965/brw_curbe.c index dfb90b18558..02c4e38c15d 100644 --- a/src/mesa/drivers/dri/i965/brw_curbe.c +++ b/src/mesa/drivers/dri/i965/brw_curbe.c @@ -56,6 +56,7 @@ #include "program/prog_parameter.h" #include "program/prog_print.h" #include "program/prog_statevars.h" +#include "util/bitscan.h" #include "intel_batchbuffer.h" #include "intel_buffer_objects.h" #include "brw_context.h" @@ -84,7 +85,7 @@ static void calculate_curbe_offsets( struct brw_context *brw ) /* _NEW_TRANSFORM */ if (ctx->Transform.ClipPlanesEnabled) { - GLuint nr_planes = 6 + _mesa_bitcount_64(ctx->Transform.ClipPlanesEnabled); + GLuint nr_planes = 6 + _mesa_bitcount(ctx->Transform.ClipPlanesEnabled); nr_clip_regs = (nr_planes * 4 + 15) / 16; } @@ -226,7 +227,7 @@ brw_upload_constant_buffer(struct brw_context *brw) /* clipper constants */ if (brw->curbe.clip_size) { GLuint offset = brw->curbe.clip_start * 16; - GLuint j; + GLbitfield mask; /* If any planes are going this way, send them all this way: */ @@ -241,14 +242,14 @@ brw_upload_constant_buffer(struct brw_context *brw) * clip-space: */ clip_planes = brw_select_clip_planes(ctx); - for (j = 0; j < MAX_CLIP_PLANES; j++) { - if (ctx->Transform.ClipPlanesEnabled & (1<<j)) { - buf[offset + i * 4 + 0].f = clip_planes[j][0]; - buf[offset + i * 4 + 1].f = clip_planes[j][1]; - buf[offset + i * 4 + 2].f = clip_planes[j][2]; - buf[offset + i * 4 + 3].f = clip_planes[j][3]; - i++; - } + mask = ctx->Transform.ClipPlanesEnabled; + while (mask) { + const int j = u_bit_scan(&mask); + buf[offset + i * 4 + 0].f = clip_planes[j][0]; + buf[offset + i * 4 + 1].f = clip_planes[j][1]; + buf[offset + i * 4 + 2].f = clip_planes[j][2]; + buf[offset + i * 4 + 3].f = clip_planes[j][3]; + i++; } } |