2021-08-27 05:52:40 +08:00
|
|
|
//===- elfnix_platform.h ----------------------------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// ORC Runtime support for dynamic loading features on ELF-based platforms.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef ORC_RT_ELFNIX_PLATFORM_H
|
|
|
|
#define ORC_RT_ELFNIX_PLATFORM_H
|
|
|
|
|
|
|
|
#include "common.h"
|
|
|
|
#include "executor_address.h"
|
|
|
|
|
|
|
|
// Atexit functions.
|
|
|
|
ORC_RT_INTERFACE int __orc_rt_elfnix_cxa_atexit(void (*func)(void *), void *arg,
|
|
|
|
void *dso_handle);
|
2021-10-09 08:36:41 +08:00
|
|
|
ORC_RT_INTERFACE int __orc_rt_elfnix_atexit(void (*func)(void *));
|
2021-08-27 05:52:40 +08:00
|
|
|
ORC_RT_INTERFACE void __orc_rt_elfnix_cxa_finalize(void *dso_handle);
|
|
|
|
|
|
|
|
// dlfcn functions.
|
|
|
|
ORC_RT_INTERFACE const char *__orc_rt_elfnix_jit_dlerror();
|
|
|
|
ORC_RT_INTERFACE void *__orc_rt_elfnix_jit_dlopen(const char *path, int mode);
|
|
|
|
ORC_RT_INTERFACE int __orc_rt_elfnix_jit_dlclose(void *dso_handle);
|
|
|
|
ORC_RT_INTERFACE void *__orc_rt_elfnix_jit_dlsym(void *dso_handle,
|
|
|
|
const char *symbol);
|
|
|
|
|
|
|
|
namespace __orc_rt {
|
|
|
|
namespace elfnix {
|
|
|
|
|
|
|
|
struct ELFNixPerObjectSectionsToRegister {
|
2021-09-24 11:52:21 +08:00
|
|
|
ExecutorAddrRange EHFrameSection;
|
|
|
|
ExecutorAddrRange ThreadDataSection;
|
2021-08-27 05:52:40 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct ELFNixJITDylibInitializers {
|
2021-09-24 11:52:21 +08:00
|
|
|
using SectionList = std::vector<ExecutorAddrRange>;
|
2021-08-27 05:52:40 +08:00
|
|
|
|
|
|
|
ELFNixJITDylibInitializers() = default;
|
2021-09-24 11:52:21 +08:00
|
|
|
ELFNixJITDylibInitializers(std::string Name, ExecutorAddr DSOHandleAddress)
|
2021-08-27 05:52:40 +08:00
|
|
|
: Name(std::move(Name)), DSOHandleAddress(std::move(DSOHandleAddress)) {}
|
|
|
|
|
|
|
|
std::string Name;
|
2021-09-24 11:52:21 +08:00
|
|
|
ExecutorAddr DSOHandleAddress;
|
2021-08-27 05:52:40 +08:00
|
|
|
|
2022-06-04 14:14:04 +08:00
|
|
|
std::vector<std::pair<std::string, SectionList>> InitSections;
|
2021-08-27 05:52:40 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class ELFNixJITDylibDeinitializers {};
|
|
|
|
|
|
|
|
using ELFNixJITDylibInitializerSequence =
|
|
|
|
std::vector<ELFNixJITDylibInitializers>;
|
|
|
|
|
|
|
|
using ELFNixJITDylibDeinitializerSequence =
|
|
|
|
std::vector<ELFNixJITDylibDeinitializers>;
|
|
|
|
|
|
|
|
enum dlopen_mode : int {
|
|
|
|
ORC_RT_RTLD_LAZY = 0x1,
|
|
|
|
ORC_RT_RTLD_NOW = 0x2,
|
|
|
|
ORC_RT_RTLD_LOCAL = 0x4,
|
|
|
|
ORC_RT_RTLD_GLOBAL = 0x8
|
|
|
|
};
|
|
|
|
|
|
|
|
} // end namespace elfnix
|
|
|
|
|
|
|
|
using SPSELFNixPerObjectSectionsToRegister =
|
2021-09-24 11:52:21 +08:00
|
|
|
SPSTuple<SPSExecutorAddrRange, SPSExecutorAddrRange>;
|
2021-08-27 05:52:40 +08:00
|
|
|
|
|
|
|
template <>
|
|
|
|
class SPSSerializationTraits<SPSELFNixPerObjectSectionsToRegister,
|
|
|
|
elfnix::ELFNixPerObjectSectionsToRegister> {
|
|
|
|
|
|
|
|
public:
|
|
|
|
static size_t size(const elfnix::ELFNixPerObjectSectionsToRegister &MOPOSR) {
|
|
|
|
return SPSELFNixPerObjectSectionsToRegister::AsArgList::size(
|
|
|
|
MOPOSR.EHFrameSection, MOPOSR.ThreadDataSection);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool
|
|
|
|
serialize(SPSOutputBuffer &OB,
|
|
|
|
const elfnix::ELFNixPerObjectSectionsToRegister &MOPOSR) {
|
|
|
|
return SPSELFNixPerObjectSectionsToRegister::AsArgList::serialize(
|
|
|
|
OB, MOPOSR.EHFrameSection, MOPOSR.ThreadDataSection);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool deserialize(SPSInputBuffer &IB,
|
|
|
|
elfnix::ELFNixPerObjectSectionsToRegister &MOPOSR) {
|
|
|
|
return SPSELFNixPerObjectSectionsToRegister::AsArgList::deserialize(
|
|
|
|
IB, MOPOSR.EHFrameSection, MOPOSR.ThreadDataSection);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-09-24 11:52:21 +08:00
|
|
|
using SPSNamedExecutorAddrRangeSequenceMap =
|
|
|
|
SPSSequence<SPSTuple<SPSString, SPSExecutorAddrRangeSequence>>;
|
2021-08-27 05:52:40 +08:00
|
|
|
|
|
|
|
using SPSELFNixJITDylibInitializers =
|
2021-09-24 11:52:21 +08:00
|
|
|
SPSTuple<SPSString, SPSExecutorAddr, SPSNamedExecutorAddrRangeSequenceMap>;
|
2021-08-27 05:52:40 +08:00
|
|
|
|
|
|
|
using SPSELFNixJITDylibInitializerSequence =
|
|
|
|
SPSSequence<SPSELFNixJITDylibInitializers>;
|
|
|
|
|
|
|
|
/// Serialization traits for ELFNixJITDylibInitializers.
|
|
|
|
template <>
|
|
|
|
class SPSSerializationTraits<SPSELFNixJITDylibInitializers,
|
|
|
|
elfnix::ELFNixJITDylibInitializers> {
|
|
|
|
public:
|
|
|
|
static size_t size(const elfnix::ELFNixJITDylibInitializers &MOJDIs) {
|
|
|
|
return SPSELFNixJITDylibInitializers::AsArgList::size(
|
|
|
|
MOJDIs.Name, MOJDIs.DSOHandleAddress, MOJDIs.InitSections);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool serialize(SPSOutputBuffer &OB,
|
|
|
|
const elfnix::ELFNixJITDylibInitializers &MOJDIs) {
|
|
|
|
return SPSELFNixJITDylibInitializers::AsArgList::serialize(
|
|
|
|
OB, MOJDIs.Name, MOJDIs.DSOHandleAddress, MOJDIs.InitSections);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool deserialize(SPSInputBuffer &IB,
|
|
|
|
elfnix::ELFNixJITDylibInitializers &MOJDIs) {
|
|
|
|
return SPSELFNixJITDylibInitializers::AsArgList::deserialize(
|
|
|
|
IB, MOJDIs.Name, MOJDIs.DSOHandleAddress, MOJDIs.InitSections);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // end namespace __orc_rt
|
|
|
|
|
|
|
|
#endif // ORC_RT_ELFNIX_PLATFORM_H
|