Linux カーネル デバイス ドライバー カーネル デバッグ テクニカル ノート集

Linux カーネル デバイス ドライバー カーネル デバッグ テクニカル ノート集
/******************
 * カーネルデバッグ技術 ********************/

(1)カーネルソースコード内のデバッグ関連の設定オプション

カーネル構成オプションには、カーネルのデバッグに関連するいくつかのオプションが含まれており、すべて「カーネル ハッキング」メニューに集中しています。含む:

CONFIG_DEBUG_KERNEL

追加のデバッグ オプションが利用可能になるため、チェックする必要があります。これだけではすべてのデバッグ機能が有効になるわけではありません。

デバッグ オプションの詳細な説明については、ドライバーのマニュアルを参照するか、menuconfig のヘルプ説明を参照してください。

(2)マクロを使ってprintkデバッグ文をグローバルに制御する方法

Makefile と連携することで、c ファイル内に独自のデバッグ ステートメントを定義できます。

(3)straceの使用

strace は、ユーザー空間プログラムによって発行されたすべてのシステムコールをトレースできます。役立つパラメータは次のとおりです。

  • -t は通話が発生した時刻を表示します
  • -T 明示的な呼び出しに費やされた時間
  • -e は、"-e execve" のように、トレースされるシステムコールの種類を制限します。
  • -f すべての子プロセスをトレースする
  • -p 特定のプロセスをトレースします。たとえば、「-p 8856」
  • -o 特定のファイルに情報を出力します

strace は、特にマルチプロセス プログラムの場合、システム コールの微妙なエラーを発見するのに非常に便利です。strace によって出力される戻り値とプロセス pid を通じて、多くの有用な情報を得ることができます。のように:

$>strace -o zht.txt -f ./process_create

(4)ltraceの使用

ltrace は、ユーザー空間プログラムによって発行されたすべての動的ライブラリ関数呼び出しをトレースできます。役立つパラメータは次のとおりです。

  • -t は通話が発生した時刻を表示します
  • -T 明示的な呼び出しに費やされた時間
  • -f すべての子プロセスをトレースする
  • -p 特定のプロセスをトレースする
  • -o 特定のファイルに情報を出力します

(5)Oopsメッセージを確認する

Oops は、何か不幸なことが起こったことをユーザーに通知するカーネルの最も一般的な方法です。通常、oops を送信した後、カーネルは不安定な状態のままになります。

場合によっては、oops によってカーネル パニックが発生し、システム クラッシュにつながることがあります。このような状況には次のようなものがあります。

  • * ロックを保持しているコードでエラーが発生する
  • *ハードウェアデバイスとの通信中にエラーが発生する
  • *割り込みコンテキストでエラーが発生する
  • * アイドルプロセス(0)またはinitプロセス(1)でエラーが発生するのは、カーネルがこれらの2つのプロセスなしでは動作できないためです。

別のプロセスの実行中に oops が発生した場合、カーネルはそのプロセスを強制終了し、実行を継続しようとします。 Oops は、範囲外のメモリ アクセスや不正な命令など、さまざまな理由で発生する可能性があります。

oops に含まれる最も重要な情報は、レジスタ コンテキストと呼び出しトレースであり、次のような oops を人為的に発生させる可能性があります。

if(悪いもの)
 バグ();
//またはBUG_ON(bad_thing);

panic() を使用すると、より深刻なエラーを引き起こすことができます。panic() を呼び出すと、エラー メッセージが表示されるだけでなく、システム全体が停止します。極めて悲惨な状況でのみ使用してください:

if(ひどいもの)
 panic("foo は %ld です!\n", foo);

場合によっては、スタック情報を印刷するだけでも、dump_stack() などのテストに役立つことがあります。

 if(!debug_check){
  printk(KERNEL_DEBUG "情報を提供してください\n");
  ダンプスタック();
 }

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。これについてもっと知りたい場合は、次のリンクをご覧ください。

以下もご興味があるかもしれません:
  • Linux カーネル デバイス ドライバーのメモリ管理に関する注意事項
  • Linux カーネル デバイス ドライバー カーネル時間管理に関する注意事項
  • Linux カーネル デバイス ドライバー キャラクタ デバイス ドライバー ノート
  • Linux カーネル デバイス ドライバー仮想ファイル システムに関する注意事項
  • Linux カーネル デバイス ドライバー カーネル リンク リストの使用上の注意
  • Linux カーネル デバイス ドライバー proc ファイル システム ノート
  • Linuxカメラドライバの書き方の詳細説明
  • Linux におけるドライバモジュールのパラメータ転送プロセスの分析

<<:  Vueでパスワードの表示と非表示機能を実装するアイデアを詳しく解説

>>:  mysql5.7 でユーザーの初期パスワードを変更する方法

推薦する

一般的なDockerコマンドの詳細な説明

1. ヘルプコマンド1. 現在のDockerバージョンを表示する docker バージョン2. イメ...

MySQL シリーズ 11 ログ

チュートリアルシリーズMySQL シリーズ: MySQL リレーショナル データベースの基本概念My...

IE8は優れたエクスペリエンスを提供します: アクティビティ

今日は IE8 ベータ 1 (以下、IE8 と略します) をチラ見しました。IE8 は素晴らしい体験...

シンプルなjQuery + CSSを使用してカスタムタグタイトルツールチップを作成します

導入シンプルな jQuery + CSS を使用して、ブラウザのデフォルトの動作を置き換えるカスタム...

mysql インストーラ ウェブ コミュニティ 5.7.21.0.msi インストール グラフィック チュートリアル

この記事の例では、Androidの9グリッド画像を表示するための具体的なコードを参考までに共有してい...

OpenLayers 3 のベクターマップソースの読み込みの問題を解決する

1. ベクターマップベクター グラフィックスは直線と曲線を使用してグラフィックスを表します。これらの...

Vue+Openlayer で select を使用して要素を選択する実装コード

効果画像: 実装コード: <テンプレート> <div id="map&q...

CentOS7 に YUM 経由で MySQL 5.7 をインストールする詳細な手順

1. インストールパッケージを保存する場所に移動しますcd /home/lnmp 2. MySQL ...

ウェブページのテーブルの境界線を設定する方法

<br />前回は、Web テーブルにセルの線を設定する方法を学びました。今日は、Web...

ウェブサイト構築経験概要

<br />注目を集めるウェブサイトを作成するには、どのような原則に従うべきでしょうか?...

HTML 再利用テクニック

HTML の再利用は、あまり話題に上らない言葉です。今日は、この問題を次のようにまとめたいと思います...

あなたのウェブサイトはIE8に適していますか?

オリンピック期間中にIE8ベータ2がリリースされ、英語版のリリースに合わせて中国語版も第一波でリリー...

純粋な CSS で「テキストオーバーフローの切り捨てと省略」を実装するいくつかの方法

私たちの日常的な開発作業では、テキストのオーバーフロー、切り捨て、省略は、考慮する必要がある非常に一...

JavaScript でアルゴリズムの複雑さを学ぶ方法

目次概要Big O 表記法とは何ですか?オー(1)の上) (n^2) O(logn) ですの上!)結...