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