From f9e291a2f655c0859bf64c2d700266f864c0e6b5 Mon Sep 17 00:00:00 2001 From: Dylan McKay Date: Sun, 24 Sep 2017 01:07:26 +0000 Subject: [PATCH] [AVR] Implement getCmpLibcallReturnType(). This fixes the avr-rust issue (#75) with floating-point comparisons generating broken code. By default, LLVM assumes these comparisons return 32-bit values, but ours are 8-bit. Patch By Thomas Backman. llvm-svn: 314070 --- llvm/lib/Target/AVR/AVRISelLowering.h | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/llvm/lib/Target/AVR/AVRISelLowering.h b/llvm/lib/Target/AVR/AVRISelLowering.h index 37e01dc950f5..c13a8b3bc8cf 100644 --- a/llvm/lib/Target/AVR/AVRISelLowering.h +++ b/llvm/lib/Target/AVR/AVRISelLowering.h @@ -75,6 +75,11 @@ public: MVT getScalarShiftAmountTy(const DataLayout &, EVT LHSTy) const override { return MVT::i8; } + + MVT::SimpleValueType getCmpLibcallReturnType() const override { + return MVT::i8; + } + const char *getTargetNodeName(unsigned Opcode) const override; SDValue LowerOperation(SDValue Op, SelectionDAG &DAG) const override;