我最近在 ubuntu 學習匯編,我發現了一些匯編,比如 NASM、MASM 和 GAS。它們的語法不同(尤其是偽指令),NASM 和 MASM 支持 Intel 語法,GAS 支持 AT&T 語法。
現在,我想學習 AT&T 匯編,所以,我使用 GAS 匯編,我找到了一系列關于 GAS 的手冊,但對我來說閱讀起來很痛苦,比如缺乏具體的例子或者只是簡單地介紹基本語法。
我找到了有代表性的部分“指南”:
- https://sourceware.org/binutils/docs/as.html
- https://en.wikibooks.org/wiki/X86_Assembly/GNU_assembly_syntax
- x86、win32 上空程式的 GCC 匯編輸出
- https://flint.cs.yale.edu/cs421/papers/x86-asm/asm.html
像這個例子https://sourceware.org/binutils/docs/as.html#Scl,我想知道storage-class value我們有什么?gccs-assembly-output-of-an-empty-program-on-x86-win32告訴我這.scl 2意味著外部存盤類,但我找不到關于這個值的任何其他內容。等等。
也許我在學習方向上錯了,或者我發現資訊的方式不對。所以我想問你有一些關于 AT&T 的指南或手冊,并為初學者提供示例和清晰的解釋。
我對偽指令感到困惑,標準匯編程式結構是什么樣的?
uj5u.com熱心網友回復:
在學習匯編時,您可以主要關注指令,.section和.globl指令。除非您嘗試了解 GAS 指令如何生成元資料,包括除錯資訊和其他對除錯高級語言比手寫 asm 更有用的東西。
許多除錯資訊指令顯然.scl只記錄了它們的語法,沒有關于值的含義或其他可能關心你放在那里的值的真正細節。
您幾乎可以只使用.section和.globl. (而對于靜態資料,/// 和.byte/用于.short初始化,在BSS 中,如果需要的話)。.long.quad.ascii.asciz.space.p2align
這就是為什么 Matt Godbolt 的“編譯器資源管理器”站點默認過濾掉指令,除了資料初始化器,因為當然資料在.dataor.rdata和代碼 in .text,關于編譯器 asm 輸出的有趣部分是實際指令(和靜態資料)。請參閱如何從 GCC/clang 程式集輸出中洗掉“噪音”?
完全符合 Windows 對用于堆疊展開的 SEH 元資料的期望(尤其是在 64 位代碼中)可能需要一些額外的指令,對于 x86-64 SysV.cfi堆疊展開元資料也是如此。但是,如果您需要在強大的生產質量環境中使用手寫 asm,而不是僅僅作為一次性實驗來學習指令如何作業,那么在您了解了組裝的基礎知識之后,您可以擔心這一點。
https://stackoverflow.com/tags/x86/info有一些教程(和手冊)鏈接,從頭開始編程是一本很好的免費書籍,適用于 32 位 x86 和 AT&T 語法。(和 GAS 指令)。它的目標是在 Linux 上運行,因此它可以沿途教授一些作業系統/計算概念,以及使匯編(和系統呼叫)有意義所需的那種背景知識。在線HTML版
要在現代 64 位 GNU/Linux 發行版上使用它,您可能需要as --32將ld -m elf_i386默認設定覆寫為 32 位。以及gcc -m32 -fno-pie -no-pie書中所說的任何地方gcc。
如果您正在比較有關 C 如何編譯的書籍示例,您可能還想-fno-stack-protector進一步簡化 C 的 asm 輸出。但請注意,不同的 GCC 版本會以不同的方式進行編譯,尤其是在多年來默認調整選項發生變化的情況下。 -mtune=pentium或者-mtune=pentium3也可能讓 GCC 選擇更像一本舊書的代碼生成策略。當然,現在的 GCC 的選擇也是正確的,更適合新的 CPU,只是和舊的 GCC 不同而已!
此外,Linux 上使用的 i386 SysV ABI 已更改為在指令之前需要 16 位元組堆疊對齊,這是call由于 GCC 不小心制作了 32 位代碼,例如使用movaps依賴于 GCC 選擇執行的性能優化的代碼。呼叫 libc 函式通常仍會在只有 4 位元組堆疊對齊的 32 位代碼中作業,但如果您看到現代 GCC 保留的空間超出其需要,這通常就是原因。
挑剔:
我找到了一些匯編程式,例如 NASM、MASM 和 GAS。它們的語法不同(尤其是偽指令),NASM 和 MASM 支持 Intel 語法,GAS 支持 AT&T 語法。
指令與指令語法正交,并且有不同風格的 Intel 語法,尤其是在 MASM 與 NASM 之間。(以及 MASM 和 NASM 指令之間的主要區別)。
此外,GAS 還支持.intel_syntax noprefix使用類似于 MASM 的指令語法,但仍支持 GAS 指令。
(同樣,YASM 有一個 AT&T 模式來使用 AT&T 指令語法,但仍然是 NASM/YASM 前處理器和指令。)
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/472516.html
