[ARM] Adjust how NEON shifts are lowered
[llvm-core.git] / test / CodeGen / X86 / subreg-to-reg-2.ll
blob6766b013a36e9c945ebb8fdc2b12a1a61cdcb465
1 ; RUN: llc < %s -mtriple=x86_64-apple-darwin | grep movl
2 ; rdar://6707985
4         %XXOO = type { %"struct.XXC::XXCC", i8*, %"struct.XXC::XXOO::$_71" }
5         %XXValue = type opaque
6         %"struct.XXC::ArrayStorage" = type { i32, i32, i32, i8*, i8*, [1 x %XXValue*] }
7         %"struct.XXC::XXArray" = type { %XXOO, i32, %"struct.XXC::ArrayStorage"* }
8         %"struct.XXC::XXCC" = type { i32 (...)**, i8* }
9         %"struct.XXC::XXOO::$_71" = type { [2 x %XXValue*] }
11 define internal fastcc %XXValue* @t(i64* %out, %"struct.XXC::ArrayStorage"* %tmp9) nounwind {
12 prologue:
13         %array = load %XXValue*, %XXValue** inttoptr (i64 11111111 to %XXValue**)               ; <%XXValue*> [#uses=0]
14         %index = load %XXValue*, %XXValue** inttoptr (i64 22222222 to %XXValue**)               ; <%XXValue*> [#uses=1]
15         %tmp = ptrtoint %XXValue* %index to i64         ; <i64> [#uses=2]
16         store i64 %tmp, i64* %out
17         %tmp6 = trunc i64 %tmp to i32           ; <i32> [#uses=1]
18         br label %bb5
20 bb5:            ; preds = %prologue
21         %tmp10 = zext i32 %tmp6 to i64          ; <i64> [#uses=1]
22         %tmp11 = getelementptr %"struct.XXC::ArrayStorage", %"struct.XXC::ArrayStorage"* %tmp9, i64 0, i32 5, i64 %tmp10                ; <%XXValue**> [#uses=1]
23         %tmp12 = load %XXValue*, %XXValue** %tmp11, align 8             ; <%XXValue*> [#uses=1]
24         ret %XXValue* %tmp12