Revert "gallium: Force blend color to 16-byte alignment"
authorTim Rowley <timothy.o.rowley@intel.com>
Wed, 13 Jul 2016 15:30:46 +0000 (10:30 -0500)
committerTim Rowley <timothy.o.rowley@intel.com>
Wed, 13 Jul 2016 18:55:33 +0000 (13:55 -0500)
This reverts commit d8d6091a846ac2a40a011d512d6d57f6c8442e6a.

Heap allocations may be only 8-byte aligned on 32-bit system, and so having
members with 16-byte alignment (such as in the case where pipe_blend_color is
embedded in radeonsi's si_context) is undefined behavior which indeed causes
crashes when compiled with gcc -O3.

Cc: <mesa-stable@lists.freedesktop.org>
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=96835
Signed-off-by: Tim Rowley <timothy.o.rowley@intel.com>
Acked-by: Chuck Atkins <chuck.atkins@kitware.com>
src/gallium/include/pipe/p_state.h

index a73a77111a993bc84ed7ee66fd5319ba5dde4f94..a3ae8701d296e2f0f9bceeea22fc21f4f6bc9d98 100644 (file)
@@ -326,17 +326,7 @@ struct pipe_blend_state
 
 struct pipe_blend_color
 {
-   /**
-    * Making the color array explicitly 16-byte aligned provides a hint to
-    * compilers to make more efficient auto-vectorization optimizations.
-    * The actual performance gains from vectorizing the blend color array are
-    * fairly minimal, if any, but the alignment is necessary to work around
-    * buggy vectorization in some compilers which fail to generate the correct
-    * unaligned accessors resulting in a segfault.  Specifically several
-    * versions of the Intel compiler are known to be affected but it's likely
-    * others are as well.
-    */
-   PIPE_ALIGN_VAR(16) float color[4];
+   float color[4];
 };