| //===-- 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 = 0; |
| 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; |
| } |
| } |
| } |