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"
20 bool MCInstrDesc::mayAffectControlFlow(const MCInst
&MI
,
21 const MCRegisterInfo
&RI
) const {
22 if (isBranch() || isCall() || isReturn() || isIndirectBranch())
24 MCRegister PC
= RI
.getProgramCounter();
27 if (hasDefOfPhysReg(MI
, PC
, RI
))
32 bool MCInstrDesc::hasImplicitDefOfPhysReg(MCRegister Reg
,
33 const MCRegisterInfo
*MRI
) const {
34 for (MCPhysReg ImpDef
: implicit_defs())
35 if (ImpDef
== Reg
|| (MRI
&& MRI
->isSubRegister(Reg
, ImpDef
)))
40 bool MCInstrDesc::hasDefOfPhysReg(const MCInst
&MI
, MCRegister Reg
,
41 const MCRegisterInfo
&RI
) const {
42 for (int i
= 0, e
= NumDefs
; i
!= e
; ++i
)
43 if (MI
.getOperand(i
).isReg() && MI
.getOperand(i
).getReg() &&
44 RI
.isSubRegisterEq(Reg
, MI
.getOperand(i
).getReg()))
46 if (variadicOpsAreDefs())
47 for (int i
= NumOperands
- 1, e
= MI
.getNumOperands(); i
!= e
; ++i
)
48 if (MI
.getOperand(i
).isReg() &&
49 RI
.isSubRegisterEq(Reg
, MI
.getOperand(i
).getReg()))
51 return hasImplicitDefOfPhysReg(Reg
, &RI
);