aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/nvptx/v2si-cvt.c
blob: 73f86bcfa9e3d0066ef6e6bd73df7e9396230125 (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
31
32
33
34
35
36
37
38
39
/* { dg-do assemble } */
/* { dg-options "-O2 -save-temps" } */

typedef int __v2si __attribute__((__vector_size__(8)));

int __attribute__((unused))
vector_cvt (__v2si arg)
{
  __v2si val4 = arg;
  char *p = (char*)&val4;

  if (p[0] != 1)
    return 1;
  if (p[1] != 2)
    return 1;
  if (p[2] != 3)
    return 1;

  return 0;
}

int
vector_cvt_2 (__v2si val, __v2si val2)
{
  char *p = (char*)&val;
  char *p2 = (char*)&val2;

  if (p[0] != p2[0])
    return 1;
  if (p[4] != p2[4])
    return 1;

  return 0;
}

/* We want to test for 'mov.t' here, but given PR80845 we test for cvt.t.t
   instead.
   { dg-final { scan-assembler "(?n)cvt\\.u32\\.u32.*\\.x" } } */
/* { dg-final { scan-assembler "(?n)cvt\\.u16\\.u32.*\\.x" } } */