mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
Add -lowertypetests-bitsets-level to control bitsets generation.
Summary: Sometimes, bitsets could get really large (>300k entries) and we might want to drop a check, as it would have a too much cost. Adding a flag to control how much penalty are we willing to pay for bitsets. Reviewers: kcc Differential Revision: https://reviews.llvm.org/D23088 llvm-svn: 277556
This commit is contained in:
parent
e6a6ea1a8c
commit
2b69153c7d
@ -48,6 +48,11 @@ static cl::opt<bool> AvoidReuse(
|
||||
cl::desc("Try to avoid reuse of byte array addresses using aliases"),
|
||||
cl::Hidden, cl::init(true));
|
||||
|
||||
static cl::opt<unsigned> BitsetsLevel(
|
||||
"lowertypetests-bitsets-level",
|
||||
cl::desc("Whether to generate bitsets: 0 - never, 1 - only if no loads, 2 - always."),
|
||||
cl::Hidden, cl::init(2));
|
||||
|
||||
bool BitSetInfo::containsGlobalOffset(uint64_t Offset) const {
|
||||
if (Offset < ByteOffset)
|
||||
return false;
|
||||
@ -473,8 +478,10 @@ Value *LowerTypeTests::lowerBitSetCall(
|
||||
Constant *BitSizeConst = ConstantInt::get(IntPtrTy, BSI.BitSize);
|
||||
Value *OffsetInRange = B.CreateICmpULT(BitOffset, BitSizeConst);
|
||||
|
||||
// If the bit set is all ones, testing against it is unnecessary.
|
||||
if (BSI.isAllOnes())
|
||||
// If the bit set is all ones (or we treat it as such), testing against it
|
||||
// is unnecessary.
|
||||
if (BSI.isAllOnes() || BitsetsLevel == 0 ||
|
||||
(BitsetsLevel == 1 && BSI.BitSize > 64))
|
||||
return OffsetInRange;
|
||||
|
||||
TerminatorInst *Term = SplitBlockAndInsertIfThen(OffsetInRange, CI, false);
|
||||
|
@ -1,4 +1,6 @@
|
||||
; RUN: opt -S -lowertypetests < %s | FileCheck %s
|
||||
; RUN: opt -S -lowertypetests < %s | FileCheck --check-prefixes=CHECK,CHECK2 %s
|
||||
; RUN: opt -S -lowertypetests -lowertypetests-bitsets-level=0 < %s | FileCheck --check-prefixes=CHECK,CHECK0 %s
|
||||
; RUN: opt -S -lowertypetests -lowertypetests-bitsets-level=2 < %s | FileCheck --check-prefixes=CHECK,CHECK2 %s
|
||||
; RUN: opt -S -lowertypetests -mtriple=x86_64-apple-macosx10.8.0 < %s | FileCheck -check-prefix=CHECK-DARWIN %s
|
||||
; RUN: opt -S -O3 < %s | FileCheck -check-prefix=CHECK-NODISCARD %s
|
||||
|
||||
@ -18,7 +20,7 @@ target datalayout = "e-p:32:32"
|
||||
; CHECK-NODISCARD: !type
|
||||
; CHECK-NODISCARD: !type
|
||||
|
||||
; CHECK: [[BA:@[^ ]*]] = private constant [68 x i8] c"\03\01\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\02\00\01"
|
||||
; CHECK2: [[BA:@[^ ]*]] = private constant [68 x i8] c"\03\01\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\02\00\01"
|
||||
|
||||
; Offset 0, 4 byte alignment
|
||||
!0 = !{i32 0, !"typeid1"}
|
||||
@ -30,9 +32,10 @@ target datalayout = "e-p:32:32"
|
||||
; Offset 0, 4 byte alignment
|
||||
!2 = !{i32 0, !"typeid3"}
|
||||
|
||||
; CHECK: @bits_use{{[0-9]*}} = private alias i8, i8* @bits{{[0-9]*}}
|
||||
; CHECK: @bits_use.{{[0-9]*}} = private alias i8, i8* @bits{{[0-9]*}}
|
||||
; CHECK: @bits_use.{{[0-9]*}} = private alias i8, i8* @bits{{[0-9]*}}
|
||||
; CHECK2: @bits_use{{[0-9]*}} = private alias i8, i8* @bits{{[0-9]*}}
|
||||
; CHECK0-NOT: bits_use
|
||||
; CHECK2: @bits_use.{{[0-9]*}} = private alias i8, i8* @bits{{[0-9]*}}
|
||||
; CHECK2: @bits_use.{{[0-9]*}} = private alias i8, i8* @bits{{[0-9]*}}
|
||||
|
||||
; CHECK: @a = alias i32, getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 0)
|
||||
; CHECK: @b = hidden alias [63 x i32], getelementptr inbounds ({ i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }, { i32, [0 x i8], [63 x i32], [4 x i8], i32, [0 x i8], [2 x i32] }* [[G]], i32 0, i32 2)
|
||||
@ -53,8 +56,8 @@ target datalayout = "e-p:32:32"
|
||||
|
||||
; CHECK-DARWIN: [[G]] = private constant
|
||||
|
||||
; CHECK: @bits{{[0-9]*}} = private alias i8, getelementptr inbounds ([68 x i8], [68 x i8]* [[BA]], i32 0, i32 0)
|
||||
; CHECK: @bits.{{[0-9]*}} = private alias i8, getelementptr inbounds ([68 x i8], [68 x i8]* [[BA]], i32 0, i32 0)
|
||||
; CHECK2: @bits{{[0-9]*}} = private alias i8, getelementptr inbounds ([68 x i8], [68 x i8]* [[BA]], i32 0, i32 0)
|
||||
; CHECK2: @bits.{{[0-9]*}} = private alias i8, getelementptr inbounds ([68 x i8], [68 x i8]* [[BA]], i32 0, i32 0)
|
||||
|
||||
declare i1 @llvm.type.test(i8* %ptr, metadata %bitset) nounwind readnone
|
||||
|
||||
@ -70,20 +73,24 @@ define i1 @foo(i32* %p) {
|
||||
; CHECK: [[R4:%[^ ]*]] = shl i32 [[R2]], 30
|
||||
; CHECK: [[R5:%[^ ]*]] = or i32 [[R3]], [[R4]]
|
||||
; CHECK: [[R6:%[^ ]*]] = icmp ult i32 [[R5]], 68
|
||||
; CHECK: br i1 [[R6]]
|
||||
; CHECK2: br i1 [[R6]]
|
||||
; CHECK0-NOT: br
|
||||
|
||||
; CHECK: [[R8:%[^ ]*]] = getelementptr i8, i8* @bits_use.{{[0-9]*}}, i32 [[R5]]
|
||||
; CHECK: [[R9:%[^ ]*]] = load i8, i8* [[R8]]
|
||||
; CHECK: [[R10:%[^ ]*]] = and i8 [[R9]], 1
|
||||
; CHECK: [[R11:%[^ ]*]] = icmp ne i8 [[R10]], 0
|
||||
; CHECK2: [[R8:%[^ ]*]] = getelementptr i8, i8* @bits_use.{{[0-9]*}}, i32 [[R5]]
|
||||
; CHECK0-NOT: bits_use
|
||||
; CHECK2: [[R9:%[^ ]*]] = load i8, i8* [[R8]]
|
||||
; CHECK2: [[R10:%[^ ]*]] = and i8 [[R9]], 1
|
||||
; CHECK2: [[R11:%[^ ]*]] = icmp ne i8 [[R10]], 0
|
||||
|
||||
; CHECK: [[R16:%[^ ]*]] = phi i1 [ false, {{%[^ ]*}} ], [ [[R11]], {{%[^ ]*}} ]
|
||||
; CHECK2: [[R16:%[^ ]*]] = phi i1 [ false, {{%[^ ]*}} ], [ [[R11]], {{%[^ ]*}} ]
|
||||
%x = call i1 @llvm.type.test(i8* %pi8, metadata !"typeid1")
|
||||
|
||||
; CHECK-NOT: llvm.type.test
|
||||
; CHECK0-NOT: llvm.type.test
|
||||
%y = call i1 @llvm.type.test(i8* %pi8, metadata !"typeid1")
|
||||
|
||||
; CHECK: ret i1 [[R16]]
|
||||
; CHECK2: ret i1 [[R16]]
|
||||
; CHECK0: ret i1 [[R6]]
|
||||
ret i1 %x
|
||||
}
|
||||
|
||||
@ -113,15 +120,18 @@ define i1 @baz(i32* %p) {
|
||||
; CHECK: [[T4:%[^ ]*]] = shl i32 [[T2]], 30
|
||||
; CHECK: [[T5:%[^ ]*]] = or i32 [[T3]], [[T4]]
|
||||
; CHECK: [[T6:%[^ ]*]] = icmp ult i32 [[T5]], 66
|
||||
; CHECK: br i1 [[T6]]
|
||||
; CHECK2: br i1 [[T6]]
|
||||
; CHECK0-NOT: br
|
||||
|
||||
; CHECK: [[T8:%[^ ]*]] = getelementptr i8, i8* @bits_use{{(\.[0-9]*)?}}, i32 [[T5]]
|
||||
; CHECK: [[T9:%[^ ]*]] = load i8, i8* [[T8]]
|
||||
; CHECK: [[T10:%[^ ]*]] = and i8 [[T9]], 2
|
||||
; CHECK: [[T11:%[^ ]*]] = icmp ne i8 [[T10]], 0
|
||||
; CHECK2: [[T8:%[^ ]*]] = getelementptr i8, i8* @bits_use{{(\.[0-9]*)?}}, i32 [[T5]]
|
||||
; CHECK0-NOT: bits_use
|
||||
; CHECK2: [[T9:%[^ ]*]] = load i8, i8* [[T8]]
|
||||
; CHECK2: [[T10:%[^ ]*]] = and i8 [[T9]], 2
|
||||
; CHECK2: [[T11:%[^ ]*]] = icmp ne i8 [[T10]], 0
|
||||
|
||||
; CHECK: [[T16:%[^ ]*]] = phi i1 [ false, {{%[^ ]*}} ], [ [[T11]], {{%[^ ]*}} ]
|
||||
; CHECK2: [[T16:%[^ ]*]] = phi i1 [ false, {{%[^ ]*}} ], [ [[T11]], {{%[^ ]*}} ]
|
||||
%x = call i1 @llvm.type.test(i8* %pi8, metadata !"typeid3")
|
||||
; CHECK: ret i1 [[T16]]
|
||||
; CHECK2: ret i1 [[T16]]
|
||||
; CHECK0: ret i1 [[T6]]
|
||||
ret i1 %x
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user