1偷遗、Floating Point Register
1墩瞳、v0~v31 128位向量寄存器
2、d0~d31 64位double寄存器
3氏豌、s0~s31 32位float寄存器
4喉酌、fpsr 浮點狀態(tài)寄存器
5、fpcr 浮點控制寄存器
2箩溃、General Purpose Registers
1瞭吃、x0~x28 64位地址寄存器
2、w0~w28 32位地址寄存器
3涣旨、sp 棧頂寄存器歪架,(寫數(shù)據(jù)是往高地址寫入數(shù)據(jù))
4、fp(x29) 棧底寄存器
5霹陡、pc 存儲下一條即將執(zhí)行的指令
6和蚪、lr 通常稱X30為程序鏈接寄存器,保存跳轉(zhuǎn)返回信息地址
7烹棉、cpsr 狀態(tài)寄存器
(1)攒霹、 0 -7低八位是控制為,8-27是保留位浆洗,28催束、29、30伏社、31(v抠刺、c塔淤、z、n)條件碼標志
1)速妖、N位標識位
記錄相關指令執(zhí)行后高蜂,其結(jié)果是否為負,如果為負 N = 1,如果為非負N = 0
2)罕容、Z標志位
記錄相關指令執(zhí)行后的备恤,其結(jié)果是否為0,如果為0锦秒,那么Z=1露泊,如果為1,那么Z=0
3)旅择、C標志位
進位標志位滤淳,一般情況下進行無符號運算。
加法運行:當運算結(jié)果產(chǎn)生了進位時(無符號數(shù)溢出)砌左,則C=1,否則C=0
減法運算(包括CMP):當運算時產(chǎn)生了錯位時(無符號數(shù)溢出),C=0否則C=1
4)铺敌、V溢出標志
在進行有符號運算的時候汇歹,如果超出了機器所能標志的范圍,稱之為溢出
3匯編指令
1偿凭、bl 將下一條指令的地址放入lr(x30)寄存器产弹,轉(zhuǎn)到標號處執(zhí)行指令
2、ret 默認使用lr(x30)寄存器的值,通過底層指令提示CPU此處作為下條指令地址!
3弯囊、str 從寄存器往內(nèi)存讀數(shù)據(jù)
4痰哨、ldr 從內(nèi)存往寄存器寫數(shù)據(jù)
5、ldp/stp 是 ldr/str 的衍生, 可以同時讀/寫兩個寄存器, ldr/str只能讀寫一個
6匾嘱、sdrp 取字符串常量
7斤斧、b.ne帶條件的跳轉(zhuǎn)
8、adrp (Address page)地址分頁
9霎烙、b.le 如果小于等于 跳轉(zhuǎn)當前地址撬讽。
10、b.hi 無符號大于等于
11悬垃、cmp 比較
12游昼、br x9 根據(jù)寄存器里的值進行跳轉(zhuǎn)。
4相關語法
stp x29,x30,[sp,#-0x10]! // 相當于 sub sp,sp,#0x10 str x29,x30,[sp]
ldp x29,x30,[sp],#0x10 // 相當于 ldr x29,x30,[sp] add sp,sp,0x10
adrp x0,1 // 一尝蠕、將1的值左移12位(1000)烘豌,二、在將pc寄存器的低12位清理看彼,三廊佩、將第一步和第二部的結(jié)果相加賦值給x0
ubfx x9,x9,#0,#32 將x9寄存器從第零位到32取出來放到x9寄存器囚聚,其余位用0補齊(高32位清零)。
5函數(shù)參數(shù)
1罐寨、arm64中靡挥,參數(shù)存放在x0~x7的八個寄存器中
2、如果是浮點就會用浮點寄存器
3鸯绿、如果超過8個就會用棧傳遞
4跋破、函數(shù)返回值,默認情況下函數(shù)的返回值放在x0寄存器中瓶蝴,如果放不下就會利用內(nèi)存毒返。寫入上一個調(diào)用棧的內(nèi)部,用x8寄存器作為參照舷手。
6函數(shù)的返回值
1拧簸、函數(shù)的返回值一般用x0寄存器保存
2、如果返回值大于8個字節(jié)男窟,就會利用內(nèi)存?zhèn)鬟f返回值
7內(nèi)存分區(qū)
1盆赤、代碼區(qū):存放代碼,可讀歉眷,可執(zhí)行
2牺六、棧區(qū):參數(shù)、局部變量汗捡、臨時數(shù)據(jù)
3淑际、堆區(qū):動態(tài)申請,可讀扇住、可寫
4春缕、全局變量:可讀、可寫
5艘蹋、常量:只讀