![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /usr/lib/llvm-6.0/build/Release/include/llvm/CodeGen/GlobalISel/ |
Upload File : |
//===- GISelWorkList.h - Worklist for GISel passes ----*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef LLVM_GISEL_WORKLIST_H #define LLVM_GISEL_WORKLIST_H #include "llvm/ADT/DenseMap.h" #include "llvm/ADT/SmallVector.h" #include "llvm/Support/Debug.h" namespace llvm { class MachineInstr; // Worklist which mostly works similar to InstCombineWorkList, but on MachineInstrs. // The main difference with something like a SetVector is that erasing an element doesn't // move all elements over one place - instead just nulls out the element of the vector. // FIXME: Does it make sense to factor out common code with the instcombinerWorkList? template<unsigned N> class GISelWorkList { SmallVector<MachineInstr*, N> Worklist; DenseMap<MachineInstr*, unsigned> WorklistMap; public: GISelWorkList() = default; bool empty() const { return WorklistMap.empty(); } unsigned size() const { return WorklistMap.size(); } /// Add - Add the specified instruction to the worklist if it isn't already /// in it. void insert(MachineInstr *I) { if (WorklistMap.try_emplace(I, Worklist.size()).second) { Worklist.push_back(I); } } /// Remove - remove I from the worklist if it exists. void remove(MachineInstr *I) { auto It = WorklistMap.find(I); if (It == WorklistMap.end()) return; // Not in worklist. // Don't bother moving everything down, just null out the slot. Worklist[It->second] = nullptr; WorklistMap.erase(It); } MachineInstr *pop_back_val() { MachineInstr *I; do { I = Worklist.pop_back_val(); } while(!I); assert(I && "Pop back on empty worklist"); WorklistMap.erase(I); return I; } }; } // end namespace llvm. #endif