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/] [testsuite/] [gcc.dg/] [pr36224.c] - Diff between revs 298 and 384

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

Rev 298 Rev 384
/* { dg-do run } */
/* { dg-do run } */
/* { dg-require-effective-target lp64 } */
/* { dg-require-effective-target lp64 } */
/* { dg-options "-O2 -ftree-vectorize" } */
/* { dg-options "-O2 -ftree-vectorize" } */
 
 
#ifndef ALIGN16
#ifndef ALIGN16
#define ALIGN16 __attribute__((__aligned__(32)))
#define ALIGN16 __attribute__((__aligned__(32)))
#endif
#endif
 
 
#define I16_B0  1
#define I16_B0  1
#define I16_B1  23
#define I16_B1  23
#define I16_B2  345
#define I16_B2  345
#define I16_B3  6789
#define I16_B3  6789
#define I16_B4  1011
#define I16_B4  1011
#define I16_B5  -12
#define I16_B5  -12
#define I16_B6  1314
#define I16_B6  1314
#define I16_B7  -1516
#define I16_B7  -1516
#define I16_B8  -1516
#define I16_B8  -1516
#define I16_B9  1314
#define I16_B9  1314
#define I16_B10 -12
#define I16_B10 -12
#define I16_B11 1011
#define I16_B11 1011
#define I16_B12 6789
#define I16_B12 6789
#define I16_B13 345
#define I16_B13 345
#define I16_B14 23
#define I16_B14 23
#define I16_B15 1
#define I16_B15 1
 
 
#define I16_C0  2
#define I16_C0  2
#define I16_C1  31567
#define I16_C1  31567
#define I16_C2  1112
#define I16_C2  1112
#define I16_C3  13
#define I16_C3  13
#define I16_C4  14
#define I16_C4  14
#define I16_C5  15
#define I16_C5  15
#define I16_C6  -16
#define I16_C6  -16
#define I16_C7  17
#define I16_C7  17
#define I16_C8  2
#define I16_C8  2
#define I16_C9  31567
#define I16_C9  31567
#define I16_C10 1112
#define I16_C10 1112
#define I16_C11 13
#define I16_C11 13
#define I16_C12 14
#define I16_C12 14
#define I16_C13 15
#define I16_C13 15
#define I16_C14 -16
#define I16_C14 -16
#define I16_C15 17
#define I16_C15 17
 
 
union ui2 {
union ui2 {
  int           si[16];
  int           si[16];
  unsigned int  ui[16];
  unsigned int  ui[16];
};
};
 
 
union us {
union us {
  short          ss[16];
  short          ss[16];
  unsigned short us[16];
  unsigned short us[16];
};
};
 
 
static union ui2 i32_sa ALIGN16;
static union ui2 i32_sa ALIGN16;
static union ui2 i32_ua ALIGN16;
static union ui2 i32_ua ALIGN16;
 
 
static union us i16_b ALIGN16 = {
static union us i16_b ALIGN16 = {
  (short)I16_B0,
  (short)I16_B0,
  (short)I16_B1,
  (short)I16_B1,
  (short)I16_B2,
  (short)I16_B2,
  (short)I16_B3,
  (short)I16_B3,
  (short)I16_B4,
  (short)I16_B4,
  (short)I16_B5,
  (short)I16_B5,
  (short)I16_B6,
  (short)I16_B6,
  (short)I16_B7,
  (short)I16_B7,
  (short)I16_B8,
  (short)I16_B8,
  (short)I16_B9,
  (short)I16_B9,
  (short)I16_B10,
  (short)I16_B10,
  (short)I16_B11,
  (short)I16_B11,
  (short)I16_B12,
  (short)I16_B12,
  (short)I16_B13,
  (short)I16_B13,
  (short)I16_B14,
  (short)I16_B14,
  (short)I16_B15,
  (short)I16_B15,
};
};
 
 
static union us i16_c ALIGN16 = {
static union us i16_c ALIGN16 = {
  (short)I16_C0,
  (short)I16_C0,
  (short)I16_C1,
  (short)I16_C1,
  (short)I16_C2,
  (short)I16_C2,
  (short)I16_C3,
  (short)I16_C3,
  (short)I16_C4,
  (short)I16_C4,
  (short)I16_C5,
  (short)I16_C5,
  (short)I16_C6,
  (short)I16_C6,
  (short)I16_C7,
  (short)I16_C7,
  (short)I16_C8,
  (short)I16_C8,
  (short)I16_C9,
  (short)I16_C9,
  (short)I16_C10,
  (short)I16_C10,
  (short)I16_C11,
  (short)I16_C11,
  (short)I16_C12,
  (short)I16_C12,
  (short)I16_C13,
  (short)I16_C13,
  (short)I16_C14,
  (short)I16_C14,
  (short)I16_C15,
  (short)I16_C15,
};
};
 
 
static long i32_sr[16] ALIGN16 = {
static long i32_sr[16] ALIGN16 = {
  ((int)I16_B0)  * ((int)I16_C0),
  ((int)I16_B0)  * ((int)I16_C0),
  ((int)I16_B1)  * ((int)I16_C1),
  ((int)I16_B1)  * ((int)I16_C1),
  ((int)I16_B2)  * ((int)I16_C2),
  ((int)I16_B2)  * ((int)I16_C2),
  ((int)I16_B3)  * ((int)I16_C3),
  ((int)I16_B3)  * ((int)I16_C3),
  ((int)I16_B4)  * ((int)I16_C4),
  ((int)I16_B4)  * ((int)I16_C4),
  ((int)I16_B5)  * ((int)I16_C5),
  ((int)I16_B5)  * ((int)I16_C5),
  ((int)I16_B6)  * ((int)I16_C6),
  ((int)I16_B6)  * ((int)I16_C6),
  ((int)I16_B7)  * ((int)I16_C7),
  ((int)I16_B7)  * ((int)I16_C7),
  ((int)I16_B8)  * ((int)I16_C8),
  ((int)I16_B8)  * ((int)I16_C8),
  ((int)I16_B9)  * ((int)I16_C9),
  ((int)I16_B9)  * ((int)I16_C9),
  ((int)I16_B10) * ((int)I16_C10),
  ((int)I16_B10) * ((int)I16_C10),
  ((int)I16_B11) * ((int)I16_C11),
  ((int)I16_B11) * ((int)I16_C11),
  ((int)I16_B12) * ((int)I16_C12),
  ((int)I16_B12) * ((int)I16_C12),
  ((int)I16_B13) * ((int)I16_C13),
  ((int)I16_B13) * ((int)I16_C13),
  ((int)I16_B14) * ((int)I16_C14),
  ((int)I16_B14) * ((int)I16_C14),
  ((int)I16_B15) * ((int)I16_C15),
  ((int)I16_B15) * ((int)I16_C15),
};
};
 
 
static unsigned long i32_ur[16] ALIGN16 = {
static unsigned long i32_ur[16] ALIGN16 = {
  ((unsigned int)(unsigned short)I16_B0)  * ((unsigned int)(unsigned short)I16_C0),
  ((unsigned int)(unsigned short)I16_B0)  * ((unsigned int)(unsigned short)I16_C0),
  ((unsigned int)(unsigned short)I16_B1)  * ((unsigned int)(unsigned short)I16_C1),
  ((unsigned int)(unsigned short)I16_B1)  * ((unsigned int)(unsigned short)I16_C1),
  ((unsigned int)(unsigned short)I16_B2)  * ((unsigned int)(unsigned short)I16_C2),
  ((unsigned int)(unsigned short)I16_B2)  * ((unsigned int)(unsigned short)I16_C2),
  ((unsigned int)(unsigned short)I16_B3)  * ((unsigned int)(unsigned short)I16_C3),
  ((unsigned int)(unsigned short)I16_B3)  * ((unsigned int)(unsigned short)I16_C3),
  ((unsigned int)(unsigned short)I16_B4)  * ((unsigned int)(unsigned short)I16_C4),
  ((unsigned int)(unsigned short)I16_B4)  * ((unsigned int)(unsigned short)I16_C4),
  ((unsigned int)(unsigned short)I16_B5)  * ((unsigned int)(unsigned short)I16_C5),
  ((unsigned int)(unsigned short)I16_B5)  * ((unsigned int)(unsigned short)I16_C5),
  ((unsigned int)(unsigned short)I16_B6)  * ((unsigned int)(unsigned short)I16_C6),
  ((unsigned int)(unsigned short)I16_B6)  * ((unsigned int)(unsigned short)I16_C6),
  ((unsigned int)(unsigned short)I16_B7)  * ((unsigned int)(unsigned short)I16_C7),
  ((unsigned int)(unsigned short)I16_B7)  * ((unsigned int)(unsigned short)I16_C7),
  ((unsigned int)(unsigned short)I16_B8)  * ((unsigned int)(unsigned short)I16_C8),
  ((unsigned int)(unsigned short)I16_B8)  * ((unsigned int)(unsigned short)I16_C8),
  ((unsigned int)(unsigned short)I16_B9)  * ((unsigned int)(unsigned short)I16_C9),
  ((unsigned int)(unsigned short)I16_B9)  * ((unsigned int)(unsigned short)I16_C9),
  ((unsigned int)(unsigned short)I16_B10) * ((unsigned int)(unsigned short)I16_C10),
  ((unsigned int)(unsigned short)I16_B10) * ((unsigned int)(unsigned short)I16_C10),
  ((unsigned int)(unsigned short)I16_B11) * ((unsigned int)(unsigned short)I16_C11),
  ((unsigned int)(unsigned short)I16_B11) * ((unsigned int)(unsigned short)I16_C11),
  ((unsigned int)(unsigned short)I16_B12) * ((unsigned int)(unsigned short)I16_C12),
  ((unsigned int)(unsigned short)I16_B12) * ((unsigned int)(unsigned short)I16_C12),
  ((unsigned int)(unsigned short)I16_B13) * ((unsigned int)(unsigned short)I16_C13),
  ((unsigned int)(unsigned short)I16_B13) * ((unsigned int)(unsigned short)I16_C13),
  ((unsigned int)(unsigned short)I16_B14) * ((unsigned int)(unsigned short)I16_C14),
  ((unsigned int)(unsigned short)I16_B14) * ((unsigned int)(unsigned short)I16_C14),
  ((unsigned int)(unsigned short)I16_B15) * ((unsigned int)(unsigned short)I16_C15),
  ((unsigned int)(unsigned short)I16_B15) * ((unsigned int)(unsigned short)I16_C15),
};
};
 
 
#ifndef ALIGN32
#ifndef ALIGN32
#define ALIGN32 __attribute__((__aligned__(32)))
#define ALIGN32 __attribute__((__aligned__(32)))
#endif
#endif
 
 
#define I32_B0  1
#define I32_B0  1
#define I32_B1  23
#define I32_B1  23
#define I32_B2  345
#define I32_B2  345
#define I32_B3  6789
#define I32_B3  6789
#define I32_B4  101112
#define I32_B4  101112
#define I32_B5  -13
#define I32_B5  -13
#define I32_B6  141516
#define I32_B6  141516
#define I32_B7  -1718
#define I32_B7  -1718
 
 
#define I32_C0  2
#define I32_C0  2
#define I32_C1  45678910
#define I32_C1  45678910
#define I32_C2  1112
#define I32_C2  1112
#define I32_C3  13
#define I32_C3  13
#define I32_C4  14
#define I32_C4  14
#define I32_C5  15
#define I32_C5  15
#define I32_C6  -16
#define I32_C6  -16
#define I32_C7  17
#define I32_C7  17
 
 
union ul {
union ul {
  long          sl[8];
  long          sl[8];
  unsigned long ul[8];
  unsigned long ul[8];
};
};
 
 
union ui {
union ui {
  int           si[8];
  int           si[8];
  unsigned int  ui[8];
  unsigned int  ui[8];
};
};
 
 
static union ul i64_sa ALIGN32;
static union ul i64_sa ALIGN32;
static union ul i64_ua ALIGN32;
static union ul i64_ua ALIGN32;
 
 
static union ui i32_b ALIGN32 = {
static union ui i32_b ALIGN32 = {
  (int)I32_B0,
  (int)I32_B0,
  (int)I32_B1,
  (int)I32_B1,
  (int)I32_B2,
  (int)I32_B2,
  (int)I32_B3,
  (int)I32_B3,
  (int)I32_B4,
  (int)I32_B4,
  (int)I32_B5,
  (int)I32_B5,
  (int)I32_B6,
  (int)I32_B6,
  (int)I32_B7,
  (int)I32_B7,
};
};
 
 
static union ui i32_c ALIGN32 = {
static union ui i32_c ALIGN32 = {
  (int)I32_C0,
  (int)I32_C0,
  (int)I32_C1,
  (int)I32_C1,
  (int)I32_C2,
  (int)I32_C2,
  (int)I32_C3,
  (int)I32_C3,
  (int)I32_C4,
  (int)I32_C4,
  (int)I32_C5,
  (int)I32_C5,
  (int)I32_C6,
  (int)I32_C6,
  (int)I32_C7,
  (int)I32_C7,
};
};
 
 
static long i64_sr[8] ALIGN32 = {
static long i64_sr[8] ALIGN32 = {
  ((long)I32_B0) * ((long)I32_C0),
  ((long)I32_B0) * ((long)I32_C0),
  ((long)I32_B1) * ((long)I32_C1),
  ((long)I32_B1) * ((long)I32_C1),
  ((long)I32_B2) * ((long)I32_C2),
  ((long)I32_B2) * ((long)I32_C2),
  ((long)I32_B3) * ((long)I32_C3),
  ((long)I32_B3) * ((long)I32_C3),
  ((long)I32_B4) * ((long)I32_C4),
  ((long)I32_B4) * ((long)I32_C4),
  ((long)I32_B5) * ((long)I32_C5),
  ((long)I32_B5) * ((long)I32_C5),
  ((long)I32_B6) * ((long)I32_C6),
  ((long)I32_B6) * ((long)I32_C6),
  ((long)I32_B7) * ((long)I32_C7),
  ((long)I32_B7) * ((long)I32_C7),
};
};
 
 
static unsigned long i64_ur[8] ALIGN32 = {
static unsigned long i64_ur[8] ALIGN32 = {
  ((unsigned long)(unsigned)I32_B0) * ((unsigned long)(unsigned)I32_C0),
  ((unsigned long)(unsigned)I32_B0) * ((unsigned long)(unsigned)I32_C0),
  ((unsigned long)(unsigned)I32_B1) * ((unsigned long)(unsigned)I32_C1),
  ((unsigned long)(unsigned)I32_B1) * ((unsigned long)(unsigned)I32_C1),
  ((unsigned long)(unsigned)I32_B2) * ((unsigned long)(unsigned)I32_C2),
  ((unsigned long)(unsigned)I32_B2) * ((unsigned long)(unsigned)I32_C2),
  ((unsigned long)(unsigned)I32_B3) * ((unsigned long)(unsigned)I32_C3),
  ((unsigned long)(unsigned)I32_B3) * ((unsigned long)(unsigned)I32_C3),
  ((unsigned long)(unsigned)I32_B4) * ((unsigned long)(unsigned)I32_C4),
  ((unsigned long)(unsigned)I32_B4) * ((unsigned long)(unsigned)I32_C4),
  ((unsigned long)(unsigned)I32_B5) * ((unsigned long)(unsigned)I32_C5),
  ((unsigned long)(unsigned)I32_B5) * ((unsigned long)(unsigned)I32_C5),
  ((unsigned long)(unsigned)I32_B6) * ((unsigned long)(unsigned)I32_C6),
  ((unsigned long)(unsigned)I32_B6) * ((unsigned long)(unsigned)I32_C6),
  ((unsigned long)(unsigned)I32_B7) * ((unsigned long)(unsigned)I32_C7),
  ((unsigned long)(unsigned)I32_B7) * ((unsigned long)(unsigned)I32_C7),
};
};
 
 
 
 
int main ()
int main ()
{
{
  int i;
  int i;
 
 
  /* Signed 16x16 -> 32-bit tests */
  /* Signed 16x16 -> 32-bit tests */
  for (i = 0; i < 16; i++)
  for (i = 0; i < 16; i++)
    i32_sa.si[i] = ((long)i16_b.ss[i]) * ((long)i16_c.ss[i]);
    i32_sa.si[i] = ((long)i16_b.ss[i]) * ((long)i16_c.ss[i]);
 
 
  for (i = 0; i < 16; i++)
  for (i = 0; i < 16; i++)
    if (i32_sa.si[i] != i32_sr[i])
    if (i32_sa.si[i] != i32_sr[i])
      __builtin_abort ();
      __builtin_abort ();
 
 
  /* Unsigned 16x16 -> 32-bit tests */
  /* Unsigned 16x16 -> 32-bit tests */
  for (i = 0; i < 16; i++)
  for (i = 0; i < 16; i++)
    i32_ua.ui[i] = ((long)i16_b.us[i]) * ((long)i16_c.us[i]);
    i32_ua.ui[i] = ((long)i16_b.us[i]) * ((long)i16_c.us[i]);
 
 
  for (i = 0; i < 16; i++)
  for (i = 0; i < 16; i++)
    if (i32_ua.ui[i] != i32_ur[i])
    if (i32_ua.ui[i] != i32_ur[i])
      __builtin_abort ();
      __builtin_abort ();
 
 
  /* Signed 32x32 -> 64-bit tests */
  /* Signed 32x32 -> 64-bit tests */
  for (i = 0; i < 8; i++)
  for (i = 0; i < 8; i++)
    i64_sa.sl[i] = ((long)i32_b.si[i]) * ((long)i32_c.si[i]);
    i64_sa.sl[i] = ((long)i32_b.si[i]) * ((long)i32_c.si[i]);
 
 
  for (i = 0; i < 8; i++)
  for (i = 0; i < 8; i++)
    if (i64_sa.sl[i] != i64_sr[i])
    if (i64_sa.sl[i] != i64_sr[i])
      __builtin_abort ();
      __builtin_abort ();
 
 
  /* Unsigned 32x32 -> 64-bit tests */
  /* Unsigned 32x32 -> 64-bit tests */
  for (i = 0; i < 8; i++)
  for (i = 0; i < 8; i++)
    i64_ua.ul[i] = ((long)i32_b.ui[i]) * ((long)i32_c.ui[i]);
    i64_ua.ul[i] = ((long)i32_b.ui[i]) * ((long)i32_c.ui[i]);
 
 
  for (i = 0; i < 8; i++)
  for (i = 0; i < 8; i++)
    if (i64_ua.ul[i] != i64_ur[i])
    if (i64_ua.ul[i] != i64_ur[i])
      __builtin_abort ();
      __builtin_abort ();
 
 
  return 0;
  return 0;
}
}
 
 

powered by: WebSVN 2.1.0

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