aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/i386/pr103611-1.c
blob: 7d8ac9de170e153b511812e8a7203e2657459191 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
/* { dg-do compile { target ia32 } } */
/* { dg-options "-O2 -msse4" } */
typedef int __v4si __attribute__ ((__vector_size__ (16)));

long long ior_1(__v4si v) {
  unsigned int loVal = (unsigned int)v[0];
  unsigned int hiVal = (unsigned int)v[1];
  return (long long)(loVal) | ((long long)(hiVal) << 32);
}

long long ior_2(__v4si v) {
  unsigned int loVal = (unsigned int)v[2];
  unsigned int hiVal = (unsigned int)v[3];
  return (long long)(loVal) | ((long long)(hiVal) << 32);
}

long long xor_1(__v4si v) {
  unsigned int loVal = (unsigned int)v[0];
  unsigned int hiVal = (unsigned int)v[1];
  return (long long)(loVal) ^ ((long long)(hiVal) << 32);
}

long long xor_2(__v4si v) {
  unsigned int loVal = (unsigned int)v[2];
  unsigned int hiVal = (unsigned int)v[3];
  return (long long)(loVal) ^ ((long long)(hiVal) << 32);
}
/* { dg-final { scan-assembler-not "\torb\t\\\$0," } } */
/* { dg-final { scan-assembler-not "\txorb\t\\\$0," } } */