On Tuesday, May 30, 2017 8:41:32 AM PDT Samuel Pitoiset wrote:
> u_vector_foreach is currently only used by the Intel Vulkan
> driver but when this macro is used in mesa core, GCC reports
> a compile-time error. Probably because some compiler options
> are different.
> 
> Signed-off-by: Samuel Pitoiset <[email protected]>
> ---
>  src/util/u_vector.h | 2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/src/util/u_vector.h b/src/util/u_vector.h
> index c7fcb37a05..c0e199cfa5 100644
> --- a/src/util/u_vector.h
> +++ b/src/util/u_vector.h
> @@ -84,7 +84,7 @@ u_vector_finish(struct u_vector *queue)
>  #define u_vector_foreach(elem, queue)                                  \
>     STATIC_ASSERT(__builtin_types_compatible_p(__typeof__(queue), struct 
> u_vector *)); \
>     for (uint32_t __u_vector_offset = (queue)->tail;                          
>       \
> -        elem = (queue)->data + (__u_vector_offset & ((queue)->size - 1)), 
> __u_vector_offset < (queue)->head; \
> +        elem = (void *)((char *)(queue)->data + (__u_vector_offset & 
> ((queue)->size - 1))), __u_vector_offset < (queue)->head; \
>          __u_vector_offset += (queue)->element_size)
>  
>  
> 

Yeah, void * math is a GCCism - we shouldn't do that in core Mesa.

Reviewed-by: Kenneth Graunke <[email protected]>

Attachment: signature.asc
Description: This is a digitally signed message part.

_______________________________________________
mesa-dev mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/mesa-dev

Reply via email to