2016-01-13 01:01:16 +08:00
|
|
|
//===--- RDFDeadCode.h ----------------------------------------------------===//
|
|
|
|
//
|
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
|
2016-01-13 01:01:16 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// RDF-based generic dead code elimination.
|
|
|
|
//
|
|
|
|
// The main interface of this class are functions "collect" and "erase".
|
|
|
|
// This allows custom processing of the function being optimized by a
|
|
|
|
// particular consumer. The simplest way to use this class would be to
|
|
|
|
// instantiate an object, and then simply call "collect" and "erase",
|
|
|
|
// passing the result of "getDeadInstrs()" to it.
|
|
|
|
// A more complex scenario would be to call "collect" first, then visit
|
|
|
|
// all post-increment instructions to see if the address update is dead
|
|
|
|
// or not, and if it is, convert the instruction to a non-updating form.
|
|
|
|
// After that "erase" can be called with the set of nodes including both,
|
|
|
|
// dead defs from the updating instructions and the nodes corresponding
|
|
|
|
// to the dead instructions.
|
|
|
|
|
|
|
|
#ifndef RDF_DEADCODE_H
|
|
|
|
#define RDF_DEADCODE_H
|
|
|
|
|
2020-03-18 02:45:11 +08:00
|
|
|
#include "llvm/CodeGen/RDFGraph.h"
|
|
|
|
#include "llvm/CodeGen/RDFLiveness.h"
|
2016-01-13 01:01:16 +08:00
|
|
|
#include "llvm/ADT/SetVector.h"
|
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
class MachineRegisterInfo;
|
|
|
|
|
|
|
|
namespace rdf {
|
|
|
|
struct DeadCodeElimination {
|
|
|
|
DeadCodeElimination(DataFlowGraph &dfg, MachineRegisterInfo &mri)
|
|
|
|
: Trace(false), DFG(dfg), MRI(mri), LV(mri, dfg) {}
|
|
|
|
|
|
|
|
bool collect();
|
|
|
|
bool erase(const SetVector<NodeId> &Nodes);
|
|
|
|
void trace(bool On) { Trace = On; }
|
|
|
|
bool trace() const { return Trace; }
|
|
|
|
|
|
|
|
SetVector<NodeId> getDeadNodes() { return DeadNodes; }
|
|
|
|
SetVector<NodeId> getDeadInstrs() { return DeadInstrs; }
|
|
|
|
DataFlowGraph &getDFG() { return DFG; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool Trace;
|
|
|
|
SetVector<NodeId> LiveNodes;
|
|
|
|
SetVector<NodeId> DeadNodes;
|
|
|
|
SetVector<NodeId> DeadInstrs;
|
|
|
|
DataFlowGraph &DFG;
|
|
|
|
MachineRegisterInfo &MRI;
|
|
|
|
Liveness LV;
|
|
|
|
|
2016-01-19 04:42:47 +08:00
|
|
|
template<typename T> struct SetQueue;
|
|
|
|
|
2016-01-13 01:01:16 +08:00
|
|
|
bool isLiveInstr(const MachineInstr *MI) const;
|
2016-01-19 04:42:47 +08:00
|
|
|
void scanInstr(NodeAddr<InstrNode*> IA, SetQueue<NodeId> &WorkQ);
|
|
|
|
void processDef(NodeAddr<DefNode*> DA, SetQueue<NodeId> &WorkQ);
|
|
|
|
void processUse(NodeAddr<UseNode*> UA, SetQueue<NodeId> &WorkQ);
|
2016-01-13 01:01:16 +08:00
|
|
|
};
|
2016-05-27 18:06:40 +08:00
|
|
|
} // namespace rdf
|
|
|
|
} // namespace llvm
|
2016-01-13 01:01:16 +08:00
|
|
|
|
|
|
|
#endif
|