mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
Add my abstracted dynamic linker support files.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9008 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bd2531f8a6
commit
f212e47271
29
include/Support/DynamicLinker.h
Normal file
29
include/Support/DynamicLinker.h
Normal file
@ -0,0 +1,29 @@
|
||||
//===-- DynamicLinker.h - System-indep. DynamicLinker interface -*- C++ -*-===//
|
||||
//
|
||||
// Lightweight interface to dynamic library linking and loading, and dynamic
|
||||
// symbol lookup functionality, in whatever form the operating system
|
||||
// provides it.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#ifndef SUPPORT_DYNAMICLINKER_H
|
||||
#define SUPPORT_DYNAMICLINKER_H
|
||||
|
||||
#include <string>
|
||||
|
||||
/// LinkDynamicObject - Load the named file as a dynamic library
|
||||
/// and link it with the currently running process. Returns false
|
||||
/// on success, true if there is an error (and sets ErrorMessage
|
||||
/// if it is not NULL). Analogous to dlopen().
|
||||
///
|
||||
bool LinkDynamicObject (const char *filename, std::string *ErrorMessage);
|
||||
|
||||
/// GetAddressOfSymbol - Returns the address of the named symbol in
|
||||
/// the currently running process, as reported by the dynamic linker,
|
||||
/// or NULL if the symbol does not exist or some other error has
|
||||
/// occurred.
|
||||
///
|
||||
void *GetAddressOfSymbol (const char *symbolName);
|
||||
void *GetAddressOfSymbol (const std::string &symbolName);
|
||||
|
||||
#endif // SUPPORT_DYNAMICLINKER_H
|
29
include/llvm/Support/DynamicLinker.h
Normal file
29
include/llvm/Support/DynamicLinker.h
Normal file
@ -0,0 +1,29 @@
|
||||
//===-- DynamicLinker.h - System-indep. DynamicLinker interface -*- C++ -*-===//
|
||||
//
|
||||
// Lightweight interface to dynamic library linking and loading, and dynamic
|
||||
// symbol lookup functionality, in whatever form the operating system
|
||||
// provides it.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#ifndef SUPPORT_DYNAMICLINKER_H
|
||||
#define SUPPORT_DYNAMICLINKER_H
|
||||
|
||||
#include <string>
|
||||
|
||||
/// LinkDynamicObject - Load the named file as a dynamic library
|
||||
/// and link it with the currently running process. Returns false
|
||||
/// on success, true if there is an error (and sets ErrorMessage
|
||||
/// if it is not NULL). Analogous to dlopen().
|
||||
///
|
||||
bool LinkDynamicObject (const char *filename, std::string *ErrorMessage);
|
||||
|
||||
/// GetAddressOfSymbol - Returns the address of the named symbol in
|
||||
/// the currently running process, as reported by the dynamic linker,
|
||||
/// or NULL if the symbol does not exist or some other error has
|
||||
/// occurred.
|
||||
///
|
||||
void *GetAddressOfSymbol (const char *symbolName);
|
||||
void *GetAddressOfSymbol (const std::string &symbolName);
|
||||
|
||||
#endif // SUPPORT_DYNAMICLINKER_H
|
42
lib/Support/DynamicLinker.cpp
Normal file
42
lib/Support/DynamicLinker.cpp
Normal file
@ -0,0 +1,42 @@
|
||||
//===-- DynamicLinker.cpp - Implement DynamicLinker interface -------------===//
|
||||
//
|
||||
// Lightweight interface to dynamic library linking and loading, and dynamic
|
||||
// symbol lookup functionality, in whatever form the operating system
|
||||
// provides it.
|
||||
//
|
||||
// Possible future extensions include support for the HPUX shl_load()
|
||||
// interface, the Mac OS X NSLinkModule() interface, and the Windows
|
||||
// LoadLibrary() interface.
|
||||
//
|
||||
// Note that we assume that if dlopen() is available, then dlsym() is too.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "Support/DynamicLinker.h"
|
||||
#include "Config/dlfcn.h"
|
||||
#include <cassert>
|
||||
|
||||
bool LinkDynamicObject (const char *filename, std::string *ErrorMessage) {
|
||||
#if defined (HAVE_DLOPEN)
|
||||
if (dlopen (filename, RTLD_NOW | RTLD_GLOBAL) == 0) {
|
||||
if (ErrorMessage) *ErrorMessage = dlerror ();
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
#else
|
||||
assert (0 && "Dynamic object linking not implemented for this platform");
|
||||
#endif
|
||||
}
|
||||
|
||||
void *GetAddressOfSymbol (const char *symbolName) {
|
||||
#if defined (HAVE_DLOPEN)
|
||||
return dlsym (RTLD_DEFAULT, symbolName);
|
||||
#else
|
||||
assert (0 && "Dynamic symbol lookup not implemented for this platform");
|
||||
#endif
|
||||
}
|
||||
|
||||
// soft, cushiony C++ interface.
|
||||
void *GetAddressOfSymbol (const std::string &symbolName) {
|
||||
return GetAddressOfSymbol (symbolName.c_str ());
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user