Home | History | Annotate | Download | only in X86
      1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
      2 ; RUN: llc < %s -mtriple=x86_64-linux | FileCheck %s --check-prefix=LNX1
      3 ; RUN: llc < %s -mtriple=x86_64-linux-gnux32 | FileCheck %s --check-prefix=LNX2
      4 ; RUN: llc < %s -mtriple=x86_64-nacl | FileCheck %s --check-prefix=NACL
      5 ; RUN: llc < %s -mtriple=x86_64-win32 | FileCheck %s --check-prefix=WIN
      6 
      7 define i64 @test2(i64 %a) {
      8 ; LNX1-LABEL: test2:
      9 ; LNX1:       # %bb.0:
     10 ; LNX1-NEXT:    leaq (,%rdi,4), %rax
     11 ; LNX1-NEXT:    orq %rdi, %rax
     12 ; LNX1-NEXT:    retq
     13 ;
     14 ; LNX2-LABEL: test2:
     15 ; LNX2:       # %bb.0:
     16 ; LNX2-NEXT:    leaq (,%rdi,4), %rax
     17 ; LNX2-NEXT:    orq %rdi, %rax
     18 ; LNX2-NEXT:    retq
     19 ;
     20 ; NACL-LABEL: test2:
     21 ; NACL:       # %bb.0:
     22 ; NACL-NEXT:    leaq (,%rdi,4), %rax
     23 ; NACL-NEXT:    orq %rdi, %rax
     24 ; NACL-NEXT:    retq
     25 ;
     26 ; WIN-LABEL: test2:
     27 ; WIN:       # %bb.0:
     28 ; WIN-NEXT:    leaq (,%rcx,4), %rax
     29 ; WIN-NEXT:    orq %rcx, %rax
     30 ; WIN-NEXT:    retq
     31   %tmp2 = shl i64 %a, 2
     32 	%tmp3 = or i64 %tmp2, %a
     33   ret i64 %tmp3
     34 }
     35 
     36 define i32 @test(i32 %a) {
     37 ; LNX1-LABEL: test:
     38 ; LNX1:       # %bb.0:
     39 ; LNX1-NEXT:    # kill: def $edi killed $edi def $rdi
     40 ; LNX1-NEXT:    leal (%rdi,%rdi,2), %eax
     41 ; LNX1-NEXT:    retq
     42 ;
     43 ; LNX2-LABEL: test:
     44 ; LNX2:       # %bb.0:
     45 ; LNX2-NEXT:    # kill: def $edi killed $edi def $rdi
     46 ; LNX2-NEXT:    leal (%rdi,%rdi,2), %eax
     47 ; LNX2-NEXT:    retq
     48 ;
     49 ; NACL-LABEL: test:
     50 ; NACL:       # %bb.0:
     51 ; NACL-NEXT:    # kill: def $edi killed $edi def $rdi
     52 ; NACL-NEXT:    leal (%rdi,%rdi,2), %eax
     53 ; NACL-NEXT:    retq
     54 ;
     55 ; WIN-LABEL: test:
     56 ; WIN:       # %bb.0:
     57 ; WIN-NEXT:    # kill: def $ecx killed $ecx def $rcx
     58 ; WIN-NEXT:    leal (%rcx,%rcx,2), %eax
     59 ; WIN-NEXT:    retq
     60   %tmp2 = mul i32 %a, 3
     61   ret i32 %tmp2
     62 }
     63 
     64 define i64 @test3(i64 %a) {
     65 ; LNX1-LABEL: test3:
     66 ; LNX1:       # %bb.0:
     67 ; LNX1-NEXT:    leaq (,%rdi,8), %rax
     68 ; LNX1-NEXT:    retq
     69 ;
     70 ; LNX2-LABEL: test3:
     71 ; LNX2:       # %bb.0:
     72 ; LNX2-NEXT:    leaq (,%rdi,8), %rax
     73 ; LNX2-NEXT:    retq
     74 ;
     75 ; NACL-LABEL: test3:
     76 ; NACL:       # %bb.0:
     77 ; NACL-NEXT:    leaq (,%rdi,8), %rax
     78 ; NACL-NEXT:    retq
     79 ;
     80 ; WIN-LABEL: test3:
     81 ; WIN:       # %bb.0:
     82 ; WIN-NEXT:    leaq (,%rcx,8), %rax
     83 ; WIN-NEXT:    retq
     84   %tmp2 = shl i64 %a, 3
     85   ret i64 %tmp2
     86 }
     87 
     88