iOS之底層匯編(五)

編寫一個(gè)完整的匯編語言

  • 匯編語言由2類指令組成

    assume cs:code
    code segment
      mov ax,1122H
      mov bx,3344H
      add ax,bx
    
      mov ah,4cH
      int 21H
    code ends
    end
    
    • 匯編指令
      如mov龙填、add骗奖、sub等
      有對(duì)應(yīng)的機(jī)器指令,可以被編譯為機(jī)器指令,最終被CPU執(zhí)行
    • 偽指令
      如assume、segment访敌、ends翩伪、end等
      沒有對(duì)應(yīng)的機(jī)器指令,由編譯器解析戒职,最終不被CPU執(zhí)行
  • 注釋以分號(hào)開頭


    匯編注釋

偽指令 - segment,ends透乾,end

assume cs:code
code segment
  mov ax,1122H
  mov bx,3344H
  add ax,bx

  mov ah,4cH
  int 21H
code ends
end
  • segment和ends的作用是定義一個(gè)段洪燥,segment代表一個(gè)段的開始,ends代表一個(gè)段的結(jié)束乳乌,使用格式為
段名 segment
     :
段名 ends
  • 一個(gè)有意義的匯編程序中捧韵,至少要有一個(gè)段作為代碼段存放代碼
  • assume
    • 將用作代碼段的code段和CPU中的CS寄存器關(guān)聯(lián)起來
  • end
    • 編譯遇到end是,就結(jié)束對(duì)源程序的編譯
  • 下面2句代碼的作用是退出程序
mov ah,4cH
int 21H
  • 也可以寫成
mov ax,4c00H
int 21H

中斷

  • 中斷
    • 中斷是由于軟件的或硬件的信號(hào)汉操,使得CPU暫停當(dāng)前的任務(wù)再来,轉(zhuǎn)而去執(zhí)行另一段子程序
      -也就是說,在程序運(yùn)行過程中磷瘤,系統(tǒng)出現(xiàn)了一個(gè)必須由CPU立即處理的情況芒篷,此時(shí),CPU暫時(shí)終止當(dāng)前程序的執(zhí)行轉(zhuǎn)而處理這個(gè)新事件的過程就叫做中斷
  • 中斷的分類
    • 硬中斷(外中斷)采缚,由外部設(shè)備(比如網(wǎng)卡针炉、硬盤)隨機(jī)引發(fā)的,比如當(dāng)前網(wǎng)卡收到數(shù)據(jù)包的時(shí)候扳抽,就會(huì)發(fā)出一個(gè)中斷
    • 軟中斷(內(nèi)中斷)篡帕,由執(zhí)行中斷指令產(chǎn)生的,可以通過程序控制觸發(fā)

從本質(zhì)上來講摔蓝,中斷是一種電信號(hào)赂苗,當(dāng)設(shè)備有某種事件發(fā)生時(shí),它就會(huì)產(chǎn)生中斷贮尉,通過總線把電信號(hào)發(fā)送給中斷控制器拌滋。如果中斷的線是激活的,中斷控制器就把電信號(hào)發(fā)送給處理器的某個(gè)特定引腳猜谚。處理器于是立即停止自己正在做的事败砂,跳到中斷程序的入口點(diǎn),進(jìn)行中斷處理魏铅。

中斷過程
  • 可以通過int n產(chǎn)生中斷
    • n是中斷碼昌犹,內(nèi)存中有一張中斷向量表,用來存放中斷碼對(duì)應(yīng)的中斷處理程序的入口地址
    • CPU在接收到中斷信號(hào)后览芳,暫停當(dāng)前正在執(zhí)行的程序斜姥,跳轉(zhuǎn)到中斷碼對(duì)應(yīng)的中斷向量表地址處,去執(zhí)行中斷處理程序
  • 常見中斷(中斷向量表)
    • int 10H用于執(zhí)行BIOS中斷
    • int 3是"斷點(diǎn)中斷",用于調(diào)試程序
    • int 21H用于執(zhí)行DOS系統(tǒng)功能調(diào)用铸敏,AH寄存器存儲(chǔ)功能號(hào)

DOS系統(tǒng)功能調(diào)用

  • DOS系統(tǒng)功能調(diào)用
    • 由DOS提供的一組實(shí)現(xiàn)特殊功能的子程序供程序員在編寫自己的程序時(shí)調(diào)用缚忧,以減輕編程的工作量
    • 涉及屏幕顯示、文件管理杈笔、I/O管理等等
    • 每個(gè)子程序 都有一個(gè)功能號(hào)闪水,所有的功能調(diào)用的格式都是一致的。調(diào)用的步驟大致如下
      • 系統(tǒng)功能號(hào)送到寄存器AH中
      • 入口參數(shù)送到指定的寄存器中
      • 用int 21H指令執(zhí)行功能調(diào)用
      • 根據(jù)出口參數(shù)分析功能調(diào)用執(zhí)行情況
;----數(shù)據(jù)段----
data segment
    string db 'Hello World!$'
data ends
mov ax,data
mov ds,ax   ;設(shè)置ds為數(shù)據(jù)段

mov ah,9H   ;功能號(hào)9H代表在屏幕顯示字符串
mov dx,offset string   ;ds:  dx代表字符串地址
int 21H  ;執(zhí)行DOS系統(tǒng)功能調(diào)用

emu8086常用快捷鍵

  • F5:調(diào)試運(yùn)行
  • F4:重新加載
  • F8:下一步(單步執(zhí)行)
  • F9:直接一步到位運(yùn)行整個(gè)程序
  • Ctrl + F8:跳過前面代碼蒙具,斷點(diǎn)到單擊選中的代碼那行



最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末球榆,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子禁筏,更是在濱河造成了極大的恐慌持钉,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件篱昔,死亡現(xiàn)場離奇詭異右钾,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)旱爆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來窘茁,“玉大人怀伦,你說我怎么就攤上這事∩搅郑” “怎么了房待?”我有些...
    開封第一講書人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長驼抹。 經(jīng)常有香客問我桑孩,道長,這世上最難降的妖魔是什么框冀? 我笑而不...
    開封第一講書人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任流椒,我火速辦了婚禮,結(jié)果婚禮上明也,老公的妹妹穿的比我還像新娘宣虾。我一直安慰自己,他們只是感情好温数,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開白布绣硝。 她就那樣靜靜地躺著,像睡著了一般撑刺。 火紅的嫁衣襯著肌膚如雪鹉胖。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評(píng)論 1 297
  • 那天,我揣著相機(jī)與錄音甫菠,去河邊找鬼挠铲。 笑死,一個(gè)胖子當(dāng)著我的面吹牛淑蔚,可吹牛的內(nèi)容都是我干的市殷。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼刹衫,長吁一口氣:“原來是場噩夢啊……” “哼醋寝!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起带迟,我...
    開封第一講書人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤音羞,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后仓犬,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體嗅绰,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年搀继,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了窘面。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡叽躯,死狀恐怖财边,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情点骑,我是刑警寧澤酣难,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站黑滴,受9級(jí)特大地震影響憨募,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜袁辈,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一菜谣、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧吵瞻,春花似錦葛菇、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至卿泽,卻和暖如春莺债,著一層夾襖步出監(jiān)牢的瞬間滋觉,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來泰國打工齐邦, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留椎侠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓措拇,卻偏偏與公主長得像我纪,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子丐吓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

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

  • 8086匯編 本筆記是筆者觀看小甲魚老師(魚C論壇)《零基礎(chǔ)入門學(xué)習(xí)匯編語言》系列視頻的筆記稚新,在此感謝他和像他一樣...
    Gibbs基閱讀 37,184評(píng)論 8 114
  • 王爽匯編全書知識(shí)點(diǎn)大綱 第一章 基礎(chǔ)知識(shí) 機(jī)器語言 匯編語言的產(chǎn)生 匯編語言的組成 存儲(chǔ)器 cpu對(duì)存儲(chǔ)器的讀寫 ...
    2c3ba901516f閱讀 2,417評(píng)論 0 1
  • 編寫一個(gè)完整的匯編 匯編語言由2類指令組成assume cs:codecode segmentmov ax,112...
    Stone_熊小叔閱讀 259評(píng)論 0 0
  • 為人父母應(yīng): 一是心態(tài)從容勘伺,心從不在憤怒中停留。不以物喜褂删,不以己悲娇昙。 二是懂得生活,在簡單事物中發(fā)現(xiàn)體味幸福笤妙,并懂...
    201701閱讀 137評(píng)論 0 0
  • 高績效來自于高頻率的計(jì)劃、執(zhí)行和評(píng)估反饋噪裕。 既然稱之為目標(biāo)和關(guān)鍵結(jié)果蹲盘,就意味著既關(guān)鍵又重要,數(shù)量應(yīng)該很有限膳音,且不包...
    kafkaliu閱讀 190評(píng)論 0 0