aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Frontend/CompilerInvocation.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2011-02-10 07:11:16 +0000
committerChris Lattner <sabre@nondot.org>2011-02-10 07:11:16 +0000
commitd86ded17add6e221d1bc48f1bfd342564ea0a3b9 (patch)
treee8c4629f8a1d9f6516dccbb338ecf441d10e3118 /clang/lib/Frontend/CompilerInvocation.cpp
parente9b4ad7391d88e7a81cb863ae5da78b2635080ea (diff)
downloadllvm-d86ded17add6e221d1bc48f1bfd342564ea0a3b9.zip
llvm-d86ded17add6e221d1bc48f1bfd342564ea0a3b9.tar.gz
llvm-d86ded17add6e221d1bc48f1bfd342564ea0a3b9.tar.bz2
implement the first part of PR8882: when lowering an inbounds
gep to explicit addressing, we know that none of the intermediate computation overflows. This could use review: it seems that the shifts certainly wouldn't overflow, but could the intermediate adds overflow if there is a negative index? Previously the testcase would instcombine to: define i1 @test(i64 %i) { %p1.idx.mask = and i64 %i, 4611686018427387903 %cmp = icmp eq i64 %p1.idx.mask, 1000 ret i1 %cmp } now we get: define i1 @test(i64 %i) { %cmp = icmp eq i64 %i, 1000 ret i1 %cmp } llvm-svn: 125271
Diffstat (limited to 'clang/lib/Frontend/CompilerInvocation.cpp')
0 files changed, 0 insertions, 0 deletions