mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-03 22:01:56 +00:00

update.py: import fileinput import sys import re alias_match_prefix = r"(.*(?:=|:|^)\s*(?:external |)(?:(?:private|internal|linkonce|linkonce_odr|weak|weak_odr|common|appending|extern_weak|available_externally) )?(?:default |hidden |protected )?(?:dllimport |dllexport )?(?:unnamed_addr |)(?:thread_local(?:\([a-z]*\))? )?alias" plain = re.compile(alias_match_prefix + r" (.*?))(| addrspace\(\d+\) *)\*($| *(?:%|@|null|undef|blockaddress|addrspacecast|\[\[[a-zA-Z]|\{\{).*$)") cast = re.compile(alias_match_prefix + r") ((?:bitcast|inttoptr|addrspacecast)\s*\(.* to (.*?)(| addrspace\(\d+\) *)\*\)\s*(?:;.*)?$)") gep = re.compile(alias_match_prefix + r") ((?:getelementptr)\s*(?:inbounds)?\s*\((?P<type>.*), (?P=type)(?:\s*addrspace\(\d+\)\s*)?\* .*\)\s*(?:;.*)?$)") def conv(line): m = re.match(cast, line) if m: return m.group(1) + " " + m.group(3) + ", " + m.group(2) m = re.match(gep, line) if m: return m.group(1) + " " + m.group(3) + ", " + m.group(2) m = re.match(plain, line) if m: return m.group(1) + ", " + m.group(2) + m.group(3) + "*" + m.group(4) + "\n" return line for line in sys.stdin: sys.stdout.write(conv(line)) apply.sh: for name in "$@" do python3 `dirname "$0"`/update.py < "$name" > "$name.tmp" && mv "$name.tmp" "$name" rm -f "$name.tmp" done The actual commands: From llvm/src: find test/ -name *.ll | xargs ./apply.sh From llvm/src/tools/clang: find test/ -name *.mm -o -name *.m -o -name *.cpp -o -name *.c | xargs -I '{}' ../../apply.sh "{}" From llvm/src/tools/polly: find test/ -name *.ll | xargs ./apply.sh git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@247378 91177308-0d34-0410-b5e6-96231b3b80d8
42 lines
1.6 KiB
LLVM
42 lines
1.6 KiB
LLVM
; RUN: opt -constmerge -S < %s | FileCheck %s
|
|
; Test that in one run var3 is merged into var2 and var1 into var4.
|
|
; Test that we merge @var5 and @var6 into one with the higher alignment
|
|
|
|
declare void @zed(%struct.foobar*, %struct.foobar*)
|
|
|
|
%struct.foobar = type { i32 }
|
|
|
|
@var1 = internal constant %struct.foobar { i32 2 }
|
|
@var2 = unnamed_addr constant %struct.foobar { i32 2 }
|
|
@var3 = internal constant %struct.foobar { i32 2 }
|
|
@var4 = unnamed_addr constant %struct.foobar { i32 2 }
|
|
|
|
; CHECK: %struct.foobar = type { i32 }
|
|
; CHECK-NOT: @
|
|
; CHECK: @var2 = constant %struct.foobar { i32 2 }
|
|
; CHECK-NEXT: @var4 = constant %struct.foobar { i32 2 }
|
|
|
|
declare void @helper([16 x i8]*)
|
|
@var5 = internal constant [16 x i8] c"foo1bar2foo3bar\00", align 16
|
|
@var6 = private unnamed_addr constant [16 x i8] c"foo1bar2foo3bar\00", align 1
|
|
@var7 = internal constant [16 x i8] c"foo1bar2foo3bar\00"
|
|
@var8 = private unnamed_addr constant [16 x i8] c"foo1bar2foo3bar\00"
|
|
|
|
; CHECK-NEXT: @var7 = internal constant [16 x i8] c"foo1bar2foo3bar\00"
|
|
; CHECK-NEXT: @var8 = private constant [16 x i8] c"foo1bar2foo3bar\00", align 16
|
|
|
|
@var4a = alias %struct.foobar, %struct.foobar* @var4
|
|
@llvm.used = appending global [1 x %struct.foobar*] [%struct.foobar* @var4a], section "llvm.metadata"
|
|
|
|
define i32 @main() {
|
|
entry:
|
|
call void @zed(%struct.foobar* @var1, %struct.foobar* @var2)
|
|
call void @zed(%struct.foobar* @var3, %struct.foobar* @var4)
|
|
call void @helper([16 x i8]* @var5)
|
|
call void @helper([16 x i8]* @var6)
|
|
call void @helper([16 x i8]* @var7)
|
|
call void @helper([16 x i8]* @var8)
|
|
ret i32 0
|
|
}
|
|
|