[PATCH] D89283: [trace][intel-pt] Implement the basic decoding functionality

Greg Clayton via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri Oct 16 16:40:31 PDT 2020


clayborg added a comment.

As I stated before we should be printing the disassembly for each instruction on the output lines. We should probably also normalize the address hex value to it doesn't change widths. Something like:

  [ 0] 0x000000000040065f: pushq  %rbp
  [ 1] 0x000000000040065a: movq   %rsp, %rbp
  [ 2] 0x0000000000400657: movl   $0x0, -0x1c(%rbp)
  [ 3] 0x0000000000400654: callq  0x100000f82               ; symbol stub for: printf
  [ 4] 0x00007ffff7df1950: movl   %edi, -0x20(%rbp)

And possibly in this patch or in another patch, we should print out when the source file and line changes

  a.out`main @ main.cpp:12
    [ 0] 0x000000000040065f: pushq  %rbp
    [ 1] 0x000000000040065a: movq   %rsp, %rbp
    [ 2] 0x0000000000400657: movl   $0x0, -0x1c(%rbp)
  a.out`main @ main.cpp:13
    [ 3] 0x0000000000400654: callq  0x00007ffff7df1950               ; symbol stub for: printf
  libc.so`printf
    [ 4] 0x00007ffff7df1950: movl   %edi, -0x20(%rbp)



================
Comment at: lldb/test/API/commands/trace/TestTraceDumpInstructions.py:159-160
+            substrs=['''thread #1: tid = 3842849, total instructions = 2
+  [0] no memory mapped at this address: 0x400518
+  [1] no memory mapped at this address: 0x400511'''])
+
----------------
These lines should start with the address like all other lines. Then the question is what the output should look like. Do we really need to tell the user that there is no memory mapped here? Can we just print "<???>" or nothing if we have no information like:

```
[0] 0x400518: <???>
[1] 0x400511: <???>
```



================
Comment at: lldb/test/API/commands/trace/TestTraceDumpInstructions.py:180
+  [ 3] 0x400654
+  [ 4] no memory mapped at this address: 0x7ffff7df1950
+  [ 5] 0x400516
----------------
```
[ 4] 0x7ffff7df1950 <???>
```


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D89283/new/

https://reviews.llvm.org/D89283



More information about the llvm-commits mailing list