diff options
Diffstat (limited to 'llvm/test')
| -rw-r--r-- | llvm/test/Assembler/insertextractvalue.ll | 13 | ||||
| -rw-r--r-- | llvm/test/Verifier/2006-07-11-StoreStruct.ll | 6 |
2 files changed, 17 insertions, 2 deletions
diff --git a/llvm/test/Assembler/insertextractvalue.ll b/llvm/test/Assembler/insertextractvalue.ll new file mode 100644 index 00000000000..ae03f45bcef --- /dev/null +++ b/llvm/test/Assembler/insertextractvalue.ll @@ -0,0 +1,13 @@ +; RUN: llvm-as < %s + +;define float @foo({{i32},{float, double}}* %p) { + ;%t = load {{i32},{float, double}}* %p + ;%s = extractvalue {{i32},{float, double}} %t, i32 1, i32 0 + ;%r = insertvalue {{i32},{float, double}} %t, double 2.0, i32 1, i32 1 + ;store {{i32},{float, double}} %r, {{i32},{float, double}}* %p + ;ret float %s +;} +define float @bar({{i32},{float, double}}* %p) { + store {{i32},{float, double}} insertvalue ({{i32},{float, double}}{{i32}{i32 4},{float, double}{float 4.0, double 5.0}}, double 20.0, i32 1, i32 1), {{i32},{float, double}}* %p + ret float extractvalue ({{i32},{float, double}}{{i32}{i32 3},{float, double}{float 7.0, double 9.0}}, i32 1, i32 0) +} diff --git a/llvm/test/Verifier/2006-07-11-StoreStruct.ll b/llvm/test/Verifier/2006-07-11-StoreStruct.ll index 655e4b748ef..80ab122d0b7 100644 --- a/llvm/test/Verifier/2006-07-11-StoreStruct.ll +++ b/llvm/test/Verifier/2006-07-11-StoreStruct.ll @@ -1,5 +1,7 @@ -; RUN: not llvm-as < %s |& grep {Instruction operands must be first-class} -; PR826 +; RUN: llvm-as < %s |& not grep {Instruction operands must be first-class} + +; This previously was for PR826, but structs are now first-class so +; the following is now valid. %struct_4 = type { i32 } |

