diff --git a/test/CodeGen/ARM/2009-04-08-AggregateAddr.ll b/test/CodeGen/ARM/2009-04-08-AggregateAddr.ll new file mode 100644 index 00000000000..c00b1fb9860 --- /dev/null +++ b/test/CodeGen/ARM/2009-04-08-AggregateAddr.ll @@ -0,0 +1,18 @@ +; RUN: llvm-as < %s | llc -march=arm +; PR3795 + +define fastcc void @_D3foo3fooFAriZv({ i32, { double, double }* } %d_arg, i32 %x_arg) { +entry: + %d = alloca { i32, { double, double }* } ; <{ i32, { double, double }* }*> [#uses=2] + %x = alloca i32 ; [#uses=2] + %b = alloca { double, double } ; <{ double, double }*> [#uses=1] + store { i32, { double, double }* } %d_arg, { i32, { double, double }* }* %d + store i32 %x_arg, i32* %x + %tmp = load i32* %x ; [#uses=1] + %tmp1 = getelementptr { i32, { double, double }* }* %d, i32 0, i32 1 ; <{ double, double }**> [#uses=1] + %.ptr = load { double, double }** %tmp1 ; <{ double, double }*> [#uses=1] + %tmp2 = getelementptr { double, double }* %.ptr, i32 %tmp ; <{ double, double }*> [#uses=1] + %tmp3 = load { double, double }* %tmp2 ; <{ double, double }> [#uses=1] + store { double, double } %tmp3, { double, double }* %b + ret void +}