diff options
author | David Blaikie <dblaikie@gmail.com> | 2015-09-11 03:22:04 +0000 |
---|---|---|
committer | David Blaikie <dblaikie@gmail.com> | 2015-09-11 03:22:04 +0000 |
commit | 2f40830ddebea58a5b6dcf31fae32651e4bddc8f (patch) | |
tree | 75b71c6711893e70d9dbaf83762083db89badb0e /llvm/test/Bitcode/compatibility-3.6.ll | |
parent | 33b4675b4419da760df111a3eea41af1de36384f (diff) | |
download | bcm5719-llvm-2f40830ddebea58a5b6dcf31fae32651e4bddc8f.tar.gz bcm5719-llvm-2f40830ddebea58a5b6dcf31fae32651e4bddc8f.zip |
[opaque pointer type] Add textual IR support for explicit type parameter for global aliases
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
llvm-svn: 247378
Diffstat (limited to 'llvm/test/Bitcode/compatibility-3.6.ll')
-rw-r--r-- | llvm/test/Bitcode/compatibility-3.6.ll | 76 |
1 files changed, 38 insertions, 38 deletions
diff --git a/llvm/test/Bitcode/compatibility-3.6.ll b/llvm/test/Bitcode/compatibility-3.6.ll index d283f7120f4..53f061da00d 100644 --- a/llvm/test/Bitcode/compatibility-3.6.ll +++ b/llvm/test/Bitcode/compatibility-3.6.ll @@ -174,52 +174,52 @@ declare void @g.f1() ; [unnamed_addr] alias <AliaseeTy> @<Aliasee> ; Aliases -- Linkage -@a.private = private alias i32* @g.private -; CHECK: @a.private = private alias i32* @g.private -@a.internal = internal alias i32* @g.internal -; CHECK: @a.internal = internal alias i32* @g.internal -@a.linkonce = linkonce alias i32* @g.linkonce -; CHECK: @a.linkonce = linkonce alias i32* @g.linkonce -@a.weak = weak alias i32* @g.weak -; CHECK: @a.weak = weak alias i32* @g.weak -@a.linkonce_odr = linkonce_odr alias i32* @g.linkonce_odr -; CHECK: @a.linkonce_odr = linkonce_odr alias i32* @g.linkonce_odr -@a.weak_odr = weak_odr alias i32* @g.weak_odr -; CHECK: @a.weak_odr = weak_odr alias i32* @g.weak_odr -@a.external = external alias i32* @g1 -; CHECK: @a.external = alias i32* @g1 +@a.private = private alias i32, i32* @g.private +; CHECK: @a.private = private alias i32, i32* @g.private +@a.internal = internal alias i32, i32* @g.internal +; CHECK: @a.internal = internal alias i32, i32* @g.internal +@a.linkonce = linkonce alias i32, i32* @g.linkonce +; CHECK: @a.linkonce = linkonce alias i32, i32* @g.linkonce +@a.weak = weak alias i32, i32* @g.weak +; CHECK: @a.weak = weak alias i32, i32* @g.weak +@a.linkonce_odr = linkonce_odr alias i32, i32* @g.linkonce_odr +; CHECK: @a.linkonce_odr = linkonce_odr alias i32, i32* @g.linkonce_odr +@a.weak_odr = weak_odr alias i32, i32* @g.weak_odr +; CHECK: @a.weak_odr = weak_odr alias i32, i32* @g.weak_odr +@a.external = external alias i32, i32* @g1 +; CHECK: @a.external = alias i32, i32* @g1 ; Aliases -- Visibility -@a.default = default alias i32* @g.default -; CHECK: @a.default = alias i32* @g.default -@a.hidden = hidden alias i32* @g.hidden -; CHECK: @a.hidden = hidden alias i32* @g.hidden -@a.protected = protected alias i32* @g.protected -; CHECK: @a.protected = protected alias i32* @g.protected +@a.default = default alias i32, i32* @g.default +; CHECK: @a.default = alias i32, i32* @g.default +@a.hidden = hidden alias i32, i32* @g.hidden +; CHECK: @a.hidden = hidden alias i32, i32* @g.hidden +@a.protected = protected alias i32, i32* @g.protected +; CHECK: @a.protected = protected alias i32, i32* @g.protected ; Aliases -- DLLStorageClass -@a.dlldefault = default alias i32* @g.dlldefault -; CHECK: @a.dlldefault = alias i32* @g.dlldefault -@a.dllimport = dllimport alias i32* @g1 -; CHECK: @a.dllimport = dllimport alias i32* @g1 -@a.dllexport = dllexport alias i32* @g.dllexport -; CHECK: @a.dllexport = dllexport alias i32* @g.dllexport +@a.dlldefault = default alias i32, i32* @g.dlldefault +; CHECK: @a.dlldefault = alias i32, i32* @g.dlldefault +@a.dllimport = dllimport alias i32, i32* @g1 +; CHECK: @a.dllimport = dllimport alias i32, i32* @g1 +@a.dllexport = dllexport alias i32, i32* @g.dllexport +; CHECK: @a.dllexport = dllexport alias i32, i32* @g.dllexport ; Aliases -- ThreadLocal -@a.notthreadlocal = alias i32* @g.notthreadlocal -; CHECK: @a.notthreadlocal = alias i32* @g.notthreadlocal -@a.generaldynamic = thread_local alias i32* @g.generaldynamic -; CHECK: @a.generaldynamic = thread_local alias i32* @g.generaldynamic -@a.localdynamic = thread_local(localdynamic) alias i32* @g.localdynamic -; CHECK: @a.localdynamic = thread_local(localdynamic) alias i32* @g.localdynamic -@a.initialexec = thread_local(initialexec) alias i32* @g.initialexec -; CHECK: @a.initialexec = thread_local(initialexec) alias i32* @g.initialexec -@a.localexec = thread_local(localexec) alias i32* @g.localexec -; CHECK: @a.localexec = thread_local(localexec) alias i32* @g.localexec +@a.notthreadlocal = alias i32, i32* @g.notthreadlocal +; CHECK: @a.notthreadlocal = alias i32, i32* @g.notthreadlocal +@a.generaldynamic = thread_local alias i32, i32* @g.generaldynamic +; CHECK: @a.generaldynamic = thread_local alias i32, i32* @g.generaldynamic +@a.localdynamic = thread_local(localdynamic) alias i32, i32* @g.localdynamic +; CHECK: @a.localdynamic = thread_local(localdynamic) alias i32, i32* @g.localdynamic +@a.initialexec = thread_local(initialexec) alias i32, i32* @g.initialexec +; CHECK: @a.initialexec = thread_local(initialexec) alias i32, i32* @g.initialexec +@a.localexec = thread_local(localexec) alias i32, i32* @g.localexec +; CHECK: @a.localexec = thread_local(localexec) alias i32, i32* @g.localexec ; Aliases -- unnamed_addr -@a.unnamed_addr = unnamed_addr alias i32* @g.unnamed_addr -; CHECK: @a.unnamed_addr = unnamed_addr alias i32* @g.unnamed_addr +@a.unnamed_addr = unnamed_addr alias i32, i32* @g.unnamed_addr +; CHECK: @a.unnamed_addr = unnamed_addr alias i32, i32* @g.unnamed_addr ;; Functions ; Format: define [linkage] [visibility] [DLLStorageClass] |