asm 宣言
提供: cppreference.com
asm 宣言は C++ のプログラム内にアセンブリ言語のソースコードを埋め込む能力を与えます。 この宣言は条件的にサポートされ、処理系定義です。 つまり、存在しないかもしれず、処理系によって提供されるときでも、固定の意味を持ちません。
目次 |
[編集] 構文
asm ( string_literal ) ;
|
|||||||||
[編集] 説明
string_literal は、一般的には、この宣言が実行されるときに実行される、アセンブリ言語で書かれた短いプログラムです。 コンパイラによって、 asm 宣言に対するルールが大きく異なり、周囲の C++ コードとのやり取りのための規約が異なります。
他のブロック宣言と同様に、この宣言はブロック (関数の本体や別の複文) の内側に現れることができ、他のすべての宣言と同様に、この宣言はブロックの外側に現れることもできます。
This section is incomplete Reason: write a note on GCC extended assembly syntax, since it is now supported by Intel, IBM, Sun (as of v12), etc |
[編集] 例
GCC コンパイラによって提供されている2種類のインラインアセンブリ構文をデモンストレーションします。 このプログラムは x86_64 プラットフォームの Linux 上でのみ正しく動作します。
Run this code
#include <iostream> extern "C" int func(); // func の定義はアセンブリ言語で記述されます。 // 生文字列リテラルが非常に便利です。 asm(R"( .globl func .type func, @function func: .cfi_startproc movl $7, %eax ret .cfi_endproc )"); int main() { int n = func(); // 拡張インラインアセンブリ。 asm ("leal (%0,%0,4),%0" : "=r" (n) : "0" (n)); std::cout << "7*5 = " << n << std::endl; // 意図的にフラッシュしています。 // 標準インラインアセンブリ。 asm ("movq $60, %rax\n\t" // Linux における exit システムコールの番号。 "movq $2, %rdi\n\t" // このプログラムは 2 を返します。 "syscall"); }
出力:
7*5 = 35