国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 編程 > ASM > 正文

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

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

  原文在此:http://www.56wlw.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)分配棧空間給子程序使用。

  下圖為匯編代碼(使用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反編譯的代碼),分析如下:

  第一行:釋放棧空間;

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

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

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

  iOS內存分區請參考這里

 

 

 


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

圖片精選

国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产精品伦理一区二区三区| 在线中文字幕视频| 亚洲视频在线观看不卡| 国产黄色免费| 精品国产一区二区三区四区阿崩| 国产精品欧美色图| 在线免费观看你懂的| h视频在线网站| 国产主播福利在线| 尤物网址在线观看| 伊人春色在线| 国产免费黄网站| 精品一区二区在线欧美| 96久久久久久| 国产中文在线观看| 精品无吗乱吗av国产爱色| 久久久久久久久久久久网站| 国产性一级片| 九九在线视频| 97视频网站| 国产小视频免费在线观看| 精品一区二区三区免费站| 欧美亚洲天堂| 精品一区二区三区在线成人| 福利视频在线导航| 天天激情综合| 在线亚洲精品自拍| 国产精品粉嫩av| 超碰在线观看免费版| 国产福利三区| 国产一区二区影视| 国产农村一级特黄α**毛片| 在线激情小视频| 国产精品久久在线| 国产写真视频在线观看| 国产在线麻豆精品| 欧美一级久久久久久久久大| 亚洲精品男人| 小说区乱图片区| 91麻豆福利| 精品入口麻豆传煤| 91九色在线看| 在线成人综合色一区| 国产精品18久久久久久久久久 | 国产一二三区在线| 久久99国产视频| 黄色毛片在线| 日本中文字幕高清视频| 免费中文字幕| 国产麻豆精品视频一区二区| 国产在线资源| 中文字幕在线第一页| 国产一二区视频| 91高清国产| 日本免费视频www| 黄网站在线观看高清免费| а√天堂8资源在线官网| 青青久草在线| 国产香蕉在线| 99色在线观看| 亚洲高清在线免费| 久草电影在线| 国产视频中文字幕| 国产精品免费视频二三区| 精品入口麻豆传煤| а√最新版地址在线天堂| 久草在线资源福利| 97最新国自产拍视频在线完整在线看| 夜夜操天天干| 国产中文在线视频| 999福利在线视频| 在线播放国产区| 国产理论电影在线观看| 91看片在线观看| 日本中文字幕在线看| av亚洲男人天堂| 国产一级影片| 日本高清中文字幕二区在线| 国产视频二区| 久久精品最新免费国产成人| 国产福利免费在线观看| 黄色av免费在线| 在线成人综合色一区| 国产激情自拍视频| 天堂在线看视频| 蜜桃视频中文字幕| 中文岛国精品亚洲一区| 中文字幕乱在线伦视频乱在线伦视频| 中文在线观看视频| 国产丝袜精品丝袜| 中文字幕国产欧美| 国产精选一区二区三区不卡催乳| 精灵使的剑舞无删减版在线观看| 国产免费av网站| 日本三级在线视频| 中文字幕2019第三页| 91美女主播在线视频| 国产小视频在线高清播放| 激情亚洲综合网| 国产在线更新| 久久久久久久美女| 亚洲欧美一区二区三区在线播放| 国产视频中文字幕| 国产女主播在线| 国产对白国语对白| 国产性网软件大全| 国产精品剧情一区二区在线观看| 国产小视频在线高清播放| 91福利在线免费| 国产三级自拍| 国产成人综合美国十次| 国产高清在线视频| av网址在线看| 成视频年人免费看黄网站| 国产中文在线观看| 天天操天天射天天插| 国产一区二区三区四区尤物| 国产欧美黑人| 日韩国产成人| 天堂在线免费av| 精品久久亚洲一级α| 午夜影院免费| 国产美女性感在线观看懂色av| 久草.com| 国产精品美女一区二区视频| 992tv在线观看在线播放| xxx国产精品| 国产小视频在线播放| 亚洲成人福利| 九九热免费在线视频| 国产三级视频在线看| 中文av资源在线| 高潮毛片在线观看| 亚洲精品在线播放视频| 天堂在线亚洲| 亚洲videos| 国产精品视频白浆合集| 日本成a人片在线观看| 国产一卡2卡3卡免费网站| 亚洲欧美国产另类首页| 国产亚洲精品自在线观看| 青草视频在线播放| 国产青青视频| 国产免费网址| 免费观看久久久久| 国产黄色片在线观看| 亚洲成人电视网| 国产黄色片中文字幕| 白浆爆出在线观看| 亚洲网站视频在线观看| 精品国语对白精品自拍视| 国产乱视频在线观看| 日本三级视频网站| 一个人看的www免费观看视频| 国产激情视频网址| 国产欧美在线观看视频| 国产区高清在线| 国产污视频在线| 中文字幕在线观看播放| 九九视频精品在线| 国产在线二区| 超碰免费在线播放| 欧美精品久久久久久久小说| 亚洲男人的天堂成人| 亚洲综合激情六月婷婷在线观看 | 国产系列在线观看| 成人欧美精品久久久久影院| 日本动漫同人动漫在线观看| 亚洲男人的天堂成人| 日本一本久久| 九九热免费视频| 国产偷倩在线播放| 国产高清在线看| 伊人影院在线视频| 精品欧美日韩一区二区| 中文字幕日本三级| 国产亚洲依依| 97一区二区三区| 天天草天天草| 国产女人在线观看| 999精品网| 黄色国产网站在线观看| 国产一二三在线观看| 国产香蕉视频在线看| 99热免费观看| 好男人免费精品视频| 国产极品嫩模在线视频一区| 亚洲一区免费在线| 中文字幕乱在线伦视频乱在线伦视频| 天堂在线视频| av中文在线| 国产精品蜜臀| 浪潮av一区| 精品卡一卡卡2卡3网站| 久久久久久日本一区99| 91最新在线| 国产精品欧美色图| 久久久久久久久免费视频| 91国内在线| 国产美女被草|