亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > ASM > 正文

iOS程序破解——ARM匯編基礎

2019-11-14 17:58:02
字體:
來源:轉載
供稿:網友

  原文在此:http://www.49028c.com/mddblog/p/4951650.html

一、Thumb指令與ARM指令
  Thumb指令為16位,因此存儲代碼的密度高,節省存儲空間。但是功能不全,它只是ARM指令(32位)集的補充,是ARM指令集下的一個子集。在初級階段我們不需要了解這些知識,只要有個概念知道有這么個東西就可以。

二、ARM的寄存器初步了解

  R0-R3:        用于函數參數及返回值的傳遞,超過4個參數,其它參數存在棧中,在ARM中棧是向下生長的,R0還可以作為返回值。
  R4-R6, R8, R10-R11: 沒有特殊規定,就是普通的通用寄存器
  R7:          棧幀指針,指向母函數與被調用子函數在棧中的交界。
  R9:          在iOS3.0被操作系統保留
  R12:          內部過程調用寄存器,動態鏈接時會用到,不必深究
  R13:          SP(stack pointer),是棧頂指針
  R14:          LR(link register),存放函數的返回地址。
  R15:          PC(PRogram counter),指向當前指令地址。
  CPSR:         當前程序狀態寄存器,在用戶狀態下存放像condition標志中斷禁用等標志的。
  另外還有VFP(向量浮點運算)相關的寄存器,不在列舉。

三、常用匯編

  助記符  說明
  ADC    帶進位的加法
  ADD    加法
  AND    邏輯與
  B      分支跳轉,很少單獨使用
  BL          分支跳轉,跳轉后返回地址存入r14
  BX          分支跳轉,并切換指令模式(Thumb/ARM)
  CMP        比較值,結果存在程序狀態寄存器,一般用于分支判斷
  BEQ        結果為0則跳轉
  BNE        結果不為0跳轉
  LDR        加載寄存器,從內存加載到寄存器
  LDRB      裝載字節到寄存器
  LDRH      裝載半字到寄存器(一個字是32位)
  LSL         邏輯左移 這是一個選項,不是指令
  LSR         邏輯右移 這是一個選項,不是指令
  MOV        傳送值/寄存器到一個寄存器 
  STR         存儲一個寄存器,寄存器值存到內存
  STRB       存儲一個字節
  STRH       存儲一個半字
  SUB         減法
  PUSH POP 堆棧操作

  更多指令請參考這里

四、函數調用

  函數的參數、局部變量、返回地址都在棧上存著,這部分棧上的內存稱為棧幀。和R0~R15(不一定全部)、CPSR等一起構成了函數的運行環境。每一個函數系統都會分配一個棧幀,執行完成后系統自動收回。每個函數都以為R0~R15、CPSR等CPU相關寄存器為自己一人享有,所以要做一些必要操作。

  舉個例子:假設A調用B時,那么A要保存自己的運行環境(保存現場),B執行完后,要恢復A的運行環境(恢復現場);另外A還可以通過R0—R4來傳遞參數,參數超過4個可以通過棧,B返回時可以通過R0傳遞返回值。其中主要涉及的就是棧的操作和寄存器的操作。下圖為函數調用前后棧的布局,左邊為調用前,右邊為調用后,當B返回時應回到左邊狀態(A調用B之前的狀態,就像沒有調用B一樣)。

  在上圖中,一個棧幀除了已經提到的參數區域(parameter area)、鏈接區域(linkage area)、局部變量存儲區(local storage area)外還有棧幀指針存放區域(saved frame pointer)、寄存器存儲區(saved registers area),棧幀指針上面已介紹(R7);寄存器存儲區:保存非易失寄存器(R4,R5,R6,R8,R10,R11),后面的匯編代碼例子會介紹。

  開始調用(現場保護):

  1)LR入棧;

  2)R7入棧,包存要恢復的寄存器入棧;

  3)R7 = SP地址;

  4)將callee會修改且在返回caller時需要恢復的寄存器入棧;

  5)分配??臻g給子程序使用。

  下圖為匯編代碼(使用hopper disassemble反編譯的代碼),分析如下:

  第一行:將LR, R7, R4-R6入棧;

  第二行:r7=sp-0xc(指向old R7),之所以減去0xc因為PUSH后,r4,r5,r6占去12個字節;

  第三行:保存要恢復的寄存器;

  第四行:給當前函數開辟棧空間。

  函數返回(恢復現場):

  1)釋放棧空間;

  2)恢復所保存的寄存器;

  3)恢復R7;

  4)將之前存放的LR從棧上彈出到PC,這樣函數就返回了。

  下圖為匯編代碼(使用hopper disassemble反編譯的代碼),分析如下:

  第一行:釋放??臻g;

  第二行:恢復保存的寄存器;

  第三行:恢復保存的寄存器,恢復R7,將之前存放的LR從棧上彈出到PC。

  更詳細函數調用請參考這里

  iOS內存分區請參考這里

 

 

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲图片制服诱惑| 久久免费视频在线| 亚洲第一页在线| 欧美大肥婆大肥bbbbb| 欧美激情视频播放| 日韩av有码在线| 日韩av色综合| 国产精品视频一区二区三区四| 久久久久久免费精品| 亚洲欧美综合图区| 亚洲电影免费观看高清完整版| 亚洲黄一区二区| 欧美性黄网官网| 日本高清视频一区| 性色av一区二区三区| 高清视频欧美一级| 日韩欧美精品在线观看| 国产日韩欧美视频| 国产不卡av在线免费观看| 国产精品91一区| 91国内精品久久| 欧美午夜精品伦理| 91po在线观看91精品国产性色| 91久久国产综合久久91精品网站| 精品久久久91| 日本一区二区三区在线播放| 欧美激情aaaa| 国产精品欧美日韩久久| 亚洲最新中文字幕| 欧美日韩xxx| 国自产精品手机在线观看视频| 中文字幕精品—区二区| 欧美性猛交99久久久久99按摩| 97在线看免费观看视频在线观看| 国产一区二区丝袜高跟鞋图片| 精品久久久久久久久久久久久久| 久久久亚洲福利精品午夜| 日韩成人在线网站| 91久久在线视频| 在线观看欧美视频| 欧美黑人xxx| 亚洲高清色综合| 日日噜噜噜夜夜爽亚洲精品| 亚洲第一福利在线观看| 欧美午夜精品久久久久久浪潮| 午夜精品一区二区三区在线视频| 精品中文字幕在线2019| 日本在线观看天堂男亚洲| 色无极亚洲影院| 国产精品三级在线| 日韩成人激情在线| 国产精品久久久久久久久免费看| 欧美精品videos另类日本| 亚洲乱码av中文一区二区| 91社影院在线观看| 国产成人拍精品视频午夜网站| 欧美日韩激情视频8区| 国产精品国产三级国产aⅴ浪潮| 国产精品白嫩美女在线观看| 韩国三级日本三级少妇99| 深夜成人在线观看| 亚洲精品动漫100p| 欧美在线国产精品| 成人av电影天堂| 国产深夜精品福利| 91影院在线免费观看视频| 欧美性极品xxxx做受| 久久久亚洲成人| 亚洲欧美国产精品专区久久| 色青青草原桃花久久综合| 欧美日韩亚洲视频| 亚洲成人三级在线| 精品国产乱码久久久久久虫虫漫画| 亚洲欧洲xxxx| 国产91精品高潮白浆喷水| 日韩欧美在线中文字幕| 中文字幕免费精品一区| 国内精品伊人久久| 欧美国产日韩精品| 国产亚洲精品久久久久动| 成人久久18免费网站图片| 久久影视三级福利片| 国产69精品久久久久久| 欧美日韩中文字幕在线| 成人h视频在线观看播放| 亚洲免费电影在线观看| 97精品国产97久久久久久免费| 2019中文字幕免费视频| 亚洲欧美中文字幕在线一区| 欧美性理论片在线观看片免费| 日韩大陆毛片av| 91精品久久久久久久久| 亚洲第一精品夜夜躁人人躁| 2019中文字幕全在线观看| 亚洲国产成人久久综合一区| 国产成人精彩在线视频九色| 日韩欧美精品网站| 亚洲精品国产精品久久清纯直播| 亚洲欧美精品在线| 全亚洲最色的网站在线观看| 欧美日韩国产激情| 国产69精品久久久久9| 日韩三级成人av网| 黄色精品在线看| 91国内揄拍国内精品对白| 日韩美女毛茸茸| 成人黄色免费看| 一区二区三区国产在线观看| 亚洲美女自拍视频| 国产精品成人一区二区三区吃奶| 亚洲网站视频福利| 神马国产精品影院av| 91精品国产91| 精品亚洲国产成av人片传媒| 亚洲国产欧美精品| 中文字幕久热精品在线视频| 日韩av快播网址| 九九精品视频在线| 成人黄色午夜影院| 亚洲精品久久久久国产| 亚洲女人被黑人巨大进入al| 成人免费视频在线观看超级碰| 国产亚洲精品久久久| 国内精品久久久久影院 日本资源| 91av视频在线| 久久久亚洲国产天美传媒修理工| 久久青草福利网站| 日韩精品www| 日韩中文字幕视频在线观看| 岛国av一区二区在线在线观看| 中文字幕免费精品一区高清| 国产欧美精品一区二区| 日韩中文理论片| 久久久国产视频91| 欧美性生交大片免费| 久久99国产精品久久久久久久久| 欧美另类第一页| 91av在线精品| 欧美精品在线免费观看| 国产成人一区二区三区电影| 狠狠躁夜夜躁人人爽超碰91| 久久精品成人欧美大片古装| 欧美日在线观看| 欧美精品精品精品精品免费| 国产精品成人免费电影| 精品久久久久久久久久ntr影视| 欧美日本在线视频中文字字幕| 久久久精品美女| 亚洲精品一区在线观看香蕉| 国产精品一区专区欧美日韩| 亚洲人成在线免费观看| 欧美国产精品人人做人人爱| 爽爽爽爽爽爽爽成人免费观看| 成人激情春色网| 亚洲人高潮女人毛茸茸| 色综合天天狠天天透天天伊人| 亚洲小视频在线观看| 91社区国产高清| 久久精品99久久久久久久久| 国产亚洲日本欧美韩国| 免费97视频在线精品国自产拍| 国产精品人成电影| 成人在线视频福利| 午夜免费日韩视频|