Mercurial > hg > CbC > CbC_llvm
view test/CodeGen/X86/rot16.ll @ 95:afa8332a0e37 LLVM3.8
LLVM 3.8
author | Kaito Tokumori <e105711@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 13 Oct 2015 17:48:58 +0900 |
parents | e4204d083e25 |
children | 803732b1fca8 |
line wrap: on
line source
; RUN: llc < %s -march=x86 -mcpu=generic | FileCheck %s define i16 @foo(i16 %x, i16 %y, i16 %z) nounwind readnone { entry: ; CHECK-LABEL: foo: ; CHECK: rolw %cl %0 = shl i16 %x, %z %1 = sub i16 16, %z %2 = lshr i16 %x, %1 %3 = or i16 %2, %0 ret i16 %3 } define i16 @bar(i16 %x, i16 %y, i16 %z) nounwind readnone { entry: ; CHECK-LABEL: bar: ; CHECK: shldw %cl %0 = shl i16 %y, %z %1 = sub i16 16, %z %2 = lshr i16 %x, %1 %3 = or i16 %2, %0 ret i16 %3 } define i16 @un(i16 %x, i16 %y, i16 %z) nounwind readnone { entry: ; CHECK-LABEL: un: ; CHECK: rorw %cl %0 = lshr i16 %x, %z %1 = sub i16 16, %z %2 = shl i16 %x, %1 %3 = or i16 %2, %0 ret i16 %3 } define i16 @bu(i16 %x, i16 %y, i16 %z) nounwind readnone { entry: ; CHECK-LABEL: bu: ; CHECK: shrdw %0 = lshr i16 %y, %z %1 = sub i16 16, %z %2 = shl i16 %x, %1 %3 = or i16 %2, %0 ret i16 %3 } define i16 @xfoo(i16 %x, i16 %y, i16 %z) nounwind readnone { entry: ; CHECK-LABEL: xfoo: ; CHECK: rolw $5 %0 = lshr i16 %x, 11 %1 = shl i16 %x, 5 %2 = or i16 %0, %1 ret i16 %2 } define i16 @xbar(i16 %x, i16 %y, i16 %z) nounwind readnone { entry: ; CHECK-LABEL: xbar: ; CHECK: shldw $5 %0 = shl i16 %y, 5 %1 = lshr i16 %x, 11 %2 = or i16 %0, %1 ret i16 %2 } define i16 @xun(i16 %x, i16 %y, i16 %z) nounwind readnone { entry: ; CHECK-LABEL: xun: ; CHECK: rolw $11 %0 = lshr i16 %x, 5 %1 = shl i16 %x, 11 %2 = or i16 %0, %1 ret i16 %2 } define i16 @xbu(i16 %x, i16 %y, i16 %z) nounwind readnone { entry: ; CHECK-LABEL: xbu: ; CHECK: shldw $11 %0 = lshr i16 %y, 5 %1 = shl i16 %x, 11 %2 = or i16 %0, %1 ret i16 %2 }