| //===- MultiHazardRecognizer.cpp - Scheduler Support ----------------------===// | 
 | // | 
 | // 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 | 
 | // | 
 | //===----------------------------------------------------------------------===// | 
 | // | 
 | // This file implements the MultiHazardRecognizer class, which is a wrapper | 
 | // for a set of ScheduleHazardRecognizer instances | 
 | // | 
 | //===----------------------------------------------------------------------===// | 
 |  | 
 | #include "llvm/CodeGen/MultiHazardRecognizer.h" | 
 | #include "llvm/ADT/STLExtras.h" | 
 | #include <algorithm> | 
 | #include <functional> | 
 | #include <numeric> | 
 |  | 
 | using namespace llvm; | 
 |  | 
 | void MultiHazardRecognizer::AddHazardRecognizer( | 
 |     std::unique_ptr<ScheduleHazardRecognizer> &&R) { | 
 |   MaxLookAhead = std::max(MaxLookAhead, R->getMaxLookAhead()); | 
 |   Recognizers.push_back(std::move(R)); | 
 | } | 
 |  | 
 | bool MultiHazardRecognizer::atIssueLimit() const { | 
 |   return llvm::any_of(Recognizers, | 
 |                       std::mem_fn(&ScheduleHazardRecognizer::atIssueLimit)); | 
 | } | 
 |  | 
 | ScheduleHazardRecognizer::HazardType | 
 | MultiHazardRecognizer::getHazardType(SUnit *SU, int Stalls) { | 
 |   for (auto &R : Recognizers) { | 
 |     auto res = R->getHazardType(SU, Stalls); | 
 |     if (res != NoHazard) | 
 |       return res; | 
 |   } | 
 |   return NoHazard; | 
 | } | 
 |  | 
 | void MultiHazardRecognizer::Reset() { | 
 |   for (auto &R : Recognizers) | 
 |     R->Reset(); | 
 | } | 
 |  | 
 | void MultiHazardRecognizer::EmitInstruction(SUnit *SU) { | 
 |   for (auto &R : Recognizers) | 
 |     R->EmitInstruction(SU); | 
 | } | 
 |  | 
 | void MultiHazardRecognizer::EmitInstruction(MachineInstr *MI) { | 
 |   for (auto &R : Recognizers) | 
 |     R->EmitInstruction(MI); | 
 | } | 
 |  | 
 | unsigned MultiHazardRecognizer::PreEmitNoops(SUnit *SU) { | 
 |   auto MN = [=](unsigned a, std::unique_ptr<ScheduleHazardRecognizer> &R) { | 
 |     return std::max(a, R->PreEmitNoops(SU)); | 
 |   }; | 
 |   return std::accumulate(Recognizers.begin(), Recognizers.end(), 0u, MN); | 
 | } | 
 |  | 
 | unsigned MultiHazardRecognizer::PreEmitNoops(MachineInstr *MI) { | 
 |   auto MN = [=](unsigned a, std::unique_ptr<ScheduleHazardRecognizer> &R) { | 
 |     return std::max(a, R->PreEmitNoops(MI)); | 
 |   }; | 
 |   return std::accumulate(Recognizers.begin(), Recognizers.end(), 0u, MN); | 
 | } | 
 |  | 
 | bool MultiHazardRecognizer::ShouldPreferAnother(SUnit *SU) { | 
 |   auto SPA = [=](std::unique_ptr<ScheduleHazardRecognizer> &R) { | 
 |     return R->ShouldPreferAnother(SU); | 
 |   }; | 
 |   return llvm::any_of(Recognizers, SPA); | 
 | } | 
 |  | 
 | void MultiHazardRecognizer::AdvanceCycle() { | 
 |   for (auto &R : Recognizers) | 
 |     R->AdvanceCycle(); | 
 | } | 
 |  | 
 | void MultiHazardRecognizer::RecedeCycle() { | 
 |   for (auto &R : Recognizers) | 
 |     R->RecedeCycle(); | 
 | } | 
 |  | 
 | void MultiHazardRecognizer::EmitNoop() { | 
 |   for (auto &R : Recognizers) | 
 |     R->EmitNoop(); | 
 | } |