3
#include <stdio.h>
int func()
{
printf("Hello World\n");
return 0;
}
int main()
{
printf("Hello World\n");
return 0;
}
この
は、32ビットアセンブリを対応しているこの単純なCプログラムを考えてみましょう.file "a.c"
.section .rodata
.LC0:
.string "Hello World"
.text
.globl func
.type func, @function
func:
pushl %ebp
movl %esp, %ebp
subl $24, %esp
movl $.LC0, (%esp)
call puts
movl $0, %eax
leave
ret
.size func, .-func
.globl main
.type main, @function
main:
pushl %ebp
movl %esp, %ebp
andl $-16, %esp
subl $16, %esp
movl $.LC0, (%esp)
call puts
movl $0, %eax
leave
ret
.size main, .-main
.ident "GCC: (Ubuntu 4.4.3-4ubuntu5) 4.4.3"
.section .note.GNU-stack,"",@progbits
なぜ文字列のためのgccの予備24バイトの "Hello World"関数 'func()'では同じ文字列のメイン関数の16バイトだけですか?
これは文字列とは関係ありません。スタックにはロードされません。メイン関数のプロローグの$ 16はスタックポインタを整列させるためのものです。 andl命令に注意してください。 –
ハンス、あなたはmainのandl命令について話しています。スタックポインタをページ境界に合わせるandl命令。私はサブ関数$ 16(%esp)をメイン関数&subl $ 24(%esp)のfuncで求めています – user1249669