1 //===------ llvm/MC/MCInstrDesc.cpp- Instruction Descriptors --------------===//
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
7 //===----------------------------------------------------------------------===//
9 // This file defines methods on the MCOperandInfo and MCInstrDesc classes, which
10 // are used to describe target instructions and their operands.
12 //===----------------------------------------------------------------------===//
14 #include "llvm/MC/MCInstrDesc.h"
15 #include "llvm/MC/MCInst.h"
16 #include "llvm/MC/MCRegisterInfo.h"
17 #include "llvm/MC/MCSubtargetInfo.h"
21 bool MCInstrDesc::mayAffectControlFlow(const MCInst
&MI
,
22 const MCRegisterInfo
&RI
) const {
23 if (isBranch() || isCall() || isReturn() || isIndirectBranch())
25 unsigned PC
= RI
.getProgramCounter();
28 if (hasDefOfPhysReg(MI
, PC
, RI
))
33 bool MCInstrDesc::hasImplicitDefOfPhysReg(unsigned Reg
,
34 const MCRegisterInfo
*MRI
) const {
35 if (const MCPhysReg
*ImpDefs
= ImplicitDefs
)
36 for (; *ImpDefs
; ++ImpDefs
)
37 if (*ImpDefs
== Reg
|| (MRI
&& MRI
->isSubRegister(Reg
, *ImpDefs
)))
42 bool MCInstrDesc::hasDefOfPhysReg(const MCInst
&MI
, unsigned Reg
,
43 const MCRegisterInfo
&RI
) const {
44 for (int i
= 0, e
= NumDefs
; i
!= e
; ++i
)
45 if (MI
.getOperand(i
).isReg() &&
46 RI
.isSubRegisterEq(Reg
, MI
.getOperand(i
).getReg()))
48 if (variadicOpsAreDefs())
49 for (int i
= NumOperands
- 1, e
= MI
.getNumOperands(); i
!= e
; ++i
)
50 if (MI
.getOperand(i
).isReg() &&
51 RI
.isSubRegisterEq(Reg
, MI
.getOperand(i
).getReg()))
53 return hasImplicitDefOfPhysReg(Reg
, &RI
);