Linuxカーネルについて読んで、カーネルデータ構造の概念に触れました。 Google でより多くの情報を見つけようとしましたが、何も見つかりませんでした。
- カーネルデータ構造とは何ですか?
- 要件、使用、アクセス権は何ですか?
- カーネル内のデータ構造はどのように構成されていますか?
file_operations
カーネルデータ構造の例はまたはですc_dev
。
答え1
カーネルはCで書かれています。 「カーネルデータ構造」は、単にソースコードで定義されているほとんどの複合型(struct
sとs)union
のさまざまな形式(ツリー、リスト、配列など)を表します。ここで、Cコードは通常、このような項目でいっぱいです。 Cを理解できない場合は理解できません。
データ構造メモリまたはアドレス空間にインフォメーションストアを設定します。 Linuxカーネルが使用するものには特別なものはありません。カーネルモジュールを作成する場合は、その一部を使用できるか使用する必要がありますが、その使用は完全にカーネル内で行われます。カーネルメモリはカーネルによってのみアクセスされ、その構造は他のどんなものとも関係がありません。
答え2
カーネルは、既存のユーザープロセス、割り当てられたメモリ、プロセッサの状態、ロードされたデバイスドライバ、ハードウェアの状態、キャッシュされたI / O、ネットワークポート、タイマー、パフォーマンス指標など、システムの状態を追跡します。デフォルトでは、すべてはシステムリソースであり、ユーザープロセスの一部でもなく、カーネルプログラム自体の一部でもありません。
これらすべての情報は、定義された方法でフォーマットされたレコードを格納する単純なメモリである「カーネルデータ構造」に格納されます。
通常、カーネルのデバッグ、トレース、またはコアダンプについて読むときにこの用語に触れます。コアダンプはカーネル構造のみをコピーしたり、プロセス/ユーザーデータとともにカーネル構造をコピーしたりできます。ほとんどの場合、カーネルデータ構造のみが必要です。