| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| ; RUN: llc < %s -mtriple=i686-- -mcpu=yonah | FileCheck %s |
| |
| ; Legalization example that requires splitting a large vector into smaller pieces. |
| |
| define void @update(<8 x i32> %val, <8 x i32>* %dst) nounwind { |
| ; CHECK-LABEL: update: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: movl {{[0-9]+}}(%esp), %eax |
| ; CHECK-NEXT: psrad $2, %xmm0 |
| ; CHECK-NEXT: psrad $4, %xmm1 |
| ; CHECK-NEXT: movdqa %xmm1, 16(%eax) |
| ; CHECK-NEXT: movdqa %xmm0, (%eax) |
| ; CHECK-NEXT: retl |
| entry: |
| %shl = shl <8 x i32> %val, < i32 2, i32 2, i32 2, i32 2, i32 4, i32 4, i32 4, i32 4 > |
| %shr = ashr <8 x i32> %val, < i32 2, i32 2, i32 2, i32 2, i32 4, i32 4, i32 4, i32 4 > |
| store <8 x i32> %shr, <8 x i32>* %dst |
| ret void |
| } |