aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/MachineVerifier/stack-protector-offset.mir
blob: 47008e1b123546f7a6a693988ed364c360f6793e (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
60
61
62
63
# REQUIRES: aarch64-registered-target, amdgpu-registered-target

# RUN: split-file %s %t

# RUN: llc -mtriple=aarch64 -run-pass=none -o - %t/valid.mir
# RUN: not --crash llc -mtriple=aarch64 -run-pass=none -o - %t/lower.mir 2>&1 | FileCheck %t/lower.mir
# RUN: not --crash llc -mtriple=aarch64 -run-pass=none -o - %t/overlap.mir 2>&1 | FileCheck %t/overlap.mir
# RUN: not --crash llc -mtriple=amdgcn -run-pass=none -o - %t/higher.mir 2>&1 | FileCheck %t/higher.mir

;--- valid.mir
---
name:            valid
frameInfo:
  stackSize:       16
  stackProtector:  '%stack.1'
stack:
  - { id: 0, offset: -24, size: 8, alignment: 8, stack-id: default }
  - { id: 1, offset: -16, size: 8, alignment: 8, stack-id: default }
body:             |
  bb.0:
...

;--- lower.mir
# CHECK: *** Bad machine code: Stack protector is not the top-most object on the stack ***
---
name:            lower
frameInfo:
  stackSize:       16
  stackProtector:  '%stack.1'
stack:
  - { id: 0, offset: -16, size: 8, alignment: 8, stack-id: default }
  - { id: 1, offset: -24, size: 8, alignment: 8, stack-id: default }
body:             |
  bb.0:
...

;--- overlap.mir
# CHECK: *** Bad machine code: Stack protector overlaps with another stack object ***
---
name:            overlap
frameInfo:
  stackSize:       16
  stackProtector:  '%stack.1'
stack:
  - { id: 0, offset: -20, size: 8, alignment: 4, stack-id: default }
  - { id: 1, offset: -16, size: 8, alignment: 8, stack-id: default }
body:             |
  bb.0:
...

;--- higher.mir
# CHECK: *** Bad machine code: Stack protector is not the top-most object on the stack ***
---
name:            higher
frameInfo:
  stackSize:       16
  stackProtector:  '%stack.1'
stack:
  - { id: 0, offset: 16, size: 8, alignment: 8, stack-id: default }
  - { id: 1, offset: 24, size: 8, alignment: 8, stack-id: default }
body:             |
  bb.0:
...