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

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

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

推薦する

セルフメディアの時代に適応した中国企業ダイナミクスが、企業ウェブサイトの4つの運用の詳細を教えます

中国企業動態は、14の主要業界の500人以上のポータルサイトユーザーを対象にインタビューと調査を実施...

Vsis: 安価なベトナム VPS、無制限のトラフィック、月額 5.2 ドル、1G メモリ/1 コア/20g SSD/100Mbps 帯域幅

vsis.net は、独自の AS 番号を持つベトナムの会社です。正確な設立時期は不明です (公式ブ...

高速ホスティング - $2.4/Kvm/250m メモリ/5g SSD/250g トラフィック/Win

fast-hosting、この会社は比較的新しいので、これまで見たことがありませんが、E3 または ...

タオバオアライアンスの新ルールのもと、店舗間の許可なしに12大節を祝うにはどうすればいいでしょうか? (1つ)

人生はいつも順風満帆というわけではありません。タオバオ連盟はユーザーの店舗間決済権限を大規模に削除し...

#Cyber​​Monday# itldc: 9 日間 50% オフ プロモーション、9 つのデータセンター VPS + 専用サーバー

itldc は、12 月 1 日から 12 月 9 日までの 9 日間、Xeon E3 シリーズ C...

対外貿易企業のウェブサイトのコンバージョン率を向上させる方法の例

最近は貿易ウェブサイトが数多く存在します。Zencart などのオープンソース CMS に慣れていれ...

Ali Bixuan: 開発者エコシステムは、クラウドの将来における成功と失敗の鍵となるでしょうか?

過去 1 年間、開発者エコシステムをめぐるクラウド ベンダー間の競争はますます激化しています。なぜこ...

K8S の混乱から熟練へ: この記事を読めば、クラスター ノードがオフラインになることはなくなります。

はじめに: まったく未知の問題や未知のシステム コンポーネントのトラブルシューティングは、多くのエン...

ブランド、マーケティング、広告の関係を説明する記事

ブランド、マーケティング、広告の関係は次のようになります。ブランド > マーケティング >...

CKA 試験の効率性の向上: 準備完了状態のノードを正確にカウントするための実用的な戦略

Kubernetes クラスターは、マスター ノードと複数のノード ノードで構成されます。ノードはク...

ハイブリッドクラウドの複雑さと導入の急ぎがセキュリティリスクをもたらすと専門家は言う

オンプレミス システムと並行してホスト型クラウド コンピューティング インフラストラクチャを急いで導...

ユーザーがゲーム フィード広告をクリックしても、コンバージョンに至らないのはなぜでしょうか?

実際のユーザーがコンバージョンしなかった理由は、ランディング ページに関係している可能性があります。...

ByteDanceのゲームアドベンチャー

バイトダンスは2019年に10以上のゲームを配信して試行錯誤した後、2019年に独自のゲーム開発のプ...

中国総合モバイルオフィスプラットフォーム産業調査レポート

包括的なモバイル オフィスプラットフォームは、企業組織管理システムを統合し、統合された多様なオフィス...

事例:日本最大のレシピ共有UGCコミュニティ「クックパッド」を深く理解する

編集者注クックパッドは、女性の「今夜は何を食べようか」という心理を捉え、リアルタイムで多様なレシピを...