arm 簡單匯編

1错负、尋址方式:

mov r0, #1234

相當(dāng)于:r0=#1234刽酱。#開頭呻逆,表示16進(jìn)制時(shí),以0x開頭弥咪,如#0x1f。

mov r0, r1

執(zhí)行后十绑,r0 = r1聚至。

LSL:邏輯左移,移位后寄存器空出的低位補(bǔ)0本橙;

LSR:邏輯右移扳躬,移位后寄存器空出的高位補(bǔ)0;

ASR:算數(shù)右移甚亭,移位過程中贷币,符號(hào)位保存不變,如果源操作數(shù)為正數(shù)亏狰,則移位后空出的高位補(bǔ)0役纹,否則補(bǔ)1。

ROR:循環(huán)右移暇唾,移位后字管,移出的低位,填入移位空出的高位信不。

RRX:帶擴(kuò)展的循環(huán)右移嘲叔,操作數(shù)右移一位,移位空出的高位抽活,用C標(biāo)志的值填充硫戈。

mov r0, r1, lsl #2

相當(dāng)于:r0 = r1<<2 = r1*4。

ldr r0, [r1]? ? // 取值

相當(dāng)于:r0 = *r1下硕。

2丁逝、寄存器

ARM 有16個(gè)寄存器:

- r0-r3 主要用來傳遞函數(shù)調(diào)用第1到第4個(gè)參數(shù)(a0-a3)汁胆,更多的參數(shù)須通過棧來傳遞。

- r0-r1 也作為結(jié)果寄存器霜幼,保存函數(shù)返回結(jié)果嫩码;被調(diào)用的子程序在返回前無須恢復(fù)這些寄存器的內(nèi)容。

- r4-r9 為被調(diào)保存(callee-save)寄存器罪既,一般保存內(nèi)部局部變量(local variables)铸题。

- r7 大部分情況用來保存系統(tǒng)調(diào)用號(hào)(syscall number)。

- r9 某些變體可能當(dāng)作特殊寄存器琢感。

- r10(SL)被調(diào)保存寄存器丢间,Stack Limit。

- r11(FP)被調(diào)保存寄存器驹针, 幀指針(Flame Pointer)烘挫。

- r12(IP)特殊寄存器,棧寄存器(Intra Procedure)柬甥。

- r13(SP)特殊寄存器饮六,棧指針,類似x86_64中的RSP苛蒲。

- r14(LR)特殊寄存器喜滨。Link Register.

- r15(PC)特殊寄存器。Program Counter (like RIP in x86_64 & EIP in x86).

被調(diào)保存寄存器(callee-save register)是指撤防,如果這個(gè)寄存器被調(diào)用/使用之前虽风,需要被保存。

值得注意的是寄月,通常 ARM 模式下 r11 會(huì)作為幀指針辜膝,THUMB 模式下 r7 則作為幀指針。但在系統(tǒng)有可能根據(jù)自己的需要改變這個(gè)約定漾肮。

然后說明下厂抖,LR 或 Link Register(鏈接寄存器),這個(gè)寄存器會(huì)保存一個(gè)子程序(subroutine/函數(shù))的返回值克懊。當(dāng)一個(gè)子程序被調(diào)用時(shí)忱辅,LR 會(huì)被填入程序計(jì)數(shù)器(PC)。

還有 PC 寄存器谭溉,該寄存器或保存目前正在執(zhí)行的內(nèi)存地址墙懂。

PC 和 LR 都是跟代碼有關(guān)的寄存器,一個(gè)是 Where you are扮念,另外一個(gè)是 Where you were损搬。

再者,SP 寄存器,該寄存器指向棧頂巧勤。該棧是一塊用來存儲(chǔ)本地函數(shù)的內(nèi)存區(qū)域嵌灰。當(dāng)函數(shù)被返回時(shí), 存儲(chǔ)空間會(huì)被回收颅悉。

在堆棧上分配空間, 需要從棧寄存器(the stack register)減去沽瞭。

分配一個(gè)32位的值, 需要從堆棧指針(the stack pointer)減去4。

ARM堆棧結(jié)構(gòu)是從高向低壓棧的剩瓶。

因?yàn)樘幚砥魇?2位的ARM驹溃,所以每壓一次棧,SP就會(huì)移動(dòng)4個(gè)字節(jié)(32位)儒搭,也就是sp = sp-4。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末芙贫,一起剝皮案震驚了整個(gè)濱河市搂鲫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌磺平,老刑警劉巖魂仍,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異拣挪,居然都是意外死亡擦酌,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門菠劝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來赊舶,“玉大人,你說我怎么就攤上這事赶诊×剑” “怎么了?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵舔痪,是天一觀的道長寓调。 經(jīng)常有香客問我,道長锄码,這世上最難降的妖魔是什么夺英? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮滋捶,結(jié)果婚禮上痛悯,老公的妹妹穿的比我還像新娘。我一直安慰自己重窟,他們只是感情好灸蟆,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般炒考。 火紅的嫁衣襯著肌膚如雪可缚。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天斋枢,我揣著相機(jī)與錄音帘靡,去河邊找鬼。 笑死瓤帚,一個(gè)胖子當(dāng)著我的面吹牛描姚,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播戈次,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼轩勘,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了怯邪?” 一聲冷哼從身側(cè)響起绊寻,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎悬秉,沒想到半個(gè)月后澄步,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡和泌,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年村缸,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片武氓。...
    茶點(diǎn)故事閱讀 39,981評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡梯皿,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出县恕,到底是詐尸還是另有隱情索烹,我是刑警寧澤,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布弱睦,位于F島的核電站百姓,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏况木。R本人自食惡果不足惜垒拢,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望火惊。 院中可真熱鬧求类,春花似錦、人聲如沸屹耐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至寿弱,卻和暖如春犯眠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背症革。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工筐咧, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人噪矛。 一個(gè)月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓量蕊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親艇挨。 傳聞我的和親對象是個(gè)殘疾皇子残炮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容