diff options
| author | Michael Liao <michael.liao@intel.com> | 2013-03-01 18:40:30 +0000 |
|---|---|---|
| committer | Michael Liao <michael.liao@intel.com> | 2013-03-01 18:40:30 +0000 |
| commit | 6af16fc3b7d0355ca43b838ef79faaa63c44b6b5 (patch) | |
| tree | 4ba86621fb61c4e2323158ec1261600f9cd91344 /llvm/lib/Target/Mips | |
| parent | 9660343b423ecce2cac5b125f87d145bb3cd12b4 (diff) | |
| download | bcm5719-llvm-6af16fc3b7d0355ca43b838ef79faaa63c44b6b5.tar.gz bcm5719-llvm-6af16fc3b7d0355ca43b838ef79faaa63c44b6b5.zip | |
Fix PR10475
- ISD::SHL/SRL/SRA must have either both scalar or both vector operands
but TLI.getShiftAmountTy() so far only return scalar type. As a
result, backend logic assuming that breaks.
- Rename the original TLI.getShiftAmountTy() to
TLI.getScalarShiftAmountTy() and re-define TLI.getShiftAmountTy() to
return target-specificed scalar type or the same vector type as the
1st operand.
- Fix most TICG logic assuming TLI.getShiftAmountTy() a simple scalar
type.
llvm-svn: 176364
Diffstat (limited to 'llvm/lib/Target/Mips')
| -rw-r--r-- | llvm/lib/Target/Mips/MipsISelLowering.h | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/lib/Target/Mips/MipsISelLowering.h b/llvm/lib/Target/Mips/MipsISelLowering.h index f0f37824cb4..5b2ef08b7b5 100644 --- a/llvm/lib/Target/Mips/MipsISelLowering.h +++ b/llvm/lib/Target/Mips/MipsISelLowering.h @@ -151,7 +151,7 @@ namespace llvm { public: explicit MipsTargetLowering(MipsTargetMachine &TM); - virtual MVT getShiftAmountTy(EVT LHSTy) const { return MVT::i32; } + virtual MVT getScalarShiftAmountTy(EVT LHSTy) const { return MVT::i32; } virtual bool allowsUnalignedMemoryAccesses (EVT VT, bool *Fast) const; |

