objdump и разрешение связывания вызовов локальных функций?

Если я запустил objdump -d для файла (linux amd64) .o, вызовы функций покажут вверх без разрешения времени ссылки. Пример:

  90:   66 89 44 24 1c          mov    %ax,0x1c(%rsp)
  95:   44 89 74 24 10          mov    %r14d,0x10(%rsp)
  9a:   e8 00 00 00 00          callq  9f <foo+0x9f>
  9f:   83 f8 ff                cmp    $0xffffffffffffffff,%eax
  a2:   74 5e                   je     102 <foo+0x102>

Ветвь внутри функции отображается правильно, но callq - это просто заглушка, вставленная для компоновщика (с четырьмя байтами нулей, доступных для компоновщика, чтобы поместить в него правильный адрес).

Есть ли способ, без фактического связывания, получить список сборок, в котором имена функций разрешены? Меня не волнует адрес, который в конечном итоге будет использован, а только название функции. Эта информация должна быть в файле .o, поскольку компоновщик должен использовать ее для выполнения своей работы.

Я спрашиваю, потому что общая библиотека, в которую входит рассматриваемый код, составляет около 140 МБ, и требуется долгое время, чтобы запустить objdump -d, чтобы получить дамп asm со всеми разрешенными вызовами функций на их настоящие имена.

7
задан Peeter Joot 24 January 2012 в 19:35
поделиться