mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 19:23:23 +01:00
75f0f1cc6c
llvm-svn: 74931
80 lines
2.4 KiB
C++
80 lines
2.4 KiB
C++
//===--- Plugin.cpp - The LLVM Compiler Driver ------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open
|
|
// Source License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Plugin support.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/CompilerDriver/Plugin.h"
|
|
#include "llvm/Support/ManagedStatic.h"
|
|
#include "llvm/System/Mutex.h"
|
|
#include <algorithm>
|
|
#include <vector>
|
|
|
|
namespace {
|
|
|
|
// Registry::Add<> does not do lifetime management (probably issues
|
|
// with static constructor/destructor ordering), so we have to
|
|
// implement it here.
|
|
//
|
|
// All this static registration/life-before-main model seems
|
|
// unnecessary convoluted to me.
|
|
|
|
static bool pluginListInitialized = false;
|
|
typedef std::vector<const llvmc::BasePlugin*> PluginList;
|
|
static PluginList Plugins;
|
|
static llvm::ManagedStatic<llvm::sys::SmartMutex<true> > PluginMutex;
|
|
|
|
struct ByPriority {
|
|
bool operator()(const llvmc::BasePlugin* lhs,
|
|
const llvmc::BasePlugin* rhs) {
|
|
return lhs->Priority() < rhs->Priority();
|
|
}
|
|
};
|
|
}
|
|
|
|
namespace llvmc {
|
|
|
|
PluginLoader::PluginLoader() {
|
|
llvm::sys::SmartScopedLock<true> Lock(*PluginMutex);
|
|
if (!pluginListInitialized) {
|
|
for (PluginRegistry::iterator B = PluginRegistry::begin(),
|
|
E = PluginRegistry::end(); B != E; ++B)
|
|
Plugins.push_back(B->instantiate());
|
|
std::sort(Plugins.begin(), Plugins.end(), ByPriority());
|
|
}
|
|
pluginListInitialized = true;
|
|
}
|
|
|
|
PluginLoader::~PluginLoader() {
|
|
llvm::sys::SmartScopedLock<true> Lock(*PluginMutex);
|
|
if (pluginListInitialized) {
|
|
for (PluginList::iterator B = Plugins.begin(), E = Plugins.end();
|
|
B != E; ++B)
|
|
delete (*B);
|
|
}
|
|
pluginListInitialized = false;
|
|
}
|
|
|
|
void PluginLoader::PopulateLanguageMap(LanguageMap& langMap) {
|
|
llvm::sys::SmartScopedLock<true> Lock(*PluginMutex);
|
|
for (PluginList::iterator B = Plugins.begin(), E = Plugins.end();
|
|
B != E; ++B)
|
|
(*B)->PopulateLanguageMap(langMap);
|
|
}
|
|
|
|
void PluginLoader::PopulateCompilationGraph(CompilationGraph& graph) {
|
|
llvm::sys::SmartScopedLock<true> Lock(*PluginMutex);
|
|
for (PluginList::iterator B = Plugins.begin(), E = Plugins.end();
|
|
B != E; ++B)
|
|
(*B)->PopulateCompilationGraph(graph);
|
|
}
|
|
|
|
}
|