[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / lib / Target / ARC / ARCInstrInfo.h
blob1289b37c37b32ea478dfc342691c921bd3789a21
1 //===- ARCInstrInfo.h - ARC Instruction Information -------------*- 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 contains the ARC implementation of the TargetInstrInfo class.
11 //===----------------------------------------------------------------------===//
13 #ifndef LLVM_LIB_TARGET_ARC_ARCINSTRINFO_H
14 #define LLVM_LIB_TARGET_ARC_ARCINSTRINFO_H
16 #include "ARCRegisterInfo.h"
17 #include "llvm/CodeGen/TargetInstrInfo.h"
19 #define GET_INSTRINFO_HEADER
20 #include "ARCGenInstrInfo.inc"
22 namespace llvm {
24 class ARCSubtarget;
26 class ARCInstrInfo : public ARCGenInstrInfo {
27 const ARCRegisterInfo RI;
28 virtual void anchor();
30 public:
31 ARCInstrInfo();
33 const ARCRegisterInfo &getRegisterInfo() const { return RI; }
35 /// If the specified machine instruction is a direct
36 /// load from a stack slot, return the virtual or physical register number of
37 /// the destination along with the FrameIndex of the loaded stack slot. If
38 /// not, return 0. This predicate must return 0 if the instruction has
39 /// any side effects other than loading from the stack slot.
40 unsigned isLoadFromStackSlot(const MachineInstr &MI,
41 int &FrameIndex) const override;
43 /// If the specified machine instruction is a direct
44 /// store to a stack slot, return the virtual or physical register number of
45 /// the source reg along with the FrameIndex of the loaded stack slot. If
46 /// not, return 0. This predicate must return 0 if the instruction has
47 /// any side effects other than storing to the stack slot.
48 unsigned isStoreToStackSlot(const MachineInstr &MI,
49 int &FrameIndex) const override;
51 unsigned getInstSizeInBytes(const MachineInstr &MI) const override;
53 bool analyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB,
54 MachineBasicBlock *&FBB,
55 SmallVectorImpl<MachineOperand> &Cond,
56 bool AllowModify) const override;
58 unsigned insertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB,
59 MachineBasicBlock *FBB, ArrayRef<MachineOperand> Cond,
60 const DebugLoc &dl,
61 int *BytesAdded = nullptr) const override;
63 unsigned removeBranch(MachineBasicBlock &MBB,
64 int *BytesRemoved = nullptr) const override;
66 void copyPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator I,
67 const DebugLoc &dl, unsigned DestReg, unsigned SrcReg,
68 bool KillSrc) const override;
70 void storeRegToStackSlot(MachineBasicBlock &MBB,
71 MachineBasicBlock::iterator MI, unsigned SrcReg,
72 bool isKill, int FrameIndex,
73 const TargetRegisterClass *RC,
74 const TargetRegisterInfo *TRI) const override;
76 void loadRegFromStackSlot(MachineBasicBlock &MBB,
77 MachineBasicBlock::iterator MI, unsigned DestReg,
78 int FrameIndex, const TargetRegisterClass *RC,
79 const TargetRegisterInfo *TRI) const override;
81 bool
82 reverseBranchCondition(SmallVectorImpl<MachineOperand> &Cond) const override;
85 bool isPostIncrement(const MachineInstr &MI) const override;
87 // ARC-specific
88 bool isPreIncrement(const MachineInstr &MI) const;
90 virtual bool getBaseAndOffsetPosition(const MachineInstr &MI,
91 unsigned &BasePos,
92 unsigned &OffsetPos) const override;
94 // Emit code before MBBI to load immediate value into physical register Reg.
95 // Returns an iterator to the new instruction.
96 MachineBasicBlock::iterator loadImmediate(MachineBasicBlock &MBB,
97 MachineBasicBlock::iterator MI,
98 unsigned Reg, uint64_t Value) const;
101 } // end namespace llvm
103 #endif // LLVM_LIB_TARGET_ARC_ARCINSTRINFO_H