|
32 | 32 | ret i32 undef
|
33 | 33 | }
|
34 | 34 |
|
35 |
| - |
36 | 35 | declare float @llvm.powi.f32.i32(float, i32)
|
37 | 36 | define void @fn2(i32* %a, i32* %b, float* %c) {
|
38 | 37 | ; CHECK-LABEL: @fn2(
|
@@ -99,3 +98,37 @@ entry:
|
99 | 98 | ret void
|
100 | 99 |
|
101 | 100 | }
|
| 101 | + |
| 102 | +define void @externally_used_ptrs() { |
| 103 | +; CHECK-LABEL: @externally_used_ptrs( |
| 104 | +; CHECK-NEXT: entry: |
| 105 | +; CHECK-NEXT: [[TMP0:%.*]] = load i64*, i64** @a, align 8 |
| 106 | +; CHECK-NEXT: [[TMP1:%.*]] = insertelement <2 x i64*> poison, i64* [[TMP0]], i32 0 |
| 107 | +; CHECK-NEXT: [[TMP2:%.*]] = insertelement <2 x i64*> [[TMP1]], i64* [[TMP0]], i32 1 |
| 108 | +; CHECK-NEXT: [[TMP3:%.*]] = getelementptr i64, <2 x i64*> [[TMP2]], <2 x i64> <i64 56, i64 11> |
| 109 | +; CHECK-NEXT: [[TMP4:%.*]] = ptrtoint <2 x i64*> [[TMP3]] to <2 x i64> |
| 110 | +; CHECK-NEXT: [[ARRAYIDX2:%.*]] = getelementptr inbounds i64, i64* [[TMP0]], i64 12 |
| 111 | +; CHECK-NEXT: [[TMP5:%.*]] = extractelement <2 x i64*> [[TMP3]], i32 0 |
| 112 | +; CHECK-NEXT: [[TMP6:%.*]] = bitcast i64* [[TMP5]] to <2 x i64>* |
| 113 | +; CHECK-NEXT: [[TMP7:%.*]] = load <2 x i64>, <2 x i64>* [[TMP6]], align 8 |
| 114 | +; CHECK-NEXT: [[TMP8:%.*]] = extractelement <2 x i64*> [[TMP3]], i32 1 |
| 115 | +; CHECK-NEXT: [[TMP9:%.*]] = add <2 x i64> [[TMP4]], [[TMP7]] |
| 116 | +; CHECK-NEXT: [[TMP10:%.*]] = bitcast i64* [[TMP5]] to <2 x i64>* |
| 117 | +; CHECK-NEXT: store <2 x i64> [[TMP9]], <2 x i64>* [[TMP10]], align 8 |
| 118 | +; CHECK-NEXT: ret void |
| 119 | +; |
| 120 | +entry: |
| 121 | + %0 = load i64*, i64** @a, align 8 |
| 122 | + %add.ptr = getelementptr inbounds i64, i64* %0, i64 11 |
| 123 | + %1 = ptrtoint i64* %add.ptr to i64 |
| 124 | + %add.ptr1 = getelementptr inbounds i64, i64* %0, i64 56 |
| 125 | + %2 = ptrtoint i64* %add.ptr1 to i64 |
| 126 | + %arrayidx2 = getelementptr inbounds i64, i64* %0, i64 12 |
| 127 | + %3 = load i64, i64* %arrayidx2, align 8 |
| 128 | + %4 = load i64, i64* %add.ptr, align 8 |
| 129 | + %5 = add i64 %1, %3 |
| 130 | + %6 = add i64 %2, %4 |
| 131 | + store i64 %6, i64* %add.ptr, align 8 |
| 132 | + store i64 %5, i64* %arrayidx2, align 8 |
| 133 | + ret void |
| 134 | +} |
0 commit comments