1 背景 最近、ZC706-ARM 開発ボードの Linux システムでコンパイル システム (apt をサポートしていない) を構築する方法を研究しています。たまたま、会社に ubunut システム (apt をサポート) を搭載した Nvidia ARM 開発ボードがあることを知りました。このとき、Nvidia ボードでコンパイルされたプログラムは ZC706 ボードで実行できるのではないかというアイデアが浮かびました。 2 プロセス NVIDIAの開発ボードでは、gcc acがa.outを生成し、それをZC706にコピーして実行すると、「そのようなファイルまたはディレクトリはありません」と表示されます。 以前遭遇した理由は次のとおりです。
しかし、以下のプロセスの後、ZC706 には xx プログラム用の指定されたローダーがないことが判明しました。 1. ファイルの破損やその他の問題を排除する --> コピー検証を再生成する 検証プロセス: a.out は NVIDIA gcc でコンパイルされており、zc706 には上記の問題があります | b.out は x86 ubunut でクロスコンパイルされており、正常に実行できます その後、Googleで調べたところ、ローダーでもこの現象が発生する可能性があることがわかりました。以下から、両者の違いは主にインタープリターにあることがわかります。 解決: 1. コンパイラとライブラリの関係を統一する 2. ソフトリンク ln -s /lib/ld-linux.so.3 /lib/ld-linux-armhf.so.3 を作成します。 3. プログラムをコンパイルするときに、-staticオプションを追加してプログラムを静的にリンクします。つまり、動的ライブラリを使用しません。 root@tegra-ubuntu:~# readelf -h a.out ELF ヘッダー: マジック: 7f 45 4c 46 01 01 01 00 00 00 00 00 00 00 00 00 クラス: ELF32 データ: 2の補数、リトルエンディアン バージョン: 1 (現在) OS/ABI: UNIX - System V ABI バージョン: 0 タイプ: EXEC (実行可能ファイル) マシン: ARM バージョン: 0x1 エントリポイントアドレス: 0x8315 プログラムヘッダーの開始: 52 (ファイル内のバイト数) セクション ヘッダーの開始: 4500 (ファイル内のバイト数) フラグ: 0x5000402、エントリ ポイントあり、バージョン 5 EABI、ハード フロート ABI このヘッダーのサイズ: 52 (バイト) プログラムヘッダーのサイズ: 32 (バイト) プログラムヘッダーの数: 9 セクション ヘッダーのサイズ: 40 (バイト) セクションヘッダーの数: 30 セクション ヘッダー文字列テーブル インデックス: 27 root@tegra-ubuntu:~# readelf -h b.out ELF ヘッダー: マジック: 7f 45 4c 46 01 01 01 00 00 00 00 00 00 00 00 00 クラス: ELF32 データ: 2の補数、リトルエンディアン バージョン: 1 (現在) OS/ABI: UNIX - System V ABI バージョン: 0 タイプ: EXEC (実行可能ファイル) マシン: ARM バージョン: 0x1 エントリポイントアドレス: 0x86bc プログラムヘッダーの開始: 52 (ファイル内のバイト数) セクション ヘッダーの開始: 4136 (ファイル内のバイト数) フラグ: 0x5000202、エントリ ポイントあり、バージョン 5 EABI、ソフト フロート ABI このヘッダーのサイズ: 52 (バイト) プログラムヘッダーのサイズ: 32 (バイト) プログラムヘッダーの数: 8 セクション ヘッダーのサイズ: 40 (バイト) セクションヘッダーの数: 31 セクション ヘッダー文字列テーブル インデックス: 28 root@tegra-ubuntu:~# readelf -l helloworld | grep インタープリター readelf: エラー: 'helloworld': そのようなファイルはありません root@tegra-ubuntu:~# readelf -l a.out | grep インタープリター [プログラムインタープリターを要求しています: /lib/ld-linux-armhf.so.3] root@tegra-ubuntu:~# readelf -l b.out | grep インタープリター [プログラムインタープリターを要求しています: /lib/ld-linux.so.3] 3 ldローダーの紹介 Linux は、この ld-linux.so* (仮想マシン x86 上の Ubuntu は ld-linux.so2 を使用) を使用して、他のライブラリ (実際にはこれは単なるリンク) を読み込みます。したがって、このライブラリは linux/lib に配置する必要があります。その他の場合、共有ライブラリは通常、システムのデフォルトの検索パスでもある /lib パスに配置されます。 Linux 共有ライブラリの検索パスの順序は次のとおりです。 知らせ: 1. 一部の開発ボードでは、/etc に ld.so.conf がないことが分かります。このとき、ldconfig を実行すると、「ldconfig: 警告: 開けない設定ファイルを無視します: /etc/ld.so.conf: そのようなファイルまたはディレクトリはありません」というメッセージが表示されます。 解決策: ライブラリを環境変数に追加し、ldconfig -v (/sbin/ldconfig: キャッシュの構築に相対パス `–v' を使用) を実行します。 2. 共有ライブラリは共有オブジェクトを開けません 動的にリンクされているかどうかをテストします。libtest.so がリストされている場合、リンクは正常であるはずです。 現時点では、libtest.so が見つかりません。ダイナミック リンク ライブラリの検索パスに問題があります。したがって、ダイナミック ライブラリの検索場所を上に追加してください。 3 ldconfig コマンドは、主に、デフォルトの検索ディレクトリ (/lib および /usr/lib) とダイナミック ライブラリ構成ファイル /etc/ld.so.conf にリストされているディレクトリで共有可能なダイナミック リンク ライブラリ (形式は前述の lib*.so*) を検索し、ダイナミック ローダー (ld.so) に必要な接続ファイルとキャッシュ ファイルを作成します。 4 LD_LIBRARY_PATH: この環境変数は、ダイナミック リンカーがダイナミック ライブラリをロードできるパスを示します。 root 権限がある場合は、/etc/ld.so.conf ファイルを変更して /sbin/ldconfig を呼び出すことで同じ目的を達成できます。ただし、root 権限がない場合は、bash コマンドを使用して LD_LIBRARY_PATH を出力する方法しか使用できません。 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: 古典的なJavaScriptの再帰ケースの質問の詳細な分析
>>: MySQL 8.0.16 winx64 のインストールと設定方法のグラフィックチュートリアル (win10 の場合)
sshd SSH は Secure Shell の略で、アプリケーション層のセキュリティ プロトコル...
序文Dockerを使ってHadoopクラスタを起動するたびに、ネットワークカードの再バインド、IPの...
単一の MYSQL サーバーが現在の Web サイトのトラフィックに対応できない場合の最適化ソリュー...
目次MySQLの大文字と小文字の区別はパラメータによって制御されますMySQLの大文字と小文字の区別...
1. 基本コンポーネントをインストールするまず、 yumコマンドを実行して、コードpullために必要...
システムとユーザー環境の設計<br />Apple システムの成功は、そのシステム アー...
序文ヒストグラムは、RDBMS によって提供される基本的な統計情報です。最も一般的に使用されるのは、...
Ⅰ. 問題の説明: html+css を使用してシンプルなナビゲーション バーを実装します。 **...
1. インストール前の準備1. 公式ウェブサイトからUbuntu 20.04のイメージファイルを直接...
序文Vue には、v-if、v-bind、v-on などの豊富な組み込みディレクティブが用意されてい...
実施原則メイングラフィックは、背景と前景の 2 つの要素で構成されています。次のサンプルコードでは、...
Baiduで検索しました。 。 chcp コマンドを使用して、cmd の文字エンコーディングを 65...
1. DNSサーバーの概念インターネットでの通信には IP アドレスの助けが必要ですが、数字に対する...
JavaScriptをクリックすると画像の形状が変わります(変形の応用)。参考までに具体的な内容は...
[LeetCode] 178.ランクスコアスコアをランク付けする SQL クエリを記述します。2 ...