mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-02-01 05:01:59 +01:00
3ea2df7c7b
Similar to gep (r230786) and load (r230794) changes. Similar migration script can be used to update test cases, which successfully migrated all of LLVM and Polly, but about 4 test cases needed manually changes in Clang. (this script will read the contents of stdin and massage it into stdout - wrap it in the 'apply.sh' script shown in previous commits + xargs to apply it over a large set of test cases) import fileinput import sys import re rep = re.compile(r"(getelementptr(?:\s+inbounds)?\s*\()((<\d*\s+x\s+)?([^@]*?)(|\s*addrspace\(\d+\))\s*\*(?(3)>)\s*)(?=$|%|@|null|undef|blockaddress|getelementptr|addrspacecast|bitcast|inttoptr|zeroinitializer|<|\[\[[a-zA-Z]|\{\{)", re.MULTILINE | re.DOTALL) def conv(match): line = match.group(1) line += match.group(4) line += ", " line += match.group(2) return line line = sys.stdin.read() off = 0 for match in re.finditer(rep, line): sys.stdout.write(line[off:match.start()]) sys.stdout.write(conv(match)) off = match.end() sys.stdout.write(line[off:]) llvm-svn: 232184
78 lines
2.0 KiB
LLVM
78 lines
2.0 KiB
LLVM
; RUN: opt < %s -instsimplify -S | FileCheck %s
|
|
target datalayout = "p:32:32"
|
|
|
|
; Check some past-the-end subtleties.
|
|
|
|
@opte_a = global i32 0
|
|
@opte_b = global i32 0
|
|
|
|
; Comparing base addresses of two distinct globals. Never equal.
|
|
|
|
define zeroext i1 @no_offsets() {
|
|
%t = icmp eq i32* @opte_a, @opte_b
|
|
ret i1 %t
|
|
; CHECK: no_offsets(
|
|
; CHECK: ret i1 false
|
|
}
|
|
|
|
; Comparing past-the-end addresses of two distinct globals. Never equal.
|
|
|
|
define zeroext i1 @both_past_the_end() {
|
|
%x = getelementptr i32, i32* @opte_a, i32 1
|
|
%y = getelementptr i32, i32* @opte_b, i32 1
|
|
%t = icmp eq i32* %x, %y
|
|
ret i1 %t
|
|
; CHECK: both_past_the_end(
|
|
; CHECK-NOT: ret i1 true
|
|
; TODO: refine this
|
|
}
|
|
|
|
; Comparing past-the-end addresses of one global to the base address
|
|
; of another. Can't fold this.
|
|
|
|
define zeroext i1 @just_one_past_the_end() {
|
|
%x = getelementptr i32, i32* @opte_a, i32 1
|
|
%t = icmp eq i32* %x, @opte_b
|
|
ret i1 %t
|
|
; CHECK: just_one_past_the_end(
|
|
; CHECK: ret i1 icmp eq (i32* getelementptr inbounds (i32, i32* @opte_a, i32 1), i32* @opte_b)
|
|
}
|
|
|
|
; Comparing base addresses of two distinct allocas. Never equal.
|
|
|
|
define zeroext i1 @no_alloca_offsets() {
|
|
%m = alloca i32
|
|
%n = alloca i32
|
|
%t = icmp eq i32* %m, %n
|
|
ret i1 %t
|
|
; CHECK: no_alloca_offsets(
|
|
; CHECK: ret i1 false
|
|
}
|
|
|
|
; Comparing past-the-end addresses of two distinct allocas. Never equal.
|
|
|
|
define zeroext i1 @both_past_the_end_alloca() {
|
|
%m = alloca i32
|
|
%n = alloca i32
|
|
%x = getelementptr i32, i32* %m, i32 1
|
|
%y = getelementptr i32, i32* %n, i32 1
|
|
%t = icmp eq i32* %x, %y
|
|
ret i1 %t
|
|
; CHECK: both_past_the_end_alloca(
|
|
; CHECK-NOT: ret i1 true
|
|
; TODO: refine this
|
|
}
|
|
|
|
; Comparing past-the-end addresses of one alloca to the base address
|
|
; of another. Can't fold this.
|
|
|
|
define zeroext i1 @just_one_past_the_end_alloca() {
|
|
%m = alloca i32
|
|
%n = alloca i32
|
|
%x = getelementptr i32, i32* %m, i32 1
|
|
%t = icmp eq i32* %x, %n
|
|
ret i1 %t
|
|
; CHECK: just_one_past_the_end_alloca(
|
|
; CHECK: ret i1 %t
|
|
}
|