2017-09-30 05:55:49 +08:00
|
|
|
//===- llvm/CodeGen/CriticalAntiDepBreaker.h - Anti-Dep Support -*- C++ -*-===//
|
2009-10-27 00:59:04 +08:00
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2009-10-27 00:59:04 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file implements the CriticalAntiDepBreaker class, which
|
|
|
|
// implements register anti-dependence breaking along a blocks
|
|
|
|
// critical path during post-RA scheduler.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2014-08-14 00:26:38 +08:00
|
|
|
#ifndef LLVM_LIB_CODEGEN_CRITICALANTIDEPBREAKER_H
|
|
|
|
#define LLVM_LIB_CODEGEN_CRITICALANTIDEPBREAKER_H
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2009-10-29 02:29:54 +08:00
|
|
|
#include "AntiDepBreaker.h"
|
2012-12-04 15:12:27 +08:00
|
|
|
#include "llvm/ADT/BitVector.h"
|
2017-09-30 05:55:49 +08:00
|
|
|
#include "llvm/Support/Compiler.h"
|
|
|
|
#include <map>
|
|
|
|
#include <vector>
|
2009-10-27 00:59:04 +08:00
|
|
|
|
|
|
|
namespace llvm {
|
2017-09-30 05:55:49 +08:00
|
|
|
|
|
|
|
class MachineBasicBlock;
|
|
|
|
class MachineFunction;
|
|
|
|
class MachineInstr;
|
|
|
|
class MachineOperand;
|
|
|
|
class MachineRegisterInfo;
|
2011-06-17 05:56:21 +08:00
|
|
|
class RegisterClassInfo;
|
2010-06-16 15:35:02 +08:00
|
|
|
class TargetInstrInfo;
|
2017-09-30 05:55:49 +08:00
|
|
|
class TargetRegisterClass;
|
2010-06-16 15:35:02 +08:00
|
|
|
class TargetRegisterInfo;
|
|
|
|
|
2015-07-01 22:47:39 +08:00
|
|
|
class LLVM_LIBRARY_VISIBILITY CriticalAntiDepBreaker : public AntiDepBreaker {
|
2009-10-27 00:59:04 +08:00
|
|
|
MachineFunction& MF;
|
|
|
|
MachineRegisterInfo &MRI;
|
2010-06-16 15:35:02 +08:00
|
|
|
const TargetInstrInfo *TII;
|
2009-10-27 00:59:04 +08:00
|
|
|
const TargetRegisterInfo *TRI;
|
2011-06-17 05:56:21 +08:00
|
|
|
const RegisterClassInfo &RegClassInfo;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// The set of allocatable registers.
|
2009-10-27 00:59:04 +08:00
|
|
|
/// We'll be ignoring anti-dependencies on non-allocatable registers,
|
|
|
|
/// because they may not be safe to break.
|
|
|
|
const BitVector AllocatableSet;
|
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// For live regs that are only used in one register class in a
|
2009-10-27 00:59:04 +08:00
|
|
|
/// live range, the register class. If the register is not live, the
|
|
|
|
/// corresponding value is null. If the register is live but used in
|
|
|
|
/// multiple register classes, the corresponding value is -1 casted to a
|
|
|
|
/// pointer.
|
2017-09-30 05:55:49 +08:00
|
|
|
std::vector<const TargetRegisterClass *> Classes;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// Map registers to all their references within a live range.
|
2009-10-27 00:59:04 +08:00
|
|
|
std::multimap<unsigned, MachineOperand *> RegRefs;
|
2017-09-30 05:55:49 +08:00
|
|
|
|
|
|
|
using RegRefIter =
|
|
|
|
std::multimap<unsigned, MachineOperand *>::const_iterator;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// The index of the most recent kill (proceeding bottom-up),
|
2009-10-27 00:59:04 +08:00
|
|
|
/// or ~0u if the register is not live.
|
2010-07-16 03:58:14 +08:00
|
|
|
std::vector<unsigned> KillIndices;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// The index of the most recent complete def (proceeding
|
2014-06-25 05:11:51 +08:00
|
|
|
/// bottom up), or ~0u if the register is live.
|
2010-07-16 03:58:14 +08:00
|
|
|
std::vector<unsigned> DefIndices;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// A set of registers which are live and cannot be changed to
|
2009-10-27 00:59:04 +08:00
|
|
|
/// break anti-dependencies.
|
2012-03-18 04:22:57 +08:00
|
|
|
BitVector KeepRegs;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
|
|
|
public:
|
2017-09-30 05:55:49 +08:00
|
|
|
CriticalAntiDepBreaker(MachineFunction& MFi, const RegisterClassInfo &RCI);
|
2015-04-11 10:11:45 +08:00
|
|
|
~CriticalAntiDepBreaker() override;
|
2010-01-07 00:48:02 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// Initialize anti-dep breaking for a new basic block.
|
2014-03-07 17:26:03 +08:00
|
|
|
void StartBlock(MachineBasicBlock *BB) override;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// Identifiy anti-dependencies along the critical path
|
2009-10-27 00:59:04 +08:00
|
|
|
/// of the ScheduleDAG and break them by renaming registers.
|
2017-09-30 05:55:49 +08:00
|
|
|
unsigned BreakAntiDependencies(const std::vector<SUnit> &SUnits,
|
2010-04-20 07:11:58 +08:00
|
|
|
MachineBasicBlock::iterator Begin,
|
|
|
|
MachineBasicBlock::iterator End,
|
2011-06-03 05:26:52 +08:00
|
|
|
unsigned InsertPosIndex,
|
2014-03-07 17:26:03 +08:00
|
|
|
DbgValueVector &DbgValues) override;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// Update liveness information to account for the current
|
2009-10-27 00:59:04 +08:00
|
|
|
/// instruction, which will not be scheduled.
|
2016-02-28 03:33:37 +08:00
|
|
|
void Observe(MachineInstr &MI, unsigned Count,
|
2014-03-07 17:26:03 +08:00
|
|
|
unsigned InsertPosIndex) override;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
2014-09-21 22:48:16 +08:00
|
|
|
/// Finish anti-dep breaking for a basic block.
|
2014-03-07 17:26:03 +08:00
|
|
|
void FinishBlock() override;
|
2009-10-27 00:59:04 +08:00
|
|
|
|
|
|
|
private:
|
2016-02-28 03:33:37 +08:00
|
|
|
void PrescanInstruction(MachineInstr &MI);
|
|
|
|
void ScanInstruction(MachineInstr &MI, unsigned Count);
|
2011-02-09 01:39:46 +08:00
|
|
|
bool isNewRegClobberedByRefs(RegRefIter RegRefBegin,
|
|
|
|
RegRefIter RegRefEnd,
|
|
|
|
unsigned NewReg);
|
2010-11-03 02:16:45 +08:00
|
|
|
unsigned findSuitableFreeRegister(RegRefIter RegRefBegin,
|
|
|
|
RegRefIter RegRefEnd,
|
2010-01-07 06:21:25 +08:00
|
|
|
unsigned AntiDepReg,
|
2009-10-27 00:59:04 +08:00
|
|
|
unsigned LastNewReg,
|
This patch addresses bug 15031.
The common code in the post-RA scheduler to break anti-dependencies on the
critical path contained a flaw. In the reported case, an anti-dependency
between the overlapping registers %X4 and %R4 exists:
%X29<def> = OR8 %X4, %X4
%R4<def>, %X3<def,dead,tied3> = LBZU 1, %X3<kill,tied1>
The unpatched code breaks the dependency by replacing %R4 and its uses
with %R3, the first register on the available list. However, %R3 and
%X3 overlap, so this creates two overlapping definitions on the same
instruction.
The fix is straightforward, preventing selection of a register that
overlaps any other defined register on the same instruction.
The test case is reduced from the bug report, and verifies that we no
longer produce "lbzu 3, 1(3)" when breaking this anti-dependency.
llvm-svn: 173706
2013-01-29 02:36:58 +08:00
|
|
|
const TargetRegisterClass *RC,
|
2013-07-03 13:16:59 +08:00
|
|
|
SmallVectorImpl<unsigned> &Forbid);
|
2009-10-27 00:59:04 +08:00
|
|
|
};
|
|
|
|
|
2017-09-30 05:55:49 +08:00
|
|
|
} // end namespace llvm
|
|
|
|
|
|
|
|
#endif // LLVM_LIB_CODEGEN_CRITICALANTIDEPBREAKER_H
|