summaryrefslogtreecommitdiff
path: root/clang/test/Analysis/uninit-asm-goto.cpp
blob: 43438dc589bef2ffc6a76bd4364a1d8d9e422552 (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
50
51
52
53
54
55
56
57
58
59
// RUN: %clang_cc1 -triple x86_64-pc-linux-gnu -std=c++11 -Wuninitialized -verify %s

// test1: Expect no diagnostics
int test1(int x) {
    int y;
    asm goto("nop" : "=r"(y) : "r"(x) : : err);
    return y;
  err:
    return -1;
}

int test2(int x) {
  int y; // expected-warning {{variable 'y' is used uninitialized whenever its declaration is reached}} \
         // expected-note {{initialize the variable}}
  if (x < 42)
    asm volatile goto("testl %0, %0; testl %1, %2; jne %l3" : "+S"(x), "+D"(y) : "r"(x) :: indirect_1, indirect_2);
  else
    asm volatile goto("testl %0, %1; testl %2, %3; jne %l5" : "+S"(x), "+D"(y) : "r"(x), "r"(y) :: indirect_1, indirect_2);
  return x + y;
indirect_1:
  return -42;
indirect_2:
  return y; // expected-note {{uninitialized use occurs here}}
}

int test3(int x) {
  int y; // expected-warning {{variable 'y' is used uninitialized whenever its declaration is reached}} \
         // expected-note {{initialize the variable}}
  asm goto("xorl %1, %0; jmp %l2" : "=&r"(y) : "r"(x) : : fail);
normal:
  y += x;
  return y;
  if (x) {
fail:
    return y; // expected-note {{uninitialized use occurs here}}
  }
  return 0;
}

int test4(int x) {
  int y; // expected-warning {{variable 'y' is used uninitialized whenever its declaration is reached}} \
         // expected-note {{initialize the variable}}
  goto forward;
backward:
  return y; // expected-note {{uninitialized use occurs here}}
forward:
  asm goto("# %0 %1 %2" : "=r"(y) : "r"(x) : : backward);
  return y;
}

// test5: Expect no diagnostics
int test5(int x) {
  int y;
  asm volatile goto("testl %0, %0; testl %1, %2; jne %l3" : "+S"(x), "+D"(y) : "r"(x) :: indirect, fallthrough);
fallthrough:
  return y;
indirect:
  return -2;
}