|  | ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py | 
|  | ; RUN: llc < %s -mtriple=i686-unknown-linux-gnu | FileCheck %s --check-prefix=X86 | 
|  | ; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu | FileCheck %s --check-prefix=X64 | 
|  |  | 
|  | %destTy = type { i2, i2 } | 
|  |  | 
|  | define void @crash(i64 %x0, i64 %y0, ptr nocapture %dest) nounwind { | 
|  | ; X86-LABEL: crash: | 
|  | ; X86:       # %bb.0: | 
|  | ; X86-NEXT:    movl {{[0-9]+}}(%esp), %eax | 
|  | ; X86-NEXT:    movzbl {{[0-9]+}}(%esp), %ecx | 
|  | ; X86-NEXT:    movzbl {{[0-9]+}}(%esp), %edx | 
|  | ; X86-NEXT:    shlb $2, %dl | 
|  | ; X86-NEXT:    andb $3, %cl | 
|  | ; X86-NEXT:    orb %dl, %cl | 
|  | ; X86-NEXT:    andb $15, %cl | 
|  | ; X86-NEXT:    movb %cl, (%eax) | 
|  | ; X86-NEXT:    retl | 
|  | ; | 
|  | ; X64-LABEL: crash: | 
|  | ; X64:       # %bb.0: | 
|  | ; X64-NEXT:    shlb $2, %sil | 
|  | ; X64-NEXT:    andb $3, %dil | 
|  | ; X64-NEXT:    orb %sil, %dil | 
|  | ; X64-NEXT:    andb $15, %dil | 
|  | ; X64-NEXT:    movb %dil, (%rdx) | 
|  | ; X64-NEXT:    retq | 
|  | %x1 = trunc i64 %x0 to i2 | 
|  | %y1 = trunc i64 %y0 to i2 | 
|  | %1 = insertelement <2 x i2> undef, i2 %x1, i32 0 | 
|  | %2 = insertelement <2 x i2> %1, i2 %y1, i32 1 | 
|  | store <2 x i2> %2, ptr %dest, align 1 | 
|  | ret void | 
|  | } |