forked from OSchip/llvm-project
Mark rotl/rotr as expand. This generates pretty ugly code, but this is better than nothing.
llvm-svn: 71976
This commit is contained in:
parent
6b5523aec2
commit
6de08cd093
|
@ -73,6 +73,10 @@ MSP430TargetLowering::MSP430TargetLowering(MSP430TargetMachine &tm) :
|
|||
setOperationAction(ISD::SRA, MVT::i16, Custom);
|
||||
setOperationAction(ISD::SHL, MVT::i16, Custom);
|
||||
setOperationAction(ISD::SRL, MVT::i16, Custom);
|
||||
setOperationAction(ISD::ROTL, MVT::i8, Expand);
|
||||
setOperationAction(ISD::ROTR, MVT::i8, Expand);
|
||||
setOperationAction(ISD::ROTL, MVT::i16, Expand);
|
||||
setOperationAction(ISD::ROTR, MVT::i16, Expand);
|
||||
setOperationAction(ISD::RET, MVT::Other, Custom);
|
||||
setOperationAction(ISD::GlobalAddress, MVT::i16, Custom);
|
||||
setOperationAction(ISD::ExternalSymbol, MVT::i16, Custom);
|
||||
|
|
|
@ -0,0 +1,17 @@
|
|||
; RUN: llvm-as < %s | llc -march=msp430
|
||||
|
||||
define i16 @rol1u16(i16 %x.arg) nounwind {
|
||||
%retval = alloca i16
|
||||
%x = alloca i16
|
||||
store i16 %x.arg, i16* %x
|
||||
%1 = load i16* %x
|
||||
%2 = shl i16 %1, 1
|
||||
%3 = load i16* %x
|
||||
%4 = lshr i16 %3, 15
|
||||
%5 = or i16 %2, %4
|
||||
store i16 %5, i16* %retval
|
||||
br label %return
|
||||
return:
|
||||
%6 = load i16* %retval
|
||||
ret i16 %6
|
||||
}
|
Loading…
Reference in New Issue