You've already forked linux-packaging-mono
Imported Upstream version 5.18.0.167
Former-commit-id: 289509151e0fee68a1b591a20c9f109c3c789d3a
This commit is contained in:
parent
e19d552987
commit
b084638f15
@ -1,77 +0,0 @@
|
||||
//===- HexagonBitTracker.h --------------------------------------*- C++ -*-===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#ifndef LLVM_LIB_TARGET_HEXAGON_HEXAGONBITTRACKER_H
|
||||
#define LLVM_LIB_TARGET_HEXAGON_HEXAGONBITTRACKER_H
|
||||
|
||||
#include "BitTracker.h"
|
||||
#include "llvm/ADT/DenseMap.h"
|
||||
#include <cstdint>
|
||||
|
||||
namespace llvm {
|
||||
|
||||
class HexagonInstrInfo;
|
||||
class HexagonRegisterInfo;
|
||||
class MachineFrameInfo;
|
||||
class MachineFunction;
|
||||
class MachineInstr;
|
||||
class MachineRegisterInfo;
|
||||
|
||||
struct HexagonEvaluator : public BitTracker::MachineEvaluator {
|
||||
using CellMapType = BitTracker::CellMapType;
|
||||
using RegisterRef = BitTracker::RegisterRef;
|
||||
using RegisterCell = BitTracker::RegisterCell;
|
||||
using BranchTargetList = BitTracker::BranchTargetList;
|
||||
|
||||
HexagonEvaluator(const HexagonRegisterInfo &tri, MachineRegisterInfo &mri,
|
||||
const HexagonInstrInfo &tii, MachineFunction &mf);
|
||||
|
||||
bool evaluate(const MachineInstr &MI, const CellMapType &Inputs,
|
||||
CellMapType &Outputs) const override;
|
||||
bool evaluate(const MachineInstr &BI, const CellMapType &Inputs,
|
||||
BranchTargetList &Targets, bool &FallsThru) const override;
|
||||
|
||||
BitTracker::BitMask mask(unsigned Reg, unsigned Sub) const override;
|
||||
|
||||
uint16_t getPhysRegBitWidth(unsigned Reg) const override;
|
||||
|
||||
const TargetRegisterClass &composeWithSubRegIndex(
|
||||
const TargetRegisterClass &RC, unsigned Idx) const override;
|
||||
|
||||
MachineFunction &MF;
|
||||
MachineFrameInfo &MFI;
|
||||
const HexagonInstrInfo &TII;
|
||||
|
||||
private:
|
||||
bool evaluateLoad(const MachineInstr &MI, const CellMapType &Inputs,
|
||||
CellMapType &Outputs) const;
|
||||
bool evaluateFormalCopy(const MachineInstr &MI, const CellMapType &Inputs,
|
||||
CellMapType &Outputs) const;
|
||||
|
||||
unsigned getNextPhysReg(unsigned PReg, unsigned Width) const;
|
||||
unsigned getVirtRegFor(unsigned PReg) const;
|
||||
|
||||
// Type of formal parameter extension.
|
||||
struct ExtType {
|
||||
enum { SExt, ZExt };
|
||||
|
||||
ExtType() = default;
|
||||
ExtType(char t, uint16_t w) : Type(t), Width(w) {}
|
||||
|
||||
char Type = 0;
|
||||
uint16_t Width = 0;
|
||||
};
|
||||
// Map VR -> extension type.
|
||||
using RegExtMap = DenseMap<unsigned, ExtType>;
|
||||
RegExtMap VRX;
|
||||
};
|
||||
|
||||
} // end namespace llvm
|
||||
|
||||
#endif // LLVM_LIB_TARGET_HEXAGON_HEXAGONBITTRACKER_H
|
Reference in New Issue
Block a user