aboutsummaryrefslogtreecommitdiff
path: root/test/NaCl/PNaClABI/abi-alignment.ll
blob: 0ef1f8660438b6568a37c6fb942de66ec23ff4a1 (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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
; RUN: pnacl-abicheck < %s | FileCheck %s

; Test the "align" attributes that are allowed on load and store
; instructions.  Note that "cmpxchg" and "atomicrmw" do not take
; "align" attributes, so are not tested here.


define void @allowed_cases(i32 %ptr, float %f, double %d) {
  %ptr.i32 = inttoptr i32 %ptr to i32*
  load i32* %ptr.i32, align 1
  store i32 123, i32* %ptr.i32, align 1

  %ptr.float = inttoptr i32 %ptr to float*
  load float* %ptr.float, align 1
  load float* %ptr.float, align 4
  store float %f, float* %ptr.float, align 1
  store float %f, float* %ptr.float, align 4

  %ptr.double = inttoptr i32 %ptr to double*
  load double* %ptr.double, align 1
  load double* %ptr.double, align 8
  store double %d, double* %ptr.double, align 1
  store double %d, double* %ptr.double, align 8

  ; Stricter alignments are required for atomics.
  load atomic i32* %ptr.i32 seq_cst, align 4
  store atomic i32 123, i32* %ptr.i32 seq_cst, align 4
  load atomic float* %ptr.float seq_cst, align 4
  store atomic float %f, float* %ptr.float seq_cst, align 4
  load atomic double* %ptr.double seq_cst, align 8
  store atomic double %d, double* %ptr.double seq_cst, align 8

  ret void
}
; CHECK-NOT: disallowed


define void @rejected_cases(i32 %ptr, float %f, double %d) {
  %ptr.i32 = inttoptr i32 %ptr to i32*
  load i32* %ptr.i32, align 4
  store i32 123, i32* %ptr.i32, align 4
; CHECK: disallowed: bad alignment: {{.*}} load i32{{.*}} align 4
; CHECK-NEXT: disallowed: bad alignment: store i32{{.*}} align 4

  ; Unusual, not-very-useful alignments are rejected.
  %ptr.float = inttoptr i32 %ptr to float*
  load float* %ptr.float, align 2
  load float* %ptr.float, align 8
  store float %f, float* %ptr.float, align 2
  store float %f, float* %ptr.float, align 8
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load float{{.*}} align 2
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load float{{.*}} align 8
; CHECK-NEXT: disallowed: bad alignment: store float{{.*}} align 2
; CHECK-NEXT: disallowed: bad alignment: store float{{.*}} align 8

  %ptr.double = inttoptr i32 %ptr to double*
  load double* %ptr.double, align 2
  load double* %ptr.double, align 4
  store double %d, double* %ptr.double, align 2
  store double %d, double* %ptr.double, align 4
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load double{{.*}} align 2
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load double{{.*}} align 4
; CHECK-NEXT: disallowed: bad alignment: store double{{.*}} align 2
; CHECK-NEXT: disallowed: bad alignment: store double{{.*}} align 4

  ; Too-small alignments for atomics are rejected.
  load atomic i32* %ptr.i32 seq_cst, align 2
  load atomic float* %ptr.float seq_cst, align 2
  load atomic double* %ptr.double seq_cst, align 4
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load atomic i32{{.*}} align 2
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load atomic float{{.*}} align 2
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load atomic double{{.*}} align 4

  ; Too-large alignments for atomics are also rejected.
  load atomic i32* %ptr.i32 seq_cst, align 8
  load atomic float* %ptr.float seq_cst, align 8
  load atomic double* %ptr.double seq_cst, align 16
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load atomic i32{{.*}} align 8
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load atomic float{{.*}} align 8
; CHECK-NEXT: disallowed: bad alignment: {{.*}} load atomic double{{.*}} align 16

  ret void
}