mirror of
https://github.com/intel/llvm.git
synced 2026-01-14 03:50:17 +08:00
This is a pretty straightforward first pass over removing a number of uses of Mutex in favor of std::mutex or std::recursive_mutex. The problem is that there are interfaces which take Mutex::Locker & to lock internal locks. This patch cleans up most of the easy cases. The only non-trivial change is in CommandObjectTarget.cpp where a Mutex::Locker was split into two. llvm-svn: 269877
77 lines
2.0 KiB
C++
77 lines
2.0 KiB
C++
//===-- JITLoader.cpp -------------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/lldb-private.h"
|
|
#include "lldb/Target/JITLoader.h"
|
|
#include "lldb/Target/JITLoaderList.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
JITLoaderList::JITLoaderList() : m_jit_loaders_vec(), m_jit_loaders_mutex()
|
|
{
|
|
}
|
|
|
|
JITLoaderList::~JITLoaderList()
|
|
{
|
|
}
|
|
|
|
void
|
|
JITLoaderList::Append (const JITLoaderSP &jit_loader_sp)
|
|
{
|
|
std::lock_guard<std::recursive_mutex> guard(m_jit_loaders_mutex);
|
|
m_jit_loaders_vec.push_back(jit_loader_sp);
|
|
}
|
|
|
|
void
|
|
JITLoaderList::Remove (const JITLoaderSP &jit_loader_sp)
|
|
{
|
|
std::lock_guard<std::recursive_mutex> guard(m_jit_loaders_mutex);
|
|
m_jit_loaders_vec.erase(std::remove(m_jit_loaders_vec.begin(),
|
|
m_jit_loaders_vec.end(), jit_loader_sp),
|
|
m_jit_loaders_vec.end());
|
|
}
|
|
|
|
size_t
|
|
JITLoaderList::GetSize() const
|
|
{
|
|
return m_jit_loaders_vec.size();
|
|
}
|
|
|
|
JITLoaderSP
|
|
JITLoaderList::GetLoaderAtIndex (size_t idx)
|
|
{
|
|
std::lock_guard<std::recursive_mutex> guard(m_jit_loaders_mutex);
|
|
return m_jit_loaders_vec[idx];
|
|
}
|
|
|
|
void
|
|
JITLoaderList::DidLaunch()
|
|
{
|
|
std::lock_guard<std::recursive_mutex> guard(m_jit_loaders_mutex);
|
|
for (auto const &jit_loader : m_jit_loaders_vec)
|
|
jit_loader->DidLaunch();
|
|
}
|
|
|
|
void
|
|
JITLoaderList::DidAttach()
|
|
{
|
|
std::lock_guard<std::recursive_mutex> guard(m_jit_loaders_mutex);
|
|
for (auto const &jit_loader : m_jit_loaders_vec)
|
|
jit_loader->DidAttach();
|
|
}
|
|
|
|
void
|
|
JITLoaderList::ModulesDidLoad(ModuleList &module_list)
|
|
{
|
|
std::lock_guard<std::recursive_mutex> guard(m_jit_loaders_mutex);
|
|
for (auto const &jit_loader : m_jit_loaders_vec)
|
|
jit_loader->ModulesDidLoad(module_list);
|
|
}
|