[LLVMdev] DataFlowSanitizer only for Linux
kcc at google.com
Tue Jul 7 22:45:09 PDT 2015
+pcc , glider
On Mon, Jul 6, 2015 at 12:59 PM, Juan Ceasar <juan.d.ceasar at gmail.com>
> I had an issue with trying to link a program with the DataFlowSanitizer
> functionality, this is from the libFuzzer project, and I was seeing:
> clang++ -fsanitize=address -fsanitize-coverage=edge test_fuzzer.cc
> Undefined symbols for architecture x86_64:
> "_dfsan_create_label", referenced from:
> fuzzer::TraceState::DFSanCmpCallback(unsigned long, unsigned long,
> unsigned long, unsigned long long, unsigned long long, unsigned short,
> unsigned short) in FuzzerTraceState.o
> fuzzer::Fuzzer::InitializeTraceState() in FuzzerTraceState.o
> "_dfsan_get_label_info", referenced from:
> fuzzer::TraceState::GetLabelRange(unsigned short) in
> But then looking at the docs:
> It appears that this is only supported under Linux? Is that right?
Correct. AFAICT, DFSan was only tested on Linux.
It is quite hard to make it work on Mac because there are too many closed
source libraries there.
Nothing impossible though -- it's just that nobody has worked on it.
libFuzzer was also never tested on Mac, but I think it should be trivial to
make it work there.
I suspect that the errors you see are caused by the weak function
declarations which don't (???) work on Mac.
You'll need to #ifdef the weak functions on Mac somehow. Patches and Mac
buildbots are welcome :)
> LLVM Developers mailing list
> LLVMdev at cs.uiuc.edu http://llvm.cs.uiuc.edu
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the llvm-dev