Что происходит в libc start main?
Я действительно пытаюсь понять шаги из кода высокого уровня - > исполняемый файл.. но у меня возникли некоторые трудности.
я написал пустой int main() {}
C файл и пытаюсь расшифровать разборку через objdump -d
. Вот что происходит:
- на
_start
, настройка выравнивания, нажмите аргументы в стеке, вызовите__libc_start_main
- на
__libc_start_main
первая строка должна выполнитьjmp *0x8049658
однако, при использовании objdump -R
чтобы проверить из записей перемещения, значение в 0x8049658
и !
Я что-то упускаю..
edit: вот некоторые из источников;
080482c0 <__libc_start_main@plt>:
80482c0: ff 25 58 96 04 08 jmp *0x8049658
80482c6: 68 08 00 00 00 push x8
80482cb: e9 d0 ff ff ff jmp 80482a0 <_init+0x2c>
Disassembly of section .text:
080482d0 <_start>:
80482d0: 31 ed xor %ebp,%ebp
80482d2: 5e pop %esi
80482d3: 89 e1 mov %esp,%ecx
80482d5: 83 e4 f0 and xfffffff0,%esp
80482d8: 50 push %eax
80482d9: 54 push %esp
80482da: 52 push %edx
80482db: 68 50 84 04 08 push x8048450
80482e0: 68 e0 83 04 08 push x80483e0
80482e5: 51 push %ecx
80482e6: 56 push %esi
80482e7: 68 d0 83 04 08 push x80483d0
80482ec: e8 cf ff ff ff call 80482c0 <__libc_start_main@plt>
80482f1: f4 hlt
80482f2: 66 90 xchg %ax,%ax
DYNAMIC RELOCATION RECORDS
OFFSET TYPE VALUE
08049644 R_386_GLOB_DAT __gmon_start__
08049654 R_386_JUMP_SLOT __gmon_start__
08049658 R_386_JUMP_SLOT __libc_start_main
1 ответов
первый блок, заканчивающийся на "@plt", является таблица связей процедуры (https://stackoverflow.com/a/5469334/994153). The jmp *0x8049658
является косвенной инструкцией ветви, поэтому она на самом деле прыгает в __libc_start_main
где он на самом деле в конечном итоге загружается в ОЗУ во время выполнения.
реальный адрес ОЗУ __libc_start_main
находится в таблице записей динамического перемещения, которая создается в ОЗУ динамическим загрузчиком при нагруженный.