[Mesa-dev] [PATCH] draw: fix line stippling

Jose Fonseca jfonseca at vmware.com
Tue Mar 15 07:20:30 UTC 2016


On 13/03/16 20:40, sroland at vmware.com wrote:
> From: Roland Scheidegger <sroland at vmware.com>
>
> The logic was comparing actual ints, not true/false values.
> This meant that it was emitting always multiple line segments instead of just
> one even if the stipple test had the same result, which looks inefficient, and
> the segments also overlapped thus breaking line aa as well.
> (In practice, with the no-op default line stipple pattern, for a 10-pixel
> long line from 0-9 it was emitting 10 segments, with the individual segments
> ranging from 0-1, 0-2, 0-3 and so on.)
>
> This fixes https://bugs.freedesktop.org/show_bug.cgi?id=94193
>
> CC: <mesa-stable at lists.freedesktop.org>
> ---
>   src/gallium/auxiliary/draw/draw_pipe_stipple.c | 30 +++++++++++++-------------
>   1 file changed, 15 insertions(+), 15 deletions(-)
>
> diff --git a/src/gallium/auxiliary/draw/draw_pipe_stipple.c b/src/gallium/auxiliary/draw/draw_pipe_stipple.c
> index dcf05aa..04854ad 100644
> --- a/src/gallium/auxiliary/draw/draw_pipe_stipple.c
> +++ b/src/gallium/auxiliary/draw/draw_pipe_stipple.c
> @@ -108,11 +108,11 @@ emit_segment(struct draw_stage *stage, struct prim_header *header,
>   }
>
>
> -static inline unsigned
> +static inline boolean
>   stipple_test(int counter, ushort pattern, int factor)
>   {
>      int b = (counter / factor) & 0xf;
> -   return (1 << b) & pattern;
> +   return !!((1 << b) & pattern);
>   }
>
>
> @@ -126,7 +126,7 @@ stipple_line(struct draw_stage *stage, struct prim_header *header)
>      const float *pos0 = v0->data[pos];
>      const float *pos1 = v1->data[pos];
>      float start = 0;
> -   int state = 0;
> +   boolean state = 0;
>
>      float x0 = pos0[0];
>      float x1 = pos1[0];
> @@ -143,29 +143,29 @@ stipple_line(struct draw_stage *stage, struct prim_header *header)
>         stipple->counter = 0;
>
>
> -   /* XXX ToDo: intead of iterating pixel-by-pixel, use a look-up table.
> +   /* XXX ToDo: instead of iterating pixel-by-pixel, use a look-up table.
>       */
>      for (i = 0; i < length; i++) {
> -      int result = stipple_test( (int) stipple->counter+i,
> -                                 (ushort) stipple->pattern, stipple->factor );
> +      boolean result = stipple_test((int)stipple->counter + i,
> +                                    (ushort)stipple->pattern, stipple->factor);
>         if (result != state) {
>            /* changing from "off" to "on" or vice versa */
> -	 if (state) {
> -	    if (start != i) {
> +         if (state) {
> +            if (start != i) {
>                  /* finishing an "on" segment */
> -	       emit_segment( stage, header, start / length, i / length );
> +               emit_segment(stage, header, start / length, i / length);
>               }
> -	 }
> -	 else {
> +         }
> +         else {
>               /* starting an "on" segment */
> -	    start = (float) i;
> -	 }
> -	 state = result;	
> +            start = (float)i;
> +         }
> +         state = result;
>         }
>      }
>
>      if (state && start < length)
> -      emit_segment( stage, header, start / length, 1.0 );
> +      emit_segment(stage, header, start / length, 1.0);
>
>      stipple->counter += length;
>   }
>

I think we're avoiding "boolean" over the standard C99 "bool".

Otherwise looks good.

Reviewed-by: Jose Fonseca <jfonseca at vmware.com>


More information about the mesa-dev mailing list