Вам нужно использовать objcopy для разделения отладочной информации :
objcopy --only-keep-debug "${tostripfile}" "${debugdir}/${debugfile}"
strip --strip-debug --strip-unneeded "${tostripfile}"
objcopy --add-gnu-debuglink="${debugdir}/${debugfile}" "${tostripfile}"
Я использую скрипт bash ниже, чтобы разделить отладочную информацию на файлы с расширением .debug в каталоге .debug. Таким образом я могу смонтировать библиотеки и исполняемые файлы в одном файле tar, а каталоги .debug - в другом. Если я хочу добавить отладочную информацию позже, я просто извлекаю отладочный tar-файл и вуаля, у меня есть символическая отладочная информация.
Это скрипт 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
опции компоновщика ?Компилировать с отладочной информацией:
Отделяйте отладочную информацию:
или
Убрать отладочную информацию из исходного файла:
или
отладка в режиме отладки ссылок:
Вы также можете использовать файл exec и файл символов отдельно:
или
Для деталей:
Ссылка:
https://sourceware.org/gdb/onlinedocs/gdb/Files.html#Files https://sourceware.org/gdb/onlinedocs/gdb/Separate-Debug-Files.html
источник
objcopy --add-gnu-debuglink main main.debug
для встраивания имени созданного файла отладки и контрольной суммы. В этом случае GDB попытается найти сам код отладки в нескольких местах, зависящих от дистрибутива, опция -s больше не нужна.Проверьте параметр «--only-keep-debug» команды strip .
По ссылке:
источник
ПРИМЕЧАНИЕ. Программы, скомпилированные с уровнями высокой оптимизации (-O3, -O4), не могут генерировать много символов отладки для оптимизированных переменных, встроенных функций и развернутых циклов, независимо от того, вставлены ли символы (-g) или извлечены (objcopy) в Файл .debug.
Альтернативные подходы
Первый вариант предоставляет возможность перестроить производственный код с полной отладкой и символами на более позднем этапе. Возможность перестроить исходный производственный код без оптимизации - огромная помощь для отладки. (ПРИМЕЧАНИЕ. Предполагается, что тестирование проводилось с оптимизированной версией программы).
Ваша система сборки может создать файл .c, загруженный с датой компиляции, коммитом и другими деталями VCS. Вот пример 'make + git':
После того, как программа скомпилирована, вы можете найти исходный 'commit' для вашего кода, используя команду:
strings -a my_program | grep VCS
Осталось только извлечь исходный код, перекомпилировать без оптимизации и начать отладку.
источник
-O4
даже не существуетНикакой ответ пока не упоминает
eu-strip --strip-debug -f <out.debug> <input>
.elfutils
пакетом.<input>
файл был очищен от символов отладки, которые теперь все в<out.debug>
.источник