Você precisa usar objcopy para separar as informações de depuração :
objcopy --only-keep-debug "${tostripfile}" "${debugdir}/${debugfile}"
strip --strip-debug --strip-unneeded "${tostripfile}"
objcopy --add-gnu-debuglink="${debugdir}/${debugfile}" "${tostripfile}"
Eu uso o script bash abaixo para separar as informações de depuração em arquivos com uma extensão .debug em um diretório .debug. Dessa forma, posso tar as bibliotecas e executáveis em um arquivo tar e os diretórios .debug em outro. Se eu quiser adicionar as informações de depuração mais tarde, simplesmente extraio o arquivo tar de depuração e pronto, tenho informações simbólicas de depuração.
Este é o script bash:
#!/bin/bash
scriptdir=`dirname ${0}`
scriptdir=`(cd ${scriptdir}; pwd)`
scriptname=`basename ${0}`
set -e
function errorexit()
{
errorcode=${1}
shift
echo $@
exit ${errorcode}
}
function usage()
{
echo "USAGE ${scriptname} <tostrip>"
}
tostripdir=`dirname "$1"`
tostripfile=`basename "$1"`
if [ -z ${tostripfile} ] ; then
usage
errorexit 0 "tostrip must be specified"
fi
cd "${tostripdir}"
debugdir=.debug
debugfile="${tostripfile}.debug"
if [ ! -d "${debugdir}" ] ; then
echo "creating dir ${tostripdir}/${debugdir}"
mkdir -p "${debugdir}"
fi
echo "stripping ${tostripfile}, putting debug info into ${debugfile}"
objcopy --only-keep-debug "${tostripfile}" "${debugdir}/${debugfile}"
strip --strip-debug --strip-unneeded "${tostripfile}"
objcopy --add-gnu-debuglink="${debugdir}/${debugfile}" "${tostripfile}"
chmod -x "${debugdir}/${debugfile}"
--build-id
opção vinculador ?Compile com informações de depuração:
Separe as informações de depuração:
ou
Tira informações de depuração do arquivo de origem:
ou
debugar pelo modo debuglink:
Você também pode usar o arquivo exec e o arquivo de símbolo separadamente:
ou
Para detalhes:
Ref:
https://sourceware.org/gdb/onlinedocs/gdb/Files.html#Files https://sourceware.org/gdb/onlinedocs/gdb/Separate-Debug-Files.html
fonte
objcopy --add-gnu-debuglink main main.debug
para incorporar o nome do arquivo de depuração criado e uma soma de verificação. Nesse caso, o gdb tentará encontrar o próprio código de depuração em alguns locais dependentes da distribuição; nenhuma opção -s é mais necessária.Confira a opção "--only-keep-debug" do comando strip .
No link:
fonte
NOTA: Programas compilados com altos níveis de otimização (-O3, -O4) não podem gerar muitos símbolos de depuração para variáveis otimizadas, funções alinhadas e loops desenrolados, independentemente dos símbolos serem incorporados (-g) ou extraídos (objcopy) em um arquivo '.debug'.
Abordagens alternativas são
A primeira opção fornece um meio de reconstruir o código de produção com depuração completa e símbolos posteriormente. Ser capaz de recriar o código de produção original sem otimizações é uma tremenda ajuda para a depuração. (NOTA: Isso pressupõe que o teste foi realizado com a versão otimizada do programa).
Seu sistema de criação pode criar um arquivo .c carregado com a data de compilação, confirmação e outros detalhes do VCS. Aqui está um exemplo 'make + git':
Após a compilação do programa, você pode localizar o 'commit' original do seu código usando o comando:
strings -a my_program | grep VCS
Tudo o que resta é fazer check-out do código original, recompilar sem otimizações e iniciar a depuração.
fonte
-O4
nem existe.Nenhuma resposta até agora menciona
eu-strip --strip-debug -f <out.debug> <input>
.elfutils
pacote.<input>
arquivo foi despojado de símbolos de depuração que agora estão todos em<out.debug>
.fonte