|簡體中文

比思論壇

 找回密碼
 按這成為會員
搜索



查看: 942|回復: 8
打印 上一主題 下一主題

Linux 汇编入门

[複製鏈接]

56

主題

0

好友

492

積分

中學生

Rank: 3Rank: 3

  • TA的每日心情
    擦汗
    2024-11-8 20:59
  • 簽到天數: 205 天

    [LV.7]常住居民III

    推廣值
    0
    貢獻值
    0
    金錢
    156
    威望
    492
    主題
    56
    樓主
    發表於 2014-7-18 20:35:12

    汇编语言是直接对应系统指令集的低级语言,在语言越来越抽象的今天,汇编语言并不像高级语言那样使用广泛,仅仅在驱动程序,嵌入式系统等对性能要求苛刻的领域才能见到它们的身影。但是这并不表示汇编语言就已经没有用武之地了,通过阅读汇编代码,有助于我们理解编译器的优化能力,并分析代码中隐含的低效率,所以能够阅读和理解汇编代码也是一项很重要的技能。因为我平时都是在linux环境下工作的,这篇文章就讲讲linux下的汇编语言。
    汇编语言分为intel风格和AT&T风格,前者被Microsoft Windows/Visual C++采用,Linux下,基本采用的是AT&T风格汇编,两者语法有很多不同的地方。
    1. 寄存器访问格式不同。在 AT&T 汇编格式中,寄存器名要加上 '%' 作为前缀;而在 Intel 汇编格式中,寄存器名不需要加前缀。例如:
    AT&T
    Intel
    pushl %eax
    push eax
    2. 立即数表示不同。在 AT&T 汇编格式中,用 '$' 前缀表示一个立即操作数;而在 Intel 汇编格式中,立即数的表示不用带任何前缀。例如:
    AT&T
    Intel
    pushl $1
    push 1
    3. 操作数顺序不同。在 Intel 汇编格式中,目标操作数在源操作数的左边;而在 AT&T 汇编格式中,目标操作数在源操作数的右边。例如:
    AT&T
    Intel
    addl $1, %eax
    add eax, 1
    4. 字长表示不同。在 AT&T 汇编格式中,操作数的字长由操作符的最后一个字母决定,后缀'b'、'w'、'l'分别表示操作数为byte、word和long;而在 Intel 汇编格式中,操作数的字长是用 "byte ptr" 和 "word ptr" 等前缀来表示的。例如:
    AT&T
    Intel

    movb val, %eax
    mov al, byte ptr val
    5. 寻址方式表示不同。在 AT&T 汇编格式中,内存操作数的寻址方式是
    section:disp(base, index, scale)
    而在 Intel 汇编格式中,内存操作数的寻址方式为:
    section:[base + index*scale + disp]
    由于 Linux 工作在保护模式下,用的是 32 位线性地址,所以在计算地址时不用考虑段基址和偏移量,而是采用如下的地址计算方法:
    disp + base + index * scale
    由此分为以下几种寻址方式:
    Intel
    AT&T
    内存直接寻址
    seg_reg: [base + index * scale + immed32]
    seg_reg: immed32 (base, index, scale)
    寄存器间接寻址
    [reg]
    (%reg)
    寄存器变址寻址
    [reg + _x]
    _x(%reg)
    立即数变址寻址
    [reg + 1]
    1(%reg)
    整数数组寻址
    [eax*4 + array]
    _array (,%eax, 4)


    無效樓層,該帖已經被刪除
    無效樓層,該帖已經被刪除
    無效樓層,該帖已經被刪除
    5#
    無效樓層,該帖已經被刪除
    6#
    無效樓層,該帖已經被刪除
    7#
    無效樓層,該帖已經被刪除
    8#
    無效樓層,該帖已經被刪除
    重要聲明:本論壇是以即時上載留言的方式運作,比思論壇對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,讀者及用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,讀者及用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本論壇受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者及用戶發現有留言出現問題,請聯絡我們比思論壇有權刪除任何留言及拒絕任何人士上載留言 (刪除前或不會作事先警告及通知 ),同時亦有不刪除留言的權利,如有任何爭議,管理員擁有最終的詮釋權。用戶切勿撰寫粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。

    手機版| 廣告聯繫

    GMT+8, 2024-11-16 06:37 , Processed in 0.026947 second(s), 26 queries , Gzip On.

    Powered by Discuz! X2.5

    © 2001-2012 Comsenz Inc.

    回頂部