小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

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

 zhouADNjj 2014-04-29

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

 

使用bp寄存器

 

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

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

    0條評(píng)論

    發(fā)表

    請遵守用戶 評(píng)論公約

    類似文章 更多