日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

匯編使用堆棧傳參是子程序獲取參數(shù)的寫法

 zhouADNjj 2014-04-29

程序加載后堆棧情況: ss為堆棧的首地址, sp為堆棧的長度,當(dāng)sp=0時堆棧滿;入棧時向低地址伸展(sp先減2再寫值),出棧時向高地址伸展。

 

使用bp寄存器

 

bp為基址寄存器,一般在函數(shù)中用來保存進入函數(shù)時的sp的棧頂基址
sp是棧頂指針,它每次指向棧頂。
每次子函數(shù)調(diào)用時,系統(tǒng)在開始時都會保存這個兩個指針并在函數(shù)結(jié)束時恢復(fù)sp和bp的值。像下面這樣:
在函數(shù)進入時:
push bp  //保存bp指針
mov bp,sp //將sp指針傳給bp,此時bp指向sp的基地址。這個時候,如果該函數(shù)有參數(shù),則[bp]是原先bp的值,[bp+2]是調(diào)用前下一條指令地址(ip的值),[bp+4]則是該子函數(shù)的第一個參數(shù),[bp+6]則是該子函數(shù)的第二個參數(shù),以此類推,有多少個參數(shù)則[bp+4+2^n]。以上是近調(diào)用的情況,如果是遠調(diào)用(調(diào)用時cs先入棧,ip后入棧),則[bp+2]是ip的值,[bp+4]是cs的值,[bp+6]是第一個參數(shù)的值,依此類推。(注意,調(diào)用時應(yīng)當(dāng)是最后一個參數(shù)先壓棧)
.....
.....
函數(shù)結(jié)束時:
mov sp,bp //將原sp指針傳回給sp
pop bp  //恢復(fù)原bp的值。
ret  //退出子函數(shù) 

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多