//===-- CodeGen/MachineInstr.cpp ------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file contains the machine function pass registry for register allocators // and instruction schedulers. // //===----------------------------------------------------------------------===// #include "llvm/CodeGen/MachinePassRegistry.h" using namespace llvm; void MachinePassRegistryListener::anchor() { } /// setDefault - Set the default constructor by name. void MachinePassRegistry::setDefault(StringRef Name) { MachinePassCtor Ctor = nullptr; for(MachinePassRegistryNode *R = getList(); R; R = R->getNext()) { if (R->getName() == Name) { Ctor = R->getCtor(); break; } } assert(Ctor && "Unregistered pass name"); setDefault(Ctor); } /// Add - Adds a function pass to the registration list. /// void MachinePassRegistry::Add(MachinePassRegistryNode *Node) { Node->setNext(List); List = Node; if (Listener) Listener->NotifyAdd(Node->getName(), Node->getCtor(), Node->getDescription()); } /// Remove - Removes a function pass from the registration list. /// void MachinePassRegistry::Remove(MachinePassRegistryNode *Node) { for (MachinePassRegistryNode **I = &List; *I; I = (*I)->getNextAddress()) { if (*I == Node) { if (Listener) Listener->NotifyRemove(Node->getName()); *I = (*I)->getNext(); break; } } }