機械命令レベルの各コマンドは、対応するソースレベルのコマンドと同じように動作します。ただし、動作の単位はソース行ではなく、単一の命令です。
ある機械命令から次の機械命令に 1 つだけステップ実行するには、nexti コマンドまたは stepi コマンドを使用します。
nexti コマンドと stepi コマンドは、それぞれに対応するソースコードレベルのコマンドと同じように動作します。すなわち、nexti コマンドは over 関数をステップ実行し、stepi は次の命令が呼び出した関数をステップ実行します (呼び出された関数の最初の命令で停止します)。コマンドの書式も同じです。詳細については、「next コマンド」と 「step コマンド」を参照してください。
nexti と stepi の出力は、対応するソースレベルのコマンドの場合と次の 2 つの違いがあります。
ソースコードの行番号の代わりに、プログラムが停止したアドレスが出力に含まれる。
ソースコード行の代わりに、デフォルトの出力に逆アセンブルされた命令が示される。
たとえば、次のようにします。
(dbx) func hand::ungrasp (dbx) nexti ungrasp +0x18: call support (dbx) |
詳細については、「nexti コマンド」と 「stepi コマンド」を参照してください。
機械命令レベルでのトレースは、ソースコードレベルでのトレースと同じように行われます。ただし、tracei コマンドを使用する場合は例外です。tracei コマンドでは、実行中のアドレスま たはトレース対象の変数の値がチェックされた場合にだけ、単一の命令が実行されます。tracei コマンドは、stepi のような動作を自動的に行います。すなわち、プログラムは 1 度に 1 つの命令だけ進み、関数呼び出しに入ります。
tracei コマンドを使用すると、各命令が実行され、アドレスの実行またはトレース中の変数または式の値を dbx が調べている間、プログラムは一瞬停止します。このように tracei コマンドの場合、実行速度がかなり低下します。
トレースとそのイベント仕様および修飾子については、「トレースの実行」と 「tracei コマンド」を参照してください。
tracei コマンドの一般的な構文は次のとおりです。
tracei event-specification [modifier] |
一般的に使用される tracei コマンドの書式は次のとおりです。
tracei step |
各命令をトレース |
tracei next |
各命令をトレースするが、呼び出しを飛び越します。 |
tracei at address |
指定のコードアドレスをトレース |
詳細については、「tracei コマンド」を参照してください。
SPARC の場合は次のようになります。
(dbx) tracei next -in main (dbx) cont 0x00010814: main+0x0004: clr %l0 0x00010818: main+0x0008: st %l0, [%fp - 0x8] 0x0001081c: main+0x000c: call foo 0x00010820: main+0x0010: nop 0x00010824: main+0x0014: clr %l0 .... .... (dbx) (dbx) tracei step -in foo -if glob == 0 (dbx) cont 0x000107dc: foo+0x0004: mov 0x2, %l1 0x000107e0: foo+0x0008: sethi %hi(0x20800), %l0 0x000107e4: foo+0x000c: or %l0, 0x1f4, %l0 ! glob 0x000107e8: foo+0x0010: st %l1, [%l0] 0x000107ec: foo+0x0014: ba foo+0x1c .... .... |