aboutsummaryrefslogtreecommitdiff
path: root/llvm/tools/llvm-jitlink/llvm-jitlink.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/tools/llvm-jitlink/llvm-jitlink.cpp')
-rw-r--r--llvm/tools/llvm-jitlink/llvm-jitlink.cpp62
1 files changed, 61 insertions, 1 deletions
diff --git a/llvm/tools/llvm-jitlink/llvm-jitlink.cpp b/llvm/tools/llvm-jitlink/llvm-jitlink.cpp
index 127a214..8e678d3 100644
--- a/llvm/tools/llvm-jitlink/llvm-jitlink.cpp
+++ b/llvm/tools/llvm-jitlink/llvm-jitlink.cpp
@@ -150,6 +150,11 @@ static cl::opt<uint64_t> SlabAddress(
cl::desc("Set slab target address (requires -slab-allocate and -noexec)"),
cl::init(~0ULL), cl::cat(JITLinkCategory));
+static cl::opt<uint64_t> SlabPageSize(
+ "slab-page-size",
+ cl::desc("Set page size for slab (requires -slab-allocate and -noexec)"),
+ cl::init(0), cl::cat(JITLinkCategory));
+
static cl::opt<bool> ShowRelocatedSectionContents(
"show-relocated-section-contents",
cl::desc("show section contents after fixups have been applied"),
@@ -464,7 +469,21 @@ private:
JITLinkSlabAllocator(uint64_t SlabSize, Error &Err) {
ErrorAsOutParameter _(&Err);
- PageSize = sys::Process::getPageSizeEstimate();
+ if (!SlabPageSize) {
+ if (auto PageSizeOrErr = sys::Process::getPageSize())
+ PageSize = *PageSizeOrErr;
+ else {
+ Err = PageSizeOrErr.takeError();
+ return;
+ }
+
+ if (PageSize == 0) {
+ Err = make_error<StringError>("Page size is zero",
+ inconvertibleErrorCode());
+ return;
+ }
+ } else
+ PageSize = SlabPageSize;
if (!isPowerOf2_64(PageSize)) {
Err = make_error<StringError>("Page size is not a power of 2",
@@ -1082,12 +1101,53 @@ static Error sanitizeArguments(const Triple &TT, const char *ArgV0) {
if (EntryPointName.empty())
EntryPointName = TT.getObjectFormat() == Triple::MachO ? "_main" : "main";
+ // If -slab-allocate is passed, check that we're not trying to use it in
+ // -oop-executor or -oop-executor-connect mode.
+ //
+ // FIXME: Remove once we enable remote slab allocation.
+ if (SlabAllocateSizeString != "") {
+ if (OutOfProcessExecutor.getNumOccurrences() ||
+ OutOfProcessExecutorConnect.getNumOccurrences())
+ return make_error<StringError>(
+ "-slab-allocate cannot be used with -oop-executor or "
+ "-oop-executor-connect",
+ inconvertibleErrorCode());
+ }
+
// If -slab-address is passed, require -slab-allocate and -noexec
if (SlabAddress != ~0ULL) {
if (SlabAllocateSizeString == "" || !NoExec)
return make_error<StringError>(
"-slab-address requires -slab-allocate and -noexec",
inconvertibleErrorCode());
+
+ errs() << "Warning: -slab-address used without -slab-page-size.\n";
+ }
+
+ if (SlabPageSize != 0) {
+ // -slab-page-size requires slab alloc.
+ if (SlabAllocateSizeString == "")
+ return make_error<StringError>("-slab-page-size requires -slab-allocate",
+ inconvertibleErrorCode());
+
+ // Check -slab-page-size / -noexec interactions.
+ if (!NoExec) {
+ if (auto RealPageSize = sys::Process::getPageSize()) {
+ if (SlabPageSize % *RealPageSize)
+ return make_error<StringError>(
+ "-slab-page-size must be a multiple of real page size for exec "
+ "tests (did you mean to use -noexec ?)\n",
+ inconvertibleErrorCode());
+ } else {
+ errs() << "Could not retrieve process page size:\n";
+ logAllUnhandledErrors(RealPageSize.takeError(), errs(), "");
+ errs() << "Executing with slab page size = "
+ << formatv("{0:x}", SlabPageSize) << ".\n"
+ << "Tool may crash if " << formatv("{0:x}", SlabPageSize)
+ << " is not a multiple of the real process page size.\n"
+ << "(did you mean to use -noexec ?)";
+ }
+ }
}
// Only one of -oop-executor and -oop-executor-connect can be used.