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

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

[[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アプリケーション処理能力の評価

推薦する

serverfield - 台湾の VPS、3 つのネットワークへの直接接続、100M の帯域幅、月額料金は 15 米ドルから

Serverfield は新しいブランドです。中国ではほとんどの人がこのビジネスに馴染みがないと思わ...

Docker Composeは、マスター1台、スレーブ2台、センチネル3台を備えた高可用性Redis 7.0.4クラスターを構築し、SpringBootを統合します。

1. はじめにRedis はエンタープライズ レベルの開発では非常に一般的ですが、単一の Redi...

ブランドマーケティング広告にはコンバージョンが必要ですか?

ブランド広告と成果広告の論争はずっと存在してきました。ブランドと成果の融合について語るのは簡単ですが...

ベテランウェブマスターが語る: SEO 担当者の将来はどこにあるのでしょうか?

実は、SEOerの育成や将来という話題は、多くの人から言及されています。私が今日このような話題を繰り...

電子商取引インターネット マーケティング: ROI の罪と罰 (パート 2)

[1 号につき 1 文] 人間は、勇敢になれるのは恐怖の時間の側面だけである。 (人間は、勇敢になれ...

V.PS: オランダの格安 VPS、年間 9.95 ユーロから、1G メモリ/1 コア/15g SSD/1T トラフィック

v.ps は最近、オランダのデータセンターに定期的な国際回線を備えた Nano シリーズという新しい...

分析フレームワークウェブサイト最適化技術

最近では、ページデザインの利便性のため、多くのウェブサイトがフレームを使用してウェブサイトをレイアウ...

Google、データ需要の増加に伴いアジア太平洋地域のクラウドリージョンを3つ追加

Google は、データ分析、オープン インフラストラクチャ、オンライン接続の需要が高まっているアジ...

「ジェネレーションZ」インサイトレポート!

2019 年の Generation Z Insight Report を皆さんと共有したいと思いま...

簡単な分析: 新規サイトの早期最適化のための準備作業と重要なポイント

会社が新しいウェブサイトを引き継ぐとき、私たちは何をすべきでしょうか? どのように始めるべきでしょう...

継続的なイノベーションについて話すことは、ウェブサイトの発展と成長の重要な要素です

ウェブマスターが議論するトピックの中で最も頻繁に登場する言葉は、ウェブサイトのプロモーションです。ウ...

SEOでは重要な作業を優先すべき

今日の話題はとてもシンプルです。問題に直面したとき、私たちは最も重要なことを選ぶべきでしょうか、それ...

PaaS、CaaS、FaaS、どれを選ぶべきか?

企業は、コンテナベースのアプリケーション向けのクラウド コンピューティング アーキテクチャを選択する...

列車チケット購入サイトは隙間に生き残る:おつかいモデルでは利益を上げるのは難しい

3月14日、国務院の「重大な部門改革」案が全国人民代表大会で承認された。鉄道部は廃止され、その機能は...

2021年から2022年にかけて、14人のCEOから見た中国のSaaS市場

SaaS が 2021 年に入ると、風が再び強まります。資本市場の熱狂はそれ自体が物語っているが、そ...