Linux彙編GAS調用C語言函數實例

    Blum的書上只講了C語言調用匯編,沒講彙編調用C語言。我自己嘗試了下。

最終試驗成功了,在此寫出與大家分享。期間歷經無數錯誤,無數異常,我不是醉了,而是跪了。。。好在最後好了。

    程序實現一個換值功能,在main.s裏定義a=10,b=20,然後調用C語言函數把a,b換值。

新建兩個文件分別爲main.s的彙編文件,還有pro.c的C語言函數文件。

main.s的代碼如下:

.section .data
a:
    .int 10
b:
    .int 20
.section .text
.globl main
.type main,@function    #別忘了這句,因爲main彙編函數也是被crt0.s調用的,main本質上也是個函數
main: 
    movl $a,%eax
    movl $b,%ebx
    pushl %ebx
    pushl %eax
    call swapint    #不要寫成 _swapint
    movl $1,%eax
    movl $0,%ebx
    int $0x80

pro.c的代碼如下:

#include<stdio.h>
int swapint(int *a,int *b)
{
    int c;
    char *str="success!!";
    c=*a;
    *a=*b;
    *b=c;
    puts(str);                #用puts可以輸出
    puts("end!");            #用puts可以輸出
    printf("output??");        #用printf會造成此句無輸出,原因:緩衝區沒滿,用\n清空緩衝區即可造成輸出。
    return 0;
}


    在彙編函數裏先把a,b的地址壓棧,注意按照C語言函數參數從右往左的順序壓棧。即先壓棧b,後搞a。

    之後直接調用即可,CPU會自動把返回地址壓棧,然後控制權移交C語言函數,之後就是C語言函數自動取參數,你就不用管了。【其實C語言函數所做的就是8(%ebp)取出堆棧中壓入的a的地址(我們壓棧的是地址),然後再12(%ebp)取出堆棧中壓入的b的地址,然後開始運算換值。。。不神祕】


    講完了,一開始被printf無輸出糾結了一會兒,不過以前學過Linux下C語言編程,還專門研究過緩衝區問題。

    ​編譯過程如下:





    之後可以用GDB調試下。【此處沒輸出"output??",因爲我沒有清空緩衝區!】

    ​就這些。

    ​有問題歡迎討論。


發佈了51 篇原創文章 · 獲贊 14 · 訪問量 11萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章