このgcc -S
オプションは AT&T 構文でアセンブリ コードを生成しますが、Intel 構文でファイルを生成する方法はありますか? または、2つの間で変換する方法はありますか?
3 に答える
使用する-masm=intel
gcc -S -masm=intel -Og -fverbose-asm test.c
これはGCC、およびclang3.5以降で機能します。 GCCマニュアル:
-masm=dialect
選択した方言を使用してasm命令を出力します。サポートされている選択肢は、intelまたはatt(デフォルト)です。ダーウィンはインテルをサポートしていません。
Mac OSXの場合、デフォルトでは、gcc
コマンドは実際にclangを実行することに注意してください。最新のclangは-masm=intel
これの同義語としてサポートしていますが、これは常にclangで機能します:
clang++ -S -mllvm --x86-asm-syntax=intel test.cpp
Clang 14までは、GCCとは異なり、 clangがインラインステートメントを処理する方法は変更されないことに注意してください。asm()
これらは、MattGodboltのCompilerExplorerサイトでデフォルトで使用されるオプションです。https
://godbolt.org/
関連項目GCC/clangアセンブリ出力から「ノイズ」を削除する方法 見るのが面白いasm出力を取得するための他のオプションとヒントについては。
の
gcc -S -masm=intel test.c
私と一緒に働きます。しかし、これは gcc の実行とは関係ありませんが、別の言い方をすることができます。実行可能ファイルまたはオブジェクト コード ファイルをコンパイルし、次のように objdump を使用して Intel asm 構文でオブジェクト コードを逆アセンブルします。
objdump -d --disassembler-options=intel a.out
これは役立つかもしれません。
私はCPPファイルにこのコードを持っています:
#include <conio.h>
#include <stdio.h>
#include <windows.h>
int a = 0;
int main(int argc, char *argv[]) {
asm("mov eax, 0xFF");
asm("mov _a, eax");
printf("Result of a = %d\n", a);
getch();
return 0;
};
これは、この GCC コマンド ラインで動作するコードです。
gcc.exe File.cpp -masm=intel -mconsole -o File.exe
*.exeファイルが生成され、私の経験ではうまくいきました。
Notes:
immediate operand must be use _variable in global variabel, not local variable.
example: mov _nLength, eax NOT mov $nLength, eax or mov nLength, eax
A number in hexadecimal format must use at&t syntax, cannot use intel syntax.
example: mov eax, 0xFF -> TRUE, mov eax, 0FFh -> FALSE.
それで全部です。