仮想メモリの観点から実行可能ファイルをロードする

仮想メモリの観点から実行可能ファイルをロードする

[[373936]]

この記事はWeChatの公開アカウント「Linux Bathhouse」から転載したもので、著者はLengmianbulelengです。この記事を転載する場合はLinux Bathhouse公式アカウントまでご連絡ください。

実行可能ファイルをダブルクリックして開くと、コンピューターは具体的に何を実行するのでしょうか?ディスク上の実行可能ファイルはどのようにメモリにロードされるのでしょうか?多くのプログラマーにとって、これはまだ答えるのが容易ではない質問です。

今回は、実行ファイルの読み込みプロセスを仮想メモリの観点から見て、実行ファイルの読み込みが開始されてから最初の命令が実行されるまでの間に何が起こるかを詳しく分析してみましょう。

この記事では、プロセスの概念、ELF ファイル構造、仮想メモリの定義、ページングの概念、およびデマンド ページングの動作原理については詳しく説明しません。以前の記事でそれらについて説明しました。興味のある友人は自分で検索することができます。

読み込みは、おおまかに次の手順に分けられます。

  1. プロセスの作成
  2. 仮想アドレス空間の作成
  3. 実行可能ファイルのヘッダーを読み取り、仮想アドレス空間と実行可能ファイル間のマッピング関係を確立する
  4. CPU命令レジスタを実行可能ファイルのエントリアドレスに設定する
  5. 実行し、ページフォールト割り込みをトリガーする

プロセスの作成

言うまでもなく、プロセスを作成すると、このときにプロセス識別子やプロセス優先度などの情報も作成されます。この時点では実行可能ファイルは含まれていないことに注意してください。

仮想アドレス空間の作成

このステップは、実際にはプロセス作成の一部としてカウントされる必要があります。実際には、物理​​メモリとの接続を確立するためにページ テーブル (マルチレベル ページ テーブル) を作成します。この時点ではページ テーブルは空です。この時点では、実行可能ファイルはまだ存在しません。

実行ファイルヘッダーの読み取り

これは重要なステップです。プロセスは、実行可能ファイル ヘッダー、つまり ELF ファイルのヘッダーの読み取りを開始します。この時点では、プロセスは ELF ファイル ヘッダーのみを読み取り、他のセグメントは読み取りません。 ELF ファイル ヘッダーには、実行可能ファイルの各セグメントの開始アドレスと長さ、実行可能ファイルのエントリ アドレスなどの情報が含まれています。ここでの「アドレス」は仮想メモリ アドレスを指すことに注意してください。

ここで強調しておきたいのは、ロード プロセス全体では ELF ヘッダーのみが読み取られ、それ以上は読み取られないということです。 ELF ヘッダーには実行ファイル全体のリズムが記録されるため、ELF ヘッダーに基づいて実行ファイル全体のフレームワークを確立できます。したがって、この手順ではディスクとの接続を確立します。簡単な例を挙げると、ページ フォールトが発生した場合、オペレーティング システムは不足しているページを物理メモリのどこにロードすればよいでしょうか。これがこのステップの重要なポイントです。仮想メモリ アドレスとディスク アドレス間の接続を確立し、ページが欠落している場合に、対応するディスク アドレスを見つけて物理メモリにロードできるようにします。

強調する必要があるもう 1 つの点は、プロセスのこの時点では、実際には関数マッピング関係のみを保存することと同じであるということです。次の図はより直感的に理解しやすいでしょう。

この写真を覚えておいてください。後でメモリ管理について説明するときに、プロセスとメモリを組み合わせます。そうすれば、カーネルを俯瞰でき、カーネルを制御しているように感じられます。

CPU命令レジスタを設定する

上記の 2 つの手順により、仮想アドレス空間と物理メモリおよびディスク間のマッピング関係が確立されました。これでこのプログラムを実行する準備が整いました。最初に実行される命令のアドレスはどこですか? ELF ヘッダー内。 CPU 命令レジスタの値を最初の命令のアドレスに設定するだけです。

実行し、ページフォールト割り込みをトリガーする

CPU がエントリ アドレスから命令をフェッチすると何が起こるかを考えてみましょう。エントリ アドレスが .text セグメントの先頭 (図に示すように 0x8049000) を指していると仮定します。 CPU はこの仮想アドレスを使用してページ テーブルを検索し、ページがロードされていないことを検出して、ページ フォールト割り込みをトリガーします。この時点で、オペレーティング システムが引き継ぎ、仮想アドレス空間とディスク間の以前に確立されたマッピング関係から、ディスク上のこのページのアドレスを見つけます。次に、このアドレスからページを読み取り、物理メモリにロードして、ページ フォールト割り込みが完了します。 CPU はエントリ アドレスから再度命令をフェッチし、ページ テーブルから物理アドレスを取得し、メモリから対応する命令を取得して CPU に渡します。

プロセスが実行されると、ページ フォールトが継続的に発生し、ディスク上の実行可能ファイルが徐々にメモリにロードされます。

要約する

上記は単純な実行可能ファイルの読み込みプロセスです。強調すべき最も重要な点は、実行可能ファイルのデータが要求に応じて物理メモリにロードされ、ページ フォールト割り込みによってプロセスの実行が駆動されることです。

<<:  Cohu、統合クラウド・プラットフォームの構築にOracle Fusion Cloud Applicationsを採用

>>:  パブリッククラウドにおけるDockerアプリケーション処理能力の評価

推薦する

草の根宣言: 大物の前では決して諦めない!

序文ネットユーザーの中には、ペンネームを考えたらどうかと提案する人もいるので、自分をXinchenと...

ウェブサイトのコンテンツ収集を増やし、コンテンツのランキングを向上させることについての簡単な説明

ウェブマスターの友人の大多数にとって、ウェブサイトコンテンツのインクルードを向上させるテクニックは基...

gcore イスラエル VPS はどうですか?イスラエルのテルアビブにある VPS の簡単なレビュー

gcore vpsはどうですか? gcore のイスラエル コンピュータ ルームはどうですか? gc...

海雲傑宣:OpenStackは順調に発展しており、コンテナ化が一般的なトレンドとなっている

「OpenStackとクラウドコンピューティングは成熟し、企業や通信ユーザーが大量に導入し始めていま...

Shanpai.comは今日、約2年間の運営を経て終了した。同社はその失敗の2つの主な理由を明らかにした。

Shanpai.comのコンセプトは人気のSwoopoからインスピレーションを得ていますShanpa...

キャッシュバックサイトは偽のショッピングサイトだが、実際の投資サイト:違法な資金調達の疑い

いくつかの有名なショッピング割引ウェブサイトの QQ グループでは、グループのメンバーは互いに「何を...

tropihost-5.5 USD/2 GB RAM/100 GB SSD/1 TB トラフィック/1 GB ポート/フロリダ

TropiHost.com がいつ登場したのかは分かりません。主な事業は VPS とサーバーレンタル...

わずか 3 ステップで Docker を使用して Nginx リバース プロキシを作成する

Web アーキテクチャでは、俊敏性とスケーラビリティが不可欠であり、最適なパフォーマンスを確保しなが...

Weiboマーケティングのメリットとデメリットについて

インターネットの急速な台頭と発展に伴い、新しいインターネット産業も急速に発展しています。Weiboの...

H3C Workspaceデジタルワークスペースソリューションは、クラウド+スクリーンでミニマリストな作業モードを構築します。

[51CTO.comよりオリジナル記事]ポストパンデミック時代において、モバイルオフィスやリモートオ...

百度の単語分割技術によるオリジナル記事の関連性について

厳密に言えば、Baidu の検索エンジンは、非常に優れた単語分割技術を備えているため、中国語分野で最...

新浪の高級電子商取引事業が閉鎖間近と報じられる

最近、一部のメディアは、Jiapin.com が大規模な人員削減を経験し、Sina Luxury が...

ウェブサイトを宣伝するためのWeiboの適切な使用

Weiboは今や人々の生活に欠かせないものとなり、仕事でも勉強でも、私たちはいつでもWeiboを利用...

クラウドストレージの5つの利点

5G 時代では、ますます多くの企業がクラウドにデータを保存することを選択するようになっています。 I...