Skip to content

Commit

Permalink
Merge pull request #1074 from catap/max-memory
Browse files Browse the repository at this point in the history
Never try to limit memory on macOS
  • Loading branch information
s3rvac authored Apr 28, 2022
2 parents b7ed6b5 + 916efae commit 8a960f1
Showing 1 changed file with 16 additions and 5 deletions.
21 changes: 16 additions & 5 deletions src/utils/memory.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ namespace utils {

namespace {

#ifdef OS_POSIX
#if defined(OS_POSIX) && !defined(OS_MACOS)

/**
* @brief Implementation of @c limitSystemMemory() on POSIX-compliant systems.
Expand Down Expand Up @@ -115,10 +115,21 @@ std::size_t getTotalSystemMemoryOnMacOS() {
* @brief Implementation of @c limitSystemMemory() on MacOS.
*/
bool limitSystemMemoryOnMacOS(std::size_t limit) {
// Warning: We have found that limitSystemMemoryOnPOSIX() does not actually
// do anything on macOS. We need to find another way. See
// https://github.com/avast/retdec/issues/379
return limitSystemMemoryOnPOSIX(limit);
// Warning: We can't limit memory on macOS. Before macOS 12
// limitSystemMemoryOnPOSIX() does not actually do anything on macOS.
// Anyway, it just succeed, since macOS 12 it returns error and retdec can't
// start. See:
// - https://github.com/avast/retdec/issues/379
// - https://github.com/avast/retdec/issues/1045
//
// To be honest Apple can control memmory limit via so-called the ledger()
// system call which is private. An old verison which was opened to OpenSource
// (from 10.9-10.10?) using setrlimit() but at some point setrlimit() was broken
// and not ledger(). Probably at macOS 12 the setrlimit() was completley broken.
//
// Because we haven't got any other choose just return true which haven't
// change anything.
return true;
}

#elif defined(OS_BSD)
Expand Down

0 comments on commit 8a960f1

Please sign in to comment.