diff options
author | Duncan Sands <baldrick@free.fr> | 2009-03-20 21:53:29 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2009-03-20 21:53:29 +0000 |
commit | ab6b226978644c438a3a7768a06dcd48509d000c (patch) | |
tree | 8d574fefe86e8fa7cf23552dc4353c69bc8dec20 /test/Feature | |
parent | db95fa131a229652f925794ca7a5b84e9490050b (diff) | |
download | external_llvm-ab6b226978644c438a3a7768a06dcd48509d000c.zip external_llvm-ab6b226978644c438a3a7768a06dcd48509d000c.tar.gz external_llvm-ab6b226978644c438a3a7768a06dcd48509d000c.tar.bz2 |
Don't load values out of global constants with weak
linkage: the value may be replaced with something
different at link time. (Frontends that want to
allow values to be loaded out of weak constants can
give their constants weak_odr linkage).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67407 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Feature')
-rw-r--r-- | test/Feature/weak_constant.ll | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/test/Feature/weak_constant.ll b/test/Feature/weak_constant.ll new file mode 100644 index 0000000..d27adfe --- /dev/null +++ b/test/Feature/weak_constant.ll @@ -0,0 +1,38 @@ +; RUN: llvm-as < %s | opt -std-compile-opts | llvm-dis > %t +; RUN: grep undef %t | count 1 +; RUN: grep 5 %t | count 1 +; RUN: grep 7 %t | count 1 +; RUN: grep 9 %t | count 1 + + type { i32, i32 } ; type %0 +@a = weak constant i32 undef ; <i32*> [#uses=1] +@b = weak constant i32 5 ; <i32*> [#uses=1] +@c = weak constant %0 { i32 7, i32 9 } ; <%0*> [#uses=1] + +define i32 @la() { + %v = load i32* @a ; <i32> [#uses=1] + ret i32 %v +} + +define i32 @lb() { + %v = load i32* @b ; <i32> [#uses=1] + ret i32 %v +} + +define i32 @lc() { + %g = getelementptr %0* @c, i32 0, i32 0 ; <i32*> [#uses=1] + %u = load i32* %g ; <i32> [#uses=1] + %h = getelementptr %0* @c, i32 0, i32 1 ; <i32*> [#uses=1] + %v = load i32* %h ; <i32> [#uses=1] + %r = add i32 %u, %v + ret i32 %r +} + +define i32 @f() { + %u = call i32 @la() ; <i32> [#uses=1] + %v = call i32 @lb() ; <i32> [#uses=1] + %w = call i32 @lc() ; <i32> [#uses=1] + %r = add i32 %u, %v ; <i32> [#uses=1] + %s = add i32 %r, %w ; <i32> [#uses=1] + ret i32 %s +} |