OpenCores
URL https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk

Subversion Repositories openrisc_2011-10-31

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc2/] [gcc/] [config/] [i386/] [wmmintrin.h] - Diff between revs 282 and 384

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 282 Rev 384
/* Copyright (C) 2008, 2009 Free Software Foundation, Inc.
/* Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 
 
   This file is part of GCC.
   This file is part of GCC.
 
 
   GCC is free software; you can redistribute it and/or modify
   GCC is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 3, or (at your option)
   the Free Software Foundation; either version 3, or (at your option)
   any later version.
   any later version.
 
 
   GCC is distributed in the hope that it will be useful,
   GCC is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.
   GNU General Public License for more details.
 
 
   Under Section 7 of GPL version 3, you are granted additional
   Under Section 7 of GPL version 3, you are granted additional
   permissions described in the GCC Runtime Library Exception, version
   permissions described in the GCC Runtime Library Exception, version
   3.1, as published by the Free Software Foundation.
   3.1, as published by the Free Software Foundation.
 
 
   You should have received a copy of the GNU General Public License and
   You should have received a copy of the GNU General Public License and
   a copy of the GCC Runtime Library Exception along with this program;
   a copy of the GCC Runtime Library Exception along with this program;
   see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
   see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
   <http://www.gnu.org/licenses/>.  */
   <http://www.gnu.org/licenses/>.  */
 
 
/* Implemented from the specification included in the Intel C++ Compiler
/* Implemented from the specification included in the Intel C++ Compiler
   User Guide and Reference, version 10.1.  */
   User Guide and Reference, version 10.1.  */
 
 
#ifndef _WMMINTRIN_H_INCLUDED
#ifndef _WMMINTRIN_H_INCLUDED
#define _WMMINTRIN_H_INCLUDED
#define _WMMINTRIN_H_INCLUDED
 
 
/* We need definitions from the SSE2 header file.  */
/* We need definitions from the SSE2 header file.  */
#include <emmintrin.h>
#include <emmintrin.h>
 
 
#if !defined (__AES__) && !defined (__PCLMUL__)
#if !defined (__AES__) && !defined (__PCLMUL__)
# error "AES/PCLMUL instructions not enabled"
# error "AES/PCLMUL instructions not enabled"
#else
#else
 
 
/* AES */
/* AES */
 
 
#ifdef __AES__
#ifdef __AES__
/* Performs 1 round of AES decryption of the first m128i using
/* Performs 1 round of AES decryption of the first m128i using
   the second m128i as a round key.  */
   the second m128i as a round key.  */
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_aesdec_si128 (__m128i __X, __m128i __Y)
_mm_aesdec_si128 (__m128i __X, __m128i __Y)
{
{
  return (__m128i) __builtin_ia32_aesdec128 ((__v2di)__X, (__v2di)__Y);
  return (__m128i) __builtin_ia32_aesdec128 ((__v2di)__X, (__v2di)__Y);
}
}
 
 
/* Performs the last round of AES decryption of the first m128i
/* Performs the last round of AES decryption of the first m128i
   using the second m128i as a round key.  */
   using the second m128i as a round key.  */
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_aesdeclast_si128 (__m128i __X, __m128i __Y)
_mm_aesdeclast_si128 (__m128i __X, __m128i __Y)
{
{
  return (__m128i) __builtin_ia32_aesdeclast128 ((__v2di)__X,
  return (__m128i) __builtin_ia32_aesdeclast128 ((__v2di)__X,
                                                 (__v2di)__Y);
                                                 (__v2di)__Y);
}
}
 
 
/* Performs 1 round of AES encryption of the first m128i using
/* Performs 1 round of AES encryption of the first m128i using
   the second m128i as a round key.  */
   the second m128i as a round key.  */
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_aesenc_si128 (__m128i __X, __m128i __Y)
_mm_aesenc_si128 (__m128i __X, __m128i __Y)
{
{
  return (__m128i) __builtin_ia32_aesenc128 ((__v2di)__X, (__v2di)__Y);
  return (__m128i) __builtin_ia32_aesenc128 ((__v2di)__X, (__v2di)__Y);
}
}
 
 
/* Performs the last round of AES encryption of the first m128i
/* Performs the last round of AES encryption of the first m128i
   using the second m128i as a round key.  */
   using the second m128i as a round key.  */
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_aesenclast_si128 (__m128i __X, __m128i __Y)
_mm_aesenclast_si128 (__m128i __X, __m128i __Y)
{
{
  return (__m128i) __builtin_ia32_aesenclast128 ((__v2di)__X, (__v2di)__Y);
  return (__m128i) __builtin_ia32_aesenclast128 ((__v2di)__X, (__v2di)__Y);
}
}
 
 
/* Performs the InverseMixColumn operation on the source m128i
/* Performs the InverseMixColumn operation on the source m128i
   and stores the result into m128i destination.  */
   and stores the result into m128i destination.  */
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_aesimc_si128 (__m128i __X)
_mm_aesimc_si128 (__m128i __X)
{
{
  return (__m128i) __builtin_ia32_aesimc128 ((__v2di)__X);
  return (__m128i) __builtin_ia32_aesimc128 ((__v2di)__X);
}
}
 
 
/* Generates a m128i round key for the input m128i AES cipher key and
/* Generates a m128i round key for the input m128i AES cipher key and
   byte round constant.  The second parameter must be a compile time
   byte round constant.  The second parameter must be a compile time
   constant.  */
   constant.  */
#ifdef __OPTIMIZE__
#ifdef __OPTIMIZE__
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_aeskeygenassist_si128 (__m128i __X, const int __C)
_mm_aeskeygenassist_si128 (__m128i __X, const int __C)
{
{
  return (__m128i) __builtin_ia32_aeskeygenassist128 ((__v2di)__X, __C);
  return (__m128i) __builtin_ia32_aeskeygenassist128 ((__v2di)__X, __C);
}
}
#else
#else
#define _mm_aeskeygenassist_si128(X, C)                                 \
#define _mm_aeskeygenassist_si128(X, C)                                 \
  ((__m128i) __builtin_ia32_aeskeygenassist128 ((__v2di)(__m128i)(X),   \
  ((__m128i) __builtin_ia32_aeskeygenassist128 ((__v2di)(__m128i)(X),   \
                                                (int)(C)))
                                                (int)(C)))
#endif
#endif
#endif  /* __AES__ */
#endif  /* __AES__ */
 
 
/* PCLMUL */
/* PCLMUL */
 
 
#ifdef __PCLMUL__
#ifdef __PCLMUL__
/* Performs carry-less integer multiplication of 64-bit halves of
/* Performs carry-less integer multiplication of 64-bit halves of
   128-bit input operands.  The third parameter inducates which 64-bit
   128-bit input operands.  The third parameter inducates which 64-bit
   haves of the input parameters v1 and v2 should be used. It must be
   haves of the input parameters v1 and v2 should be used. It must be
   a compile time constant.  */
   a compile time constant.  */
#ifdef __OPTIMIZE__
#ifdef __OPTIMIZE__
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
extern __inline __m128i __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_clmulepi64_si128 (__m128i __X, __m128i __Y, const int __I)
_mm_clmulepi64_si128 (__m128i __X, __m128i __Y, const int __I)
{
{
  return (__m128i) __builtin_ia32_pclmulqdq128 ((__v2di)__X,
  return (__m128i) __builtin_ia32_pclmulqdq128 ((__v2di)__X,
                                                (__v2di)__Y, __I);
                                                (__v2di)__Y, __I);
}
}
#else
#else
#define _mm_clmulepi64_si128(X, Y, I)                                   \
#define _mm_clmulepi64_si128(X, Y, I)                                   \
  ((__m128i) __builtin_ia32_pclmulqdq128 ((__v2di)(__m128i)(X),         \
  ((__m128i) __builtin_ia32_pclmulqdq128 ((__v2di)(__m128i)(X),         \
                                          (__v2di)(__m128i)(Y), (int)(I)))
                                          (__v2di)(__m128i)(Y), (int)(I)))
#endif
#endif
#endif  /* __PCLMUL__  */
#endif  /* __PCLMUL__  */
 
 
#endif /* __AES__/__PCLMUL__ */
#endif /* __AES__/__PCLMUL__ */
 
 
#endif /* _WMMINTRIN_H_INCLUDED */
#endif /* _WMMINTRIN_H_INCLUDED */
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.