[cfe-commits] r131268 - in /cfe/trunk/lib/Headers: emmintrin.h xmmintrin.h

Eli Friedman eli.friedman at gmail.com
Thu May 12 18:10:46 PDT 2011


On Thu, May 12, 2011 at 5:11 PM, Bill Wendling <isanbard at gmail.com> wrote:
> Author: void
> Date: Thu May 12 19:11:39 2011
> New Revision: 131268
>
> URL: http://llvm.org/viewvc/llvm-project?rev=131268&view=rev
> Log:
> Represent the unaligned loads natively. These are converted into a call to the
> correct unaligned load.
>
> Modified:
>    cfe/trunk/lib/Headers/emmintrin.h
>    cfe/trunk/lib/Headers/xmmintrin.h
>
> Modified: cfe/trunk/lib/Headers/emmintrin.h
> URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Headers/emmintrin.h?rev=131268&r1=131267&r2=131268&view=diff
> ==============================================================================
> --- cfe/trunk/lib/Headers/emmintrin.h (original)
> +++ cfe/trunk/lib/Headers/emmintrin.h Thu May 12 19:11:39 2011
> @@ -466,7 +466,10 @@
>  static __inline__ __m128d __attribute__((__always_inline__, __nodebug__))
>  _mm_loadu_pd(double const *dp)
>  {
> -  return __builtin_ia32_loadupd(dp);
> +  struct __loadu_pd {
> +    __m128d v;
> +  } __attribute__((packed));
> +  return ((struct __loadu_pd*)dp)->v;
>  }
>
>  static __inline__ __m128d __attribute__((__always_inline__, __nodebug__))
> @@ -1011,7 +1014,10 @@
>  static __inline__ __m128i __attribute__((__always_inline__, __nodebug__))
>  _mm_loadu_si128(__m128i const *p)
>  {
> -  return (__m128i)__builtin_ia32_loaddqu((char const *)p);
> +  struct __loadu_si128 {
> +    __m128i v;
> +  } __attribute__((packed));
> +  return ((struct __loadu_si128*)p)->v;
>  }

I think you also need to mark the struct may_alias.

-Eli




More information about the cfe-commits mailing list