forked from OSchip/llvm-project
[ASan] Suppress the deprecation warning from atos that breaks AtosSymbolizer on OSX 10.9
On OS X 10.9 /usr/bin/atos prints the following warning upon invocation: -- Warning: /usr/bin/atos is moving and will be removed from a future OS X release. It is now available in the Xcode developer tools to be invoked via: `xcrun atos` To silence this warning, pass the '-d' command-line flag to this tool. -- AtosSymbolizer treats the warning as the symbolization result for the first PC passed to the symbolizer. As a result, for each of the following PCs the file:line info for the previous PC is printed, e.g.: ==97926==ERROR: AddressSanitizer: attempting double-free on 0x60200000dfb0 in thread T0: ==97926==Using atos at user-specified path: /usr/bin/atos ==97926==Using dladdr symbolizer. #0 0x1007407e0 in -- (+0x427e0) #1 0x1006f6f25 in wrap_free asan_malloc_mac.cc:114 #2 0x7fff916e05fc in main atos-symbolizer.cc:17 #3 0x0 (<unknown module>) Unfortunately atos doesn't accept the -d switch on OSX versions other than 10.9, thus we have to check for the OSX version. llvm-svn: 233180
This commit is contained in:
parent
639e8ad644
commit
2dee295a89
|
@ -16,6 +16,7 @@
|
||||||
#if SANITIZER_MAC
|
#if SANITIZER_MAC
|
||||||
|
|
||||||
#include "sanitizer_allocator_internal.h"
|
#include "sanitizer_allocator_internal.h"
|
||||||
|
#include "sanitizer_mac.h"
|
||||||
#include "sanitizer_symbolizer_mac.h"
|
#include "sanitizer_symbolizer_mac.h"
|
||||||
|
|
||||||
namespace __sanitizer {
|
namespace __sanitizer {
|
||||||
|
@ -57,8 +58,15 @@ class AtosSymbolizerProcess : public SymbolizerProcess {
|
||||||
|
|
||||||
char pid_str[16];
|
char pid_str[16];
|
||||||
internal_snprintf(pid_str, sizeof(pid_str), "%d", parent_pid_);
|
internal_snprintf(pid_str, sizeof(pid_str), "%d", parent_pid_);
|
||||||
|
if (GetMacosVersion() == MACOS_VERSION_MAVERICKS) {
|
||||||
|
// On Mavericks atos prints a deprecation warning which we suppress by
|
||||||
|
// passing -d. The warning isn't present on other OSX versions, even the
|
||||||
|
// newer ones.
|
||||||
|
execl(path_to_binary, path_to_binary, "-p", pid_str, "-d", (char *)0);
|
||||||
|
} else {
|
||||||
execl(path_to_binary, path_to_binary, "-p", pid_str, (char *)0);
|
execl(path_to_binary, path_to_binary, "-p", pid_str, (char *)0);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pid_t parent_pid_;
|
pid_t parent_pid_;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue