[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / lib / Target / ARC / ARCISelLowering.h
blob4b72bfdaee9c4f4b98fe684a18aadf3e9a78416f
1 //===- ARCISelLowering.h - ARC DAG Lowering Interface -----------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This file defines the interfaces that ARC uses to lower LLVM code into a
10 // selection DAG.
12 //===----------------------------------------------------------------------===//
14 #ifndef LLVM_LIB_TARGET_ARC_ARCISELLOWERING_H
15 #define LLVM_LIB_TARGET_ARC_ARCISELLOWERING_H
17 #include "ARC.h"
18 #include "llvm/CodeGen/SelectionDAG.h"
19 #include "llvm/CodeGen/TargetLowering.h"
21 namespace llvm {
23 // Forward delcarations
24 class ARCSubtarget;
25 class ARCTargetMachine;
27 namespace ARCISD {
29 enum NodeType : unsigned {
30 // Start the numbering where the builtin ops and target ops leave off.
31 FIRST_NUMBER = ISD::BUILTIN_OP_END,
33 // Branch and link (call)
34 BL,
36 // Jump and link (indirect call)
37 JL,
39 // CMP
40 CMP,
42 // CMOV
43 CMOV,
45 // BRcc
46 BRcc,
48 // Global Address Wrapper
49 GAWRAPPER,
51 // return, (j_s [blink])
52 RET
55 } // end namespace ARCISD
57 //===--------------------------------------------------------------------===//
58 // TargetLowering Implementation
59 //===--------------------------------------------------------------------===//
60 class ARCTargetLowering : public TargetLowering {
61 public:
62 explicit ARCTargetLowering(const TargetMachine &TM,
63 const ARCSubtarget &Subtarget);
65 /// Provide custom lowering hooks for some operations.
66 SDValue LowerOperation(SDValue Op, SelectionDAG &DAG) const override;
68 /// This method returns the name of a target specific DAG node.
69 const char *getTargetNodeName(unsigned Opcode) const override;
71 /// Return true if the addressing mode represented by AM is legal for this
72 /// target, for a load/store of the specified type.
73 bool isLegalAddressingMode(const DataLayout &DL, const AddrMode &AM, Type *Ty,
74 unsigned AS,
75 Instruction *I = nullptr) const override;
77 private:
78 const ARCSubtarget &Subtarget;
80 // Lower Operand helpers
81 SDValue LowerCallArguments(SDValue Chain, CallingConv::ID CallConv,
82 bool isVarArg,
83 const SmallVectorImpl<ISD::InputArg> &Ins,
84 SDLoc dl, SelectionDAG &DAG,
85 SmallVectorImpl<SDValue> &InVals) const;
86 // Lower Operand specifics
87 SDValue LowerJumpTable(SDValue Op, SelectionDAG &DAG) const;
88 SDValue LowerFRAMEADDR(SDValue Op, SelectionDAG &DAG) const;
89 SDValue LowerSELECT_CC(SDValue Op, SelectionDAG &DAG) const;
90 SDValue LowerBR_CC(SDValue Op, SelectionDAG &DAG) const;
91 SDValue LowerSIGN_EXTEND_INREG(SDValue Op, SelectionDAG &DAG) const;
92 SDValue LowerGlobalAddress(SDValue Op, SelectionDAG &DAG) const;
93 SDValue PerformDAGCombine(SDNode *N, DAGCombinerInfo &DCI) const override;
95 SDValue LowerFormalArguments(SDValue Chain, CallingConv::ID CallConv,
96 bool isVarArg,
97 const SmallVectorImpl<ISD::InputArg> &Ins,
98 const SDLoc &dl, SelectionDAG &DAG,
99 SmallVectorImpl<SDValue> &InVals) const override;
101 SDValue LowerCall(TargetLowering::CallLoweringInfo &CLI,
102 SmallVectorImpl<SDValue> &InVals) const override;
104 SDValue LowerReturn(SDValue Chain, CallingConv::ID CallConv, bool isVarArg,
105 const SmallVectorImpl<ISD::OutputArg> &Outs,
106 const SmallVectorImpl<SDValue> &OutVals, const SDLoc &dl,
107 SelectionDAG &DAG) const override;
109 bool CanLowerReturn(CallingConv::ID CallConv, MachineFunction &MF,
110 bool isVarArg,
111 const SmallVectorImpl<ISD::OutputArg> &ArgsFlags,
112 LLVMContext &Context) const override;
114 bool mayBeEmittedAsTailCall(const CallInst *CI) const override;
117 } // end namespace llvm
119 #endif // LLVM_LIB_TARGET_ARC_ARCISELLOWERING_H