検索
ホームページバックエンド開発C++OKMX-C GDB リモート デバッグ スキル

OKMX-C GDB Remote Debugging Skills

組み込み開発の分野では、デバッグはプログラムの安定した動作を保証するための重要なステップです。 OKMX8MP-C 開発ボードを使用する開発者は、GDB リモート デバッグ手法を習得することで開発効率を大幅に向上させることができます。 GDB (GNU Project Debugger の略) は、Linux 上の包括的なデバッグ ツールです。 GDB は、ブレークポイントの設定、シングルステップ実行、変数の出力、変数の監視、レジスタの検査、コール スタックの表示など、さまざまなデバッグ方法をサポートしています。

Linux 環境のソフトウェア開発では、GDB は C および C プログラムのデバッグに使用される主要なデバッグ ツールです。 OKMX8MP-C の 5.4.70 バージョンには、デフォルトで gdbserver がサポートされており、当社が提供する開発環境もデフォルトで gdb をサポートします。次に、OKMX8MP-C で GDB リモート デバッグを実行する方法を詳しく説明します。

  1. コンパイル前の準備 GDB デバッグを実行する前に、アプリケーションが正しくコンパイルされており、デバッグ情報が含まれていることを確認することが重要です。これは、コンパイル中に -g オプションを追加することで実現できます。例:

forlinx@ubuntu:~$ $CC -g test_bug.c -o test_bug

このコマンドは、test_bug.c ソース ファイルをコンパイルし、デバッグ情報を含む実行可能ファイル test_bug を生成します。このようにして、GDB は後続のデバッグ プロセス中にソース コード内の対応する位置を正確に特定できます。

コンパイル後、生成された実行可能ファイルを開発ボードにコピーする必要があります。これは通常、シリアル ポート、ネットワーク、またはその他のファイル転送方法を介して実現されます。この例では、test_bug ファイルが開発ボードの / ディレクトリにコピーされていることを前提としています。

  1. 開発ボードの IP と gdbserver の開始設定 次に、開発ボードに IP アドレスを設定し、gdbserver サービスを開始する必要があります。具体的な手順は次のとおりです。

IP アドレスを設定します:

ifconfig コマンドを使用して、開発ボードの IP アドレスを設定します。例:

ifconfig eth0 172.16.0.109

ここでは、開発ボードの IP アドレスは 172.16.0.109 に設定されています

開発ボード上で gdbserver を起動し、リスニング ポート番号とデバッグするプログラムを指定します。例:

gdbserver 172.16.0.109:2345 /test_bug

このコマンドは gdbserver を起動し、ポート 2345 で GDB クライアントからの接続リクエストをリッスンします。

root@OK8MP:~# ifconfig eth0 172.16.0.109
root@OK8MP:~# gdbserver 172.16.0.109:2345 test_bug
プロセス /home/root/test_bug が作成されました。 pid = 1356
ポート 2345 でリッスン
仮想マシンまたはホストで、開発ボードと同じネットワーク セグメント内の IP アドレスを設定し、ping コマンドを使用して開発ボードとの接続をテストします。

開発ボードの IP アドレスの ping が成功することを確認します。これはリモート デバッグの前提条件です。

  1. GDB クライアントの起動と開発ボードへの接続 GDB クライアントを起動します:

仮想マシンまたはホスト上で、aarch64-poky-linux-gdb コマンドを使用して GDB クライアントを起動し、デバッグするプログラムを指定します。例:

forlinx@ubuntu:~/aarch64-poky-linux-gdb test_bug
GNU gdb (GDB) 8.3.1
Copyright (C) 2019 Free Software Foundation, Inc.
ライセンス GPLv3 : GNU GPL バージョン 3 以降 http://gnu.org/licenses/gpl.html
これはフリー ソフトウェアです。自由に変更したり再配布したりできます。
法律で認められる範囲においては、いかなる保証もありません。
詳細については、「コピーを表示」および「保証を表示」と入力してください。この GDB は「--host=x86_64-pokysdk-linux --target=aarch64-poky-linux」として構成されました。
構成の詳細については、「showconfiguration」と入力します。
バグ報告の手順については、以下を参照してください:
http://www.gnu.org/software/gdb/bugs/
GDB マニュアルおよびその他のドキュメント リソースは、次の場所でオンラインで検索できます。
http://www.gnu.org/software/gdb/documentation/
ヘルプを表示するには、「ヘルプ」と入力します。
「apropos word」と入力して、「word」に関連するコマンドを検索します...
test_bug からシンボルを読み取り中...
(gdb)
ボードに接続します:

GDB クライアントで、target リモート コマンドを使用して、ボード上の gdbserver に接続します。例:

(gdb) ターゲットリモート 172.16.0.109:2345
172.16.0.109:2345
を使用したリモート デバッグ リモートターゲットから /lib/ld-linux-aarch64.so.1 を読み取り中...
警告: リモート ターゲットからのファイル転送は遅くなる可能性があります。ファイルにローカルでアクセスするには、代わりに「set sysroot」を使用してください。
リモートターゲットから /lib/ld-linux-aarch64.so.1 を読み取り中...
target:/lib/ld-linux-aarch64.so.1...
からシンボルを読み取ります リモートターゲットから /lib/ld-2.30.so を読み取り中...
リモート ターゲットから /lib/.debug/ld-2.30.so を読み取り中...
リモート ターゲットから /lib/.debug/ld-2.30.so を読み取り中...
ターゲットからシンボルを読み取ります:/lib/.debug/ld-2.30.so...
target:/lib/ld-linux-aarch64.so.1 からの _start () 内の 0x0000fffff7fcf080
(gdb)
この時点で、GDB クライアントはボード上の gdbserver に接続し、リモート デバッグを開始する準備が整います。

  1. リモートデバッグ 接続に成功すると、リモート デバッグ用のさまざまな GDB デバッグ コマンドの使用を開始できます。以下は、一般的に使用されるデバッグ コマンドの一部です:

l (リスト): ソースコードをリストします。

b (ブレーク): ブレークポイントを設定します。

n (次へ): コードを 1 行ずつステップ実行します。

s (ステップ): 関数を 1 行ずつ実行するためにステップインします。

c (継続): プログラムの実行を継続します。

p (print): 変数の値を出力します。

たとえば、l コマンドを使用して、現在の場所にあるソース コードを表示します。

(gdb)l
12 }
13
14 void A(int *p)
15 {
16 B(p);
17 }
18
19 void A2(int *p)
20 {
21 C(p);
(gdb)

次に、B コマンドを使用して、行 16 などの行にブレークポイントを設定できます。

bash コードをコピー

(gdb) b 16

0x のブレークポイント 1...: ファイル test_bug.c、16 行目。

プログラムの実行を続けるには、c コマンドを使用します。プログラムはブレークポイントで一時停止し、さらなるデバッグを待ちます。

  1. デバッグ手法と注意事項 ブレークポイント管理: ブレークポイントを適切に設定すると、デバッグ効率が大幅に向上します。ブレークポイントを削除するには、d コマンドを使用します。現在のすべてのブレークポイントを表示するには、info b コマンドを使用します。

変数の監視: watch コマンドを使用して、変数の変更を監視します。変数の値が変更されると、GDB は自動的に実行を一時停止します。

マルチスレッド デバッグ: プログラムがマルチスレッドの場合、スレッド コマンドを使用してデバッグ用のスレッドを切り替えます。

セキュリティに関する考慮事項: リモート デバッグ中は、ネットワーク環境のセキュリティを確保することが重要です。 SSH トンネルまたはその他の暗号化方式を使用して、デバッグ データの送信を保護します。

OKMX8MP-C GDB リモート デバッグ スキルは以上です。この強力なツールにより、効率的な問題解決と開発の強化が可能になります。

以上がOKMX-C GDB リモート デバッグ スキルの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
C:それは死にかけていますか、それとも単に進化していますか?C:それは死にかけていますか、それとも単に進化していますか?Apr 24, 2025 am 12:13 AM

c isnotdying; it'sevolving.1)c relelevantdueToitsversitileSileSixivisityinperformance-criticalApplications.2)thelanguageSlikeModulesandCoroutoUtoimveUsablive.3)despiteChallen

C現代の世界:アプリケーションと産業C現代の世界:アプリケーションと産業Apr 23, 2025 am 12:10 AM

Cは、現代世界で広く使用され、重要です。 1)ゲーム開発において、Cは、非現実的や統一など、その高性能と多型に広く使用されています。 2)金融取引システムでは、Cの低レイテンシと高スループットが最初の選択となり、高周波取引とリアルタイムのデータ分析に適しています。

C XMLライブラリ:オプションの比較と対照C XMLライブラリ:オプションの比較と対照Apr 22, 2025 am 12:05 AM

C:tinyxml-2、pugixml、xerces-c、およびrapidxmlには、一般的に使用される4つのXMLライブラリがあります。 1.TinyXML-2は、リソースが限られている環境、軽量ではあるが機能が限られていることに適しています。 2。PUGIXMLは高速で、複雑なXML構造に適したXPathクエリをサポートしています。 3.Xerces-Cは強力で、DOMとSAXの解像度をサポートし、複雑な処理に適しています。 4。RapidXMLはパフォーマンスと分割に非常に高速に焦点を当てていますが、XPathクエリをサポートしていません。

CおよびXML:関係とサポートの調査CおよびXML:関係とサポートの調査Apr 21, 2025 am 12:02 AM

Cは、サードパーティライブラリ(TinyXML、PUGIXML、XERCES-Cなど)を介してXMLと相互作用します。 1)ライブラリを使用してXMLファイルを解析し、それらをC処理可能なデータ構造に変換します。 2)XMLを生成するときは、Cデータ構造をXML形式に変換します。 3)実際のアプリケーションでは、XMLが構成ファイルとデータ交換に使用されることがよくあり、開発効率を向上させます。

C#対C:重要な違​​いと類似点を理解するC#対C:重要な違​​いと類似点を理解するApr 20, 2025 am 12:03 AM

C#とCの主な違いは、構文、パフォーマンス、アプリケーションシナリオです。 1)C#構文はより簡潔で、ガベージコレクションをサポートし、.NETフレームワーク開発に適しています。 2)Cはパフォーマンスが高く、手動メモリ管理が必要であり、システムプログラミングとゲーム開発でよく使用されます。

C#対C:歴史、進化、将来の見通しC#対C:歴史、進化、将来の見通しApr 19, 2025 am 12:07 AM

C#とCの歴史と進化はユニークであり、将来の見通しも異なります。 1.Cは、1983年にBjarnestrostrupによって発明され、オブジェクト指向のプログラミングをC言語に導入しました。その進化プロセスには、C 11の自動キーワードとラムダ式の導入など、複数の標準化が含まれます。C20概念とコルーチンの導入、将来のパフォーマンスとシステムレベルのプログラミングに焦点を当てます。 2.C#は2000年にMicrosoftによってリリースされました。CとJavaの利点を組み合わせて、その進化はシンプルさと生産性に焦点を当てています。たとえば、C#2.0はジェネリックを導入し、C#5.0は非同期プログラミングを導入しました。これは、将来の開発者の生産性とクラウドコンピューティングに焦点を当てます。

C#対C:学習曲線と開発者エクスペリエンスC#対C:学習曲線と開発者エクスペリエンスApr 18, 2025 am 12:13 AM

C#とCおよび開発者の経験の学習曲線には大きな違いがあります。 1)C#の学習曲線は比較的フラットであり、迅速な開発およびエンタープライズレベルのアプリケーションに適しています。 2)Cの学習曲線は急勾配であり、高性能および低レベルの制御シナリオに適しています。

C#対C:オブジェクト指向のプログラミングと機能C#対C:オブジェクト指向のプログラミングと機能Apr 17, 2025 am 12:02 AM

オブジェクト指向プログラミング(OOP)のC#とCの実装と機能には大きな違いがあります。 1)C#のクラス定義と構文はより簡潔であり、LINQなどの高度な機能をサポートします。 2)Cは、システムプログラミングと高性能のニーズに適した、より細かい粒状制御を提供します。どちらにも独自の利点があり、選択は特定のアプリケーションシナリオに基づいている必要があります。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。