[LLVMdev] MacOSX: cache losing clang/llvm debug symbols with separate compilation…

Christophe de Dinechin christophe.de.dinechin at gmail.com
Mon Jul 28 12:35:46 PDT 2014


Apparently, ccache loses debug symbols on Mavericks with clang/lldb. Here is a session illustrating the problem. I spent quite a bit of time figuring out that ccache was the culprit, so I thought I'd share also on the clang and LLVM mailing lists in case someone else runs into this.

Here is a session illustrating the issue (same issue with C and C++ source files):

% cat glop.cpp 
#include <iostream>

int main()
{
    std::cerr << "Hello World\n";
}
% c++ -g glop.cpp  -o glop
% lldb glop
Current executable set to 'glop' (x86_64).
(lldb) b glop.cpp:5
Breakpoint 1: where = glop`main + 22 at glop.cpp:5, address = 0x00000001000011e6
(lldb) exit

# So far so good. But with separate compilation, it breaks:

% c++ -g -c glop.cpp -o glop.o
% c++ -g glop.o -o glop
% lldb glop
Current executable set to 'glop' (x86_64).
(lldb) b main.cpp:5
Breakpoint 1: no locations (pending).
WARNING:  Unable to resolve breakpoint to any actual locations.
(lldb) exit

% c++ --version
Apple LLVM version 5.1 (clang-503.0.40) (based on LLVM 3.4svn)
Target: x86_64-apple-darwin13.3.0
Thread model: posix
% uname -a 
Darwin somemachine.local 13.3.0 Darwin Kernel Version 13.3.0: Tue Jun  3 21:27:35 PDT 2014; root:xnu-2422.110.17~1/RELEASE_X86_64 x86_64
% ccache --version
ccache version 3.1.9


My ccache is from MacPorts. It seems to be the latest as of today.


Thanks for your help.
Christophe



More information about the llvm-dev mailing list