カーネルシステムコールの接続メカニズムはなぜそんなに速いのですか? [閉鎖]

カーネルシステムコールの接続メカニズムはなぜそんなに速いのですか? [閉鎖]

Linuxカーネルでファイルを開くと、ほとんどすべてのファイルに外部関数とマクロがたくさん#indefありますが、#ifndefファイルに70個以上のヘッダファイルが含まれている場合は、コンパイル時にどのようにすべての関数とマクロを正確にマップしますか.c/.h

これはどのくらい正確かつ迅速に行われますか? GCCはこれらのタスクだけを担当していますか、それともこれらすべてのタスクを実行できる他のプログラムはありますか?

答え1

いいですね。あなたの質問に完全に答えるためには、Cプログラミングの入門に関する本を読んでください。タネンバウムそして龍の本。 Cから学びましょう。

始めるための基本事項:Cプログラムをコンパイルするとき、伝統的にいくつかの異なる手順があります。 (最新のコンパイラはフェーズ間最適化を実行できます。)フェーズは次のとおりです。

  1. パイオニア。これには、インクルードファイル、#ifdef、#define、およびマクロ拡張が含まれます。
  2. 翻訳者。これはCコードをより機械レベルの中間表現(時にはアセンブラ)に変換します。
  3. アセンブラ。これは中間表現を実際の機械語コードに変換します。
  4. リンカー。これにより、すべてのフラグメントがまとめられ、メモリの問題が処理されます。複数のリンクを渡すことができます。

gccは上記のすべてを行うことができますが、カーネルが複雑であるため、他のツールが使用され、ほとんどはカーネルによって異なります。

カーネルはいくつかの点で別のプログラムですが、ハードウェアに応じてシステムコールを含む多くの違いがあります。

一般的なLinuxプログラムでカーネルにファイルを開くなどの操作を要求した場合

  1. プログラムはライブラリ関数を呼び出します。
  2. ライブラリ関数はシステムコールを実行します。
  3. カーネルはディスパッチテーブルからシステムコールを探します。
  4. カーネルは認証確認を行います。
  5. カーネルは自分の仕事をします。
  6. カーネルは結果をライブラリ関数として返します。
  7. ライブラリ関数は結果をプログラムに返します。

これは毎秒数百回発生する可能性があります。

関連情報