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

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

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

推薦する

Pinduoduo の根底にあるビジネスロジック!

Pinduoduoは、C2B グループ購入に重点を置いたサードパーティのソーシャル e コマース プ...

veesp: 月額 1 ドル、ロシアの VPS、KVM 仮想化、512 RAM/10G ハードディスク、PayPal 対応

2004年に設立されたFishnet Сommunicationsは、RNET、vStoike、Ve...

10gbiz: ロサンゼルス cn2 gia 無制限トラフィック VPS は月額 3.58 ドルから、ロサンゼルス 200M cn2 gia 専用サーバーは月額 160 ドルから

10gbizは、米国ロサンゼルスのデータセンターでVPS・専用サーバー事業を中心に展開する新ブランド...

アリババの音声AIが「世界の画期的技術トップ10」に選ばれ、中国企業もリスト入り!

2月28日、アリババの音声AI技術がMITの2019年「世界トップ10の画期的技術」の1つに選ばれま...

SEOの詳細に焦点を当て、360度の旅行サイトの最適化を分析

360 のビジネスはますます大きくなっています。同社は新しい Web サイト「360 Travel」...

パフォーマンスが2倍になります! Cloud Native GatewayはTLSハードウェアアクセラレーションをサポート

ネットワーク環境がますます複雑になるにつれて、従来の HTTP プレーンテキスト伝送プロトコルによっ...

ハイブリッドクラウドとは何ですか?

今日の急速に変化するデジタル環境において、企業は IT インフラストラクチャを最適化する革新的な方法...

管理者が知っておくべき6つの構成管理ツール

[51CTO.com クイック翻訳] 仮想インフラストラクチャとソフトウェアの共通の特徴は、常に構成...

母子向け電子商取引会社Redbabyが2000万ドルの資金調達、蘇寧による買収の噂を否定

昨日、売却の噂に巻き込まれた母子向け電子商取引会社レッドベイビーが今日沈黙を破り、自らメディアとコミ...

アリママ公式解釈:タオバオ不正行為の手数料を凍結する理由

A5 Webmaster Network(admin5.com)は11月22日、多くのTaobaoア...

エッジコンピューティング (Edge ML) を 1 つの記事で理解しましょう。

エッジコンピューティングを使用してローカルデバイスでAIを有効にするモノのインターネット (IoT)...

マッキンゼー:クラウドコンピューティング環境におけるセキュリティ問題は以前ほど顕著ではない

今日では、パブリック クラウドの導入が容易になり、企業は以前に比べてそのセキュリティや有効性に対する...

クラウドポータビリティに関する3つの考慮事項: 1. クラウドネイティブとコンテナ

市場にはさまざまなクラウド サービス プラットフォームが存在します。自分に最適なものをどのように選び...

ウェブサイトを最適化するときは冷静さを保つことが重要です。

ウェブサイト運営者、特に中小企業やウェブマスターはウェブサイトのランキングを毎日チェックしており、少...