summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/i386/pr78904-2.c
blob: 0cc4aaa91ea8be138980e0852e9bae05718babed (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
40
41
42
43
44
45
46
47
48
49
/* PR target/78904 */
/* { dg-do compile } */
/* { dg-require-effective-target nonpic } */
/* { dg-options "-O2 -masm=att" } */

struct S1
{
  unsigned char pad1;
  unsigned char val;
  unsigned short pad2;
};

extern struct S1 t;

struct S1 test_and (struct S1 a)
{
  a.val &= t.val;

  return a;
}

/* { dg-final { scan-assembler "\[ \t\]andb\[ \t\]+t\[^\n\r]*, %.h" } } */

struct S1 test_or (struct S1 a)
{
  a.val |= t.val;

  return a;
}

/* { dg-final { scan-assembler "\[ \t\]orb\[ \t\]+t\[^\n\r]*, %.h" } } */

struct S1 test_xor (struct S1 a)
{
  a.val ^= t.val;

  return a;
}

/* { dg-final { scan-assembler "\[ \t\]xorb\[ \t\]+t\[^\n\r]*, %.h" } } */

struct S1 test_add (struct S1 a)
{
  a.val += t.val;

  return a;
}

/* { dg-final { scan-assembler "\[ \t\]addb\[ \t\]+t\[^\n\r]*, %.h" } } */