Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

152 lines
6.2KB

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  2. <html>
  3. <!-- Copyright (C) 1988-2020 Free Software Foundation, Inc.
  4. Permission is granted to copy, distribute and/or modify this document
  5. under the terms of the GNU Free Documentation License, Version 1.3 or
  6. any later version published by the Free Software Foundation; with the
  7. Invariant Sections being "Free Software" and "Free Software Needs
  8. Free Documentation", with the Front-Cover Texts being "A GNU Manual,"
  9. and with the Back-Cover Texts as in (a) below.
  10. (a) The FSF's Back-Cover Text is: "You are free to copy and modify
  11. this GNU Manual. Buying copies from GNU Press supports the FSF in
  12. developing GNU and promoting software freedom." -->
  13. <!-- Created by GNU Texinfo 6.5, http://www.gnu.org/software/texinfo/ -->
  14. <head>
  15. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  16. <title>tdump (Debugging with GDB)</title>
  17. <meta name="description" content="tdump (Debugging with GDB)">
  18. <meta name="keywords" content="tdump (Debugging with GDB)">
  19. <meta name="resource-type" content="document">
  20. <meta name="distribution" content="global">
  21. <meta name="Generator" content="makeinfo">
  22. <link href="index.html#Top" rel="start" title="Top">
  23. <link href="Concept-Index.html#Concept-Index" rel="index" title="Concept Index">
  24. <link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
  25. <link href="Analyze-Collected-Data.html#Analyze-Collected-Data" rel="up" title="Analyze Collected Data">
  26. <link href="save-tracepoints.html#save-tracepoints" rel="next" title="save tracepoints">
  27. <link href="tfind.html#tfind" rel="prev" title="tfind">
  28. <style type="text/css">
  29. <!--
  30. a.summary-letter {text-decoration: none}
  31. blockquote.indentedblock {margin-right: 0em}
  32. blockquote.smallindentedblock {margin-right: 0em; font-size: smaller}
  33. blockquote.smallquotation {font-size: smaller}
  34. div.display {margin-left: 3.2em}
  35. div.example {margin-left: 3.2em}
  36. div.lisp {margin-left: 3.2em}
  37. div.smalldisplay {margin-left: 3.2em}
  38. div.smallexample {margin-left: 3.2em}
  39. div.smalllisp {margin-left: 3.2em}
  40. kbd {font-style: oblique}
  41. pre.display {font-family: inherit}
  42. pre.format {font-family: inherit}
  43. pre.menu-comment {font-family: serif}
  44. pre.menu-preformatted {font-family: serif}
  45. pre.smalldisplay {font-family: inherit; font-size: smaller}
  46. pre.smallexample {font-size: smaller}
  47. pre.smallformat {font-family: inherit; font-size: smaller}
  48. pre.smalllisp {font-size: smaller}
  49. span.nolinebreak {white-space: nowrap}
  50. span.roman {font-family: initial; font-weight: normal}
  51. span.sansserif {font-family: sans-serif; font-weight: normal}
  52. ul.no-bullet {list-style: none}
  53. -->
  54. </style>
  55. </head>
  56. <body lang="en">
  57. <a name="tdump"></a>
  58. <div class="header">
  59. <p>
  60. Next: <a href="save-tracepoints.html#save-tracepoints" accesskey="n" rel="next">save tracepoints</a>, Previous: <a href="tfind.html#tfind" accesskey="p" rel="prev">tfind</a>, Up: <a href="Analyze-Collected-Data.html#Analyze-Collected-Data" accesskey="u" rel="up">Analyze Collected Data</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Concept-Index.html#Concept-Index" title="Index" rel="index">Index</a>]</p>
  61. </div>
  62. <hr>
  63. <a name="tdump-1"></a>
  64. <h4 class="subsection">13.2.2 <code>tdump</code></h4>
  65. <a name="index-tdump"></a>
  66. <a name="index-dump-all-data-collected-at-tracepoint"></a>
  67. <a name="index-tracepoint-data_002c-display"></a>
  68. <p>This command takes no arguments. It prints all the data collected at
  69. the current trace snapshot.
  70. </p>
  71. <div class="smallexample">
  72. <pre class="smallexample">(gdb) <b>trace 444</b>
  73. (gdb) <b>actions</b>
  74. Enter actions for tracepoint #2, one per line:
  75. &gt; collect $regs, $locals, $args, gdb_long_test
  76. &gt; end
  77. (gdb) <b>tstart</b>
  78. (gdb) <b>tfind line 444</b>
  79. #0 gdb_test (p1=0x11, p2=0x22, p3=0x33, p4=0x44, p5=0x55, p6=0x66)
  80. at gdb_test.c:444
  81. 444 printp( &quot;%s: arguments = 0x%X 0x%X 0x%X 0x%X 0x%X 0x%X\n&quot;, )
  82. (gdb) <b>tdump</b>
  83. Data collected at tracepoint 2, trace frame 1:
  84. d0 0xc4aa0085 -995491707
  85. d1 0x18 24
  86. d2 0x80 128
  87. d3 0x33 51
  88. d4 0x71aea3d 119204413
  89. d5 0x22 34
  90. d6 0xe0 224
  91. d7 0x380035 3670069
  92. a0 0x19e24a 1696330
  93. a1 0x3000668 50333288
  94. a2 0x100 256
  95. a3 0x322000 3284992
  96. a4 0x3000698 50333336
  97. a5 0x1ad3cc 1758156
  98. fp 0x30bf3c 0x30bf3c
  99. sp 0x30bf34 0x30bf34
  100. ps 0x0 0
  101. pc 0x20b2c8 0x20b2c8
  102. fpcontrol 0x0 0
  103. fpstatus 0x0 0
  104. fpiaddr 0x0 0
  105. p = 0x20e5b4 &quot;gdb-test&quot;
  106. p1 = (void *) 0x11
  107. p2 = (void *) 0x22
  108. p3 = (void *) 0x33
  109. p4 = (void *) 0x44
  110. p5 = (void *) 0x55
  111. p6 = (void *) 0x66
  112. gdb_long_test = 17 '\021'
  113. (gdb)
  114. </pre></div>
  115. <p><code>tdump</code> works by scanning the tracepoint&rsquo;s current collection
  116. actions and printing the value of each expression listed. So
  117. <code>tdump</code> can fail, if after a run, you change the tracepoint&rsquo;s
  118. actions to mention variables that were not collected during the run.
  119. </p>
  120. <p>Also, for tracepoints with <code>while-stepping</code> loops, <code>tdump</code>
  121. uses the collected value of <code>$pc</code> to distinguish between trace
  122. frames that were collected at the tracepoint hit, and frames that were
  123. collected while stepping. This allows it to correctly choose whether
  124. to display the basic list of collections, or the collections from the
  125. body of the while-stepping loop. However, if <code>$pc</code> was not collected,
  126. then <code>tdump</code> will always attempt to dump using the basic collection
  127. list, and may fail if a while-stepping frame does not include all the
  128. same data that is collected at the tracepoint hit.
  129. </p>
  130. <hr>
  131. <div class="header">
  132. <p>
  133. Next: <a href="save-tracepoints.html#save-tracepoints" accesskey="n" rel="next">save tracepoints</a>, Previous: <a href="tfind.html#tfind" accesskey="p" rel="prev">tfind</a>, Up: <a href="Analyze-Collected-Data.html#Analyze-Collected-Data" accesskey="u" rel="up">Analyze Collected Data</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Concept-Index.html#Concept-Index" title="Index" rel="index">Index</a>]</p>
  134. </div>
  135. </body>
  136. </html>