Skip to content

Commit 09eea22

Browse files
authored
[Attributor] Check range size before constant fold load (llvm#151359)
If the range size doesn't match the type size, it might read wrong data.
1 parent 8485777 commit 09eea22

File tree

2 files changed

+41
-0
lines changed

2 files changed

+41
-0
lines changed

llvm/lib/Transforms/IPO/Attributor.cpp

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -272,6 +272,9 @@ AA::getInitialValueForObj(Attributor &A, const AbstractAttribute &QueryingAA,
272272
}
273273

274274
if (RangePtr && !RangePtr->offsetOrSizeAreUnknown()) {
275+
int64_t StorageSize = DL.getTypeStoreSize(&Ty);
276+
if (StorageSize != RangePtr->Size)
277+
return nullptr;
275278
APInt Offset = APInt(64, RangePtr->Offset);
276279
return ConstantFoldLoadFromConst(Initializer, &Ty, Offset, DL);
277280
}
Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6
2+
; RUN: opt -S -passes=attributor %s -o - | FileCheck %s
3+
4+
@g = internal unnamed_addr addrspace(4) constant [3 x i8] c"12\00", align 16
5+
6+
define void @foo(i32 %a, i32 %b, ptr %p.0, ptr %p.1) {
7+
; CHECK-LABEL: define void @foo(
8+
; CHECK-SAME: i32 [[A:%.*]], i32 [[B:%.*]], ptr nofree nonnull writeonly captures(none) dereferenceable(1) [[P_0:%.*]], ptr nofree nonnull writeonly align 4 captures(none) dereferenceable(8) [[P_1:%.*]]) #[[ATTR0:[0-9]+]] {
9+
; CHECK-NEXT: [[ENTRY:.*:]]
10+
; CHECK-NEXT: [[CMP:%.*]] = icmp ne i32 [[A]], [[B]]
11+
; CHECK-NEXT: br i1 [[CMP]], label %[[L1:.*]], label %[[L2:.*]]
12+
; CHECK: [[L1]]:
13+
; CHECK-NEXT: br label %[[L3:.*]]
14+
; CHECK: [[L2]]:
15+
; CHECK-NEXT: br label %[[L3]]
16+
; CHECK: [[L3]]:
17+
; CHECK-NEXT: [[PHI:%.*]] = phi ptr addrspace(4) [ @g, %[[L1]] ], [ getelementptr inbounds nuw (i8, ptr addrspace(4) @g, i64 1), %[[L2]] ]
18+
; CHECK-NEXT: [[LOAD_SMALL:%.*]] = load i8, ptr addrspace(4) [[PHI]], align 4
19+
; CHECK-NEXT: store i8 [[LOAD_SMALL]], ptr [[P_0]], align 1
20+
; CHECK-NEXT: [[LOAD_LARGE:%.*]] = load i64, ptr addrspace(4) [[PHI]], align 4
21+
; CHECK-NEXT: store i64 [[LOAD_LARGE]], ptr [[P_1]], align 4
22+
; CHECK-NEXT: ret void
23+
;
24+
entry:
25+
%cmp = icmp ne i32 %a, %b
26+
br i1 %cmp, label %l1, label %l2
27+
l1:
28+
br label %l3
29+
l2:
30+
br label %l3
31+
l3:
32+
%phi = phi ptr addrspace(4) [ @g, %l1 ], [ getelementptr inbounds nuw (i8, ptr addrspace(4) @g, i64 1), %l2 ]
33+
%load.small = load i8, ptr addrspace(4) %phi
34+
store i8 %load.small, ptr %p.0
35+
%load.large = load i64, ptr addrspace(4) %phi
36+
store i64 %load.large, ptr %p.1
37+
ret void
38+
}

0 commit comments

Comments
 (0)