mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-08 13:00:43 +00:00
8bb56ccbc0
The motivation for this change is to fix linking issues on OSX. However this only partially fixes linking issues (the uninstrumented tests and a few others won't succesfully link yet). This change introduces a struct of function pointers (``fuzzer::ExternalFuntions``) which when initialised will point to the optional functions if they are available. Currently these ``LLVMFuzzerInitialize`` and ``LLVMFuzzerCustomMutator`` functions. Two implementations of ``fuzzer::ExternalFunctions`` constructor are provided one for Linux and one for OSX. The OSX implementation uses ``dlsym()`` because the prior implementation using weak symbols does not work unless the additional flags are passed to the linker. The Linux implementation continues to use weak symbols because the ``dlsym()`` approach does not work unless additional flags are passed to the linker. Differential Revision: http://reviews.llvm.org/D20741 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@271491 91177308-0d34-0410-b5e6-96231b3b80d8
51 lines
1.7 KiB
C++
51 lines
1.7 KiB
C++
//===- FuzzerExtFunctionsWeak.cpp - Interface to external functions -------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
// Implementation for Linux. This relies on the linker's support for weak
|
|
// symbols. We don't use this approach on Apple platforms because it requires
|
|
// clients of LibFuzzer to pass ``-U _<symbol_name>`` to the linker to allow
|
|
// weak symbols to be undefined. That is a complication we don't want to expose
|
|
// to clients right now.
|
|
//===----------------------------------------------------------------------===//
|
|
#include "FuzzerInternal.h"
|
|
#if LIBFUZZER_LINUX
|
|
|
|
#include "FuzzerExtFunctions.h"
|
|
|
|
extern "C" {
|
|
// Declare these symbols as weak to allow them to be optionally defined.
|
|
#define EXT_FUNC(NAME, RETURN_TYPE, FUNC_SIG, WARN) \
|
|
__attribute__((weak)) RETURN_TYPE NAME FUNC_SIG
|
|
|
|
#include "FuzzerExtFunctions.def"
|
|
|
|
#undef EXT_FUNC
|
|
}
|
|
|
|
using namespace fuzzer;
|
|
|
|
static void CheckFnPtr(void *FnPtr, const char *FnName, bool WarnIfMissing) {
|
|
if (FnPtr == nullptr && WarnIfMissing) {
|
|
Printf("WARNING: Failed to find function \"%s\".\n", FnName);
|
|
}
|
|
}
|
|
|
|
namespace fuzzer {
|
|
|
|
ExternalFunctions::ExternalFunctions() {
|
|
#define EXT_FUNC(NAME, RETURN_TYPE, FUNC_SIG, WARN) \
|
|
this->NAME = ::NAME; \
|
|
CheckFnPtr((void *)::NAME, #NAME, WARN);
|
|
|
|
#include "FuzzerExtFunctions.def"
|
|
|
|
#undef EXT_FUNC
|
|
}
|
|
} // namespace fuzzer
|
|
#endif // LIBFUZZER_LINUX
|