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

首頁 > 系統 > iOS > 正文

使用ARM匯編破解iOS程序基礎知識分享

2020-07-26 03:32:29
字體:
來源:轉載
供稿:網友

一、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),棧幀寄存器就不再解釋,寄存器存儲區:保存非易失寄存器(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個字節;

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

  第四行:給當前函數開辟??臻g。

  函數返回(恢復現場):

  1)釋放??臻g;

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

  3)恢復R7;

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

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

  第一行:釋放??臻g;

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日韩欧美影视| 国产视频福利一区| 丝袜美腿亚洲一区二区| 性欧美在线看片a免费观看| 国产精品永久免费视频| 亚洲精品电影在线| 成人免费直播live| 91久久精品美女| 欧美日韩国产二区| 国产日韩欧美在线观看| 国外视频精品毛片| 亚洲精品国偷自产在线99热| 在线观看成人黄色| 色爱精品视频一区| 欧美做受高潮1| 日韩精品免费在线| 九九热视频这里只有精品| 成人激情视频网| 亚洲成人激情在线观看| 欧美激情视频一区二区三区不卡| 日韩欧中文字幕| 国产精品视频26uuu| 欧美黑人性视频| 欧美激情视频播放| 亚洲国产欧美一区| 国产亚洲免费的视频看| 亚洲精品国产精品乱码不99按摩| 成人在线视频福利| 国产精品va在线播放| 日韩国产在线播放| 国产精品一区二区3区| 亚洲精品乱码久久久久久金桔影视| 日韩欧美精品中文字幕| 国产精品久久久久久久久久东京| 北条麻妃一区二区三区中文字幕| 欧美视频中文字幕在线| 欧美亚洲日本网站| 欧美激情在线狂野欧美精品| 亚洲精品成人久久电影| 亚洲一区二区黄| 亚洲va久久久噜噜噜| 亚洲人成电影网站色…| 日韩av影视在线| 久久久久久久久亚洲| 中文日韩在线视频| xx视频.9999.com| 成人国产精品久久久久久亚洲| 麻豆乱码国产一区二区三区| 奇米四色中文综合久久| 91亚洲精品在线观看| 亚洲国产精品成人精品| 亚洲国产成人精品女人久久久| 久久久久一本一区二区青青蜜月| 国产视频久久久久久久| 日韩av男人的天堂| 神马久久久久久| 日韩精品极品在线观看播放免费视频| 亚洲精品日韩av| 一本色道久久88精品综合| 欧美疯狂xxxx大交乱88av| 久久久久久久久久久免费精品| 欧美亚洲午夜视频在线观看| 久久久久久久亚洲精品| 日韩精品中文字幕久久臀| 欧美日韩福利电影| 欧美成人高清视频| 韩国三级电影久久久久久| 欧美日韩精品在线视频| 影音先锋日韩有码| 久久久精品一区二区三区| 97久久久久久| 欧美在线视频一区二区| 久久综合国产精品台湾中文娱乐网| 亚洲少妇中文在线| 欧美日韩免费在线观看| 久久亚洲精品一区二区| 一区二区欧美久久| 亚洲一区二区自拍| 国产成人自拍视频在线观看| 国产精品高潮呻吟久久av野狼| 亚洲一区中文字幕| 96国产粉嫩美女| 丝袜亚洲另类欧美重口| 97视频在线观看播放| 亚洲高清一二三区| 国产精品久久久久免费a∨大胸| 日韩中文在线观看| 亚洲精品成人久久| 久久人人爽亚洲精品天堂| 岛国av一区二区| 97人洗澡人人免费公开视频碰碰碰| 久久成人亚洲精品| 色偷偷av亚洲男人的天堂| 日韩av一区二区在线| 国产精品青草久久久久福利99| 欧美性xxxxx| 欧美又大粗又爽又黄大片视频| 久久久久久com| 欧美一级大片在线免费观看| 久久久精品亚洲| 在线成人激情视频| 久久久久久亚洲精品中文字幕| 日韩精品中文字| 亚洲福利视频久久| 国产精品久久激情| 91久久精品国产91性色| 日韩在线视频导航| 最近2019中文字幕第三页视频| 国产日韩在线亚洲字幕中文| 精品国产一区av| xvideos成人免费中文版| 久久精品国产91精品亚洲| 美女黄色丝袜一区| 欧美日本中文字幕| 国产精品激情av电影在线观看| 少妇精69xxtheporn| 欧美成人午夜激情视频| 欧美电影在线观看高清| 久久久噜噜噜久久久| 亚洲精品成人久久| 久久99久国产精品黄毛片入口| 久久久av网站| 欧美亚洲另类制服自拍| 日韩精品极品在线观看播放免费视频| 欧美日韩免费看| 伊人青青综合网站| 午夜精品久久久久久久久久久久| 丝袜亚洲另类欧美重口| 国产精品jizz在线观看麻豆| 亚洲欧美国产另类| 激情av一区二区| 亚洲精品狠狠操| 亚洲在线第一页| 欧美日韩国产在线播放| 久久这里只有精品99| 亚洲区在线播放| 亚洲欧美日韩精品久久亚洲区| 欧洲中文字幕国产精品| 欧美老女人bb| 亚洲wwwav| 国产精品免费看久久久香蕉| 久久久噜噜噜久噜久久| 中文字幕一区日韩电影| 亚洲欧美精品一区二区| 亚洲人成网站在线播| 久久精品在线视频| 亚洲第一视频网站| 国产欧美精品一区二区三区-老狼| 在线日韩精品视频| 69**夜色精品国产69乱| 亚洲激情在线观看| 欧美孕妇孕交黑巨大网站| 国产日韩精品在线| 国产精品一二区| 国产成人97精品免费看片| 不卡av在线播放| 日韩中文av在线| 18久久久久久| 久久伊人精品天天| 欧美亚洲另类视频| 久久久久久久久久久av| 狠狠躁18三区二区一区| 亚洲人成电影网站色www| 色偷偷91综合久久噜噜|