diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2020-01-17 20:45:01 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2020-01-17 20:45:01 +0000 | 
| commit | 706b4fc47bbc608932d3b491ae19a3b9cde9497b (patch) | |
| tree | 4adf86a776049cbf7f69a1929c4babcbbef925eb /llvm/lib/CodeGen/MacroFusion.cpp | |
| parent | 7cc9cf2bf09f069cb2dd947ead05d0b54301fb71 (diff) | |
Notes
Diffstat (limited to 'llvm/lib/CodeGen/MacroFusion.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/MacroFusion.cpp | 27 | 
1 files changed, 26 insertions, 1 deletions
| diff --git a/llvm/lib/CodeGen/MacroFusion.cpp b/llvm/lib/CodeGen/MacroFusion.cpp index d21eae222af0..d2ee21c8720f 100644 --- a/llvm/lib/CodeGen/MacroFusion.cpp +++ b/llvm/lib/CodeGen/MacroFusion.cpp @@ -36,6 +36,21 @@ static bool isHazard(const SDep &Dep) {    return Dep.getKind() == SDep::Anti || Dep.getKind() == SDep::Output;  } +static SUnit *getPredClusterSU(const SUnit &SU) { +  for (const SDep &SI : SU.Preds) +    if (SI.isCluster()) +      return SI.getSUnit(); + +  return nullptr; +} + +static bool hasLessThanNumFused(const SUnit &SU, unsigned FuseLimit) { +  unsigned Num = 1; +  const SUnit *CurrentSU = &SU; +  while ((CurrentSU = getPredClusterSU(*CurrentSU)) && Num < FuseLimit) Num ++; +  return Num < FuseLimit; +} +  static bool fuseInstructionPair(ScheduleDAGInstrs &DAG, SUnit &FirstSU,                                  SUnit &SecondSU) {    // Check that neither instr is already paired with another along the edge @@ -56,6 +71,14 @@ static bool fuseInstructionPair(ScheduleDAGInstrs &DAG, SUnit &FirstSU,    if (!DAG.addEdge(&SecondSU, SDep(&FirstSU, SDep::Cluster)))      return false; +  // TODO - If we want to chain more than two instructions, we need to create +  // artifical edges to make dependencies from the FirstSU also dependent +  // on other chained instructions, and other chained instructions also +  // dependent on the dependencies of the SecondSU, to prevent them from being +  // scheduled into these chained instructions. +  assert(hasLessThanNumFused(FirstSU, 2) && +         "Currently we only support chaining together two instructions"); +    // Adjust the latency between both instrs.    for (SDep &SI : FirstSU.Succs)      if (SI.getSUnit() == &SecondSU) @@ -161,8 +184,10 @@ bool MacroFusion::scheduleAdjacentImpl(ScheduleDAGInstrs &DAG, SUnit &AnchorSU)      if (DepSU.isBoundaryNode())        continue; +    // Only chain two instructions together at most.      const MachineInstr *DepMI = DepSU.getInstr(); -    if (!shouldScheduleAdjacent(TII, ST, DepMI, AnchorMI)) +    if (!hasLessThanNumFused(DepSU, 2) || +        !shouldScheduleAdjacent(TII, ST, DepMI, AnchorMI))        continue;      if (fuseInstructionPair(DAG, DepSU, AnchorSU)) | 
