gdb не удается запустить 64-разрядную программу ELF с " формат файла не распознан"

Я пытаюсь использовать GDB для отладки (чтобы найти раздражающий segfault). Когда я бегу:

gdb ./filename

из командной строки, я получаю следующую ошибку:

This GDB was configured as "i686-pc-linux-
gnu"..."/path/exec": not in executable 
format: File format not recognized

когда я выполнить:

file /path/executable/

Я получаю следующую информацию:

 ELF 64-bit LSB executable, AMD x86-64,
 version 1 (SYSV), for GNU/Linux 2.4.0, 
 dynamically linked (uses shared libs), not stripped

Я использую GDB 6.1, и исполняемый файл скомпилирован с GCC версии 3.4.6.

Я немного не в своей воде с точки зрения использования gdb, но, насколько я могу сказать, он должен работать в этом случае. Есть идеи, что не так?

5 ответов


исполняемый файл 64-разрядный (x86-64), а отладчик-32-разрядная (i686-pc-linux) сборка. Возможно, потребуется установить 64-разрядную (x86-64) версию отладчика.


Я не уверен, что это ваша проблема, но я сталкивался с этой ситуацией очень часто. Исполняемый файл в дереве сборки build by make / automake не является двоичным, а скриптом, поэтому вы не можете использовать gdb с ним. Попробуйте установить приложение и изменить каталог, потому что иначе gdb попытается отладить скрипт.


вопрос относится к "./ filename " и "/ path / исполняемый файл". Это тот же файл?

Если вы делаете посмертный анализ, вы бы запустить:

gdb executable-file core-file

Если вы собираетесь игнорировать основной файл, вы должны запустить:

gdb executable-file

В обоих случаях, 'executable-file ' означает путь к двоичному файлу, который вы хотите отладить. Обычно это на самом деле простое имя файла в текущем каталоге, так как у вас есть исходный код из сборки отладки там.

на Solaris 64-разрядная сборка GDB должна быть способна отлаживать как 32-разрядные, так и 64-разрядные исполняемые файлы (хотя у меня были некоторые проблемы с последними версиями GDB). Я не уверен в обратном - что 32-битный GDB обязательно может отлаживать 64-битные исполняемые файлы.


то, что вам нужно проверить, на самом деле является библиотекой bfd. The двоичный файл дескриптора библиотека-это то, что binutils / gdb использует для фактического анализа и обработки двоичных файлов (ELF / a.вне etc..).

вы можете видеть текущие Поддерживаемые платформы через objdump;

# objdump -H

objdump: supported targets: elf32-powerpc aixcoff-rs6000 elf32-powerpcle ppcboot elf64-powerpc elf64-powerpcle elf64-little elf64-big elf32-little elf32-big srec symbolsrec tekhex binary ihex
objdump: supported architectures: rs6000:6000 rs6000:rs1 rs6000:rsc rs6000:rs2 powerpc:common powerpc:common64 powerpc:603 powerpc:EC603e powerpc:604 powerpc:403 powerpc:601 powerpc:620 powerpc:630 powerpc:a35 powerpc:rs64ii powerpc:rs64iii powerpc:7400 powerpc:e500 powerpc:MPC8XX powerpc:750

The following PPC specific disassembler options are supported for use with
the -M switch:
  booke|booke32|booke64    Disassemble the BookE instructions
  e300                     Disassemble the e300 instructions
  e500|e500x2              Disassemble the e500 instructions
  efs                      Disassemble the EFS instructions
  power4                   Disassemble the Power4 instructions
  power5                   Disassemble the Power5 instructions
  power6                   Disassemble the Power6 instructions
  32                       Do not disassemble 64-bit instructions
  64                       Allow disassembly of 64-bit instructions

кажется, ваш отладчик GNU (gdb) не поддерживает архитектуру x86_64.

так попробуй символы отладки отладчик (lldb), который призван заменить его. Он поддерживает наборы инструкций i386, x86-64 и ARM.

он доступен по умолчанию на BSD / OS X, на Linux установить через:sudo apt-get install lldb (или использовать yum).

посмотреть: gdb в lldb командная карта страница для получения дополнительной информации.