File: chapter_debug.xml

package info (click to toggle)
covered 0.7.10-7
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 9,040 kB
  • sloc: ansic: 48,809; yacc: 11,650; xml: 8,838; tcl: 7,698; sh: 3,925; lex: 2,240; makefile: 362; perl: 329
file content (389 lines) | stat: -rw-r--r-- 19,127 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
<chapter id="chapter.debug">
  <title>Debugging</title>
  <para>
    As much as it pains the developers of Covered to admit, there will be times when a user of Covered will encounter a 
    problem in the resimulation process or will experience a performance issue during certain runs and will want to 
    investigate the issue a bit themselves before posting a bug report. There may also be people out there who just 
    might want to learn more about how Covered operates "under the hood". For those people whom I have just mentioned, 
    this section is for you.
  </para>
  
  <sect1 id="section.debug.output">
    <title>Verbose Debug Output</title>
    <para>
      The brute force method of understanding Covered's internals is to generate verbose debug output using the global "-D" 
      option to any of Covered's commands. The user of this method should take care to note that using this option may 
      generate an <emphasis>extremely</emphasis> large amount of output and will definitely cause Covered's runtime performance 
      to degrade considerably. If this option is used, its output should probably be redirected to a file for 
      post-processing purposes. It should be noted that the verbose debug output is most useful for the developer's of 
      Covered and is not meant to be of much help to the normal user.
    </para>
    
    <sect2 id="section.debug.output.building">
      <title>Building Covered for Verbose Debug Outputting</title>
      <para>
        Because generating verbose debug output can have a tremendous degradation in performance when it is even compiled, 
        Covered requires the user to specify an option to the configuration/build process to enable this feature. To enable 
        verbose debug outputting, simply specify the <emphasis role="bold"><code>--enable-debug</code></emphasis> option to the configure 
        script. This will cause Covered to compile in verbose debug output support and enable the use of the -D global option.
      </para>
      <note>
        <para>
          If the user has not specified the --enable-debug option to the configuration script but proceeds to specify the -D global option, 
          Covered will emit a warning message that it is unable to output verbose debug information due to the lack of the --enable-debug 
          option being specified. It will then proceed to ignore the -D option.
        </para>
      </note>
    </sect2>
    
  </sect1>
  
  <sect1 id="section.cli">
    <title>Command-Line Interface (CLI)</title>
    <para>
      As an alternative to simply outputting the verbose debug output from Covered, the score command comes equipped with its own 
      interactive debugging mechanism called the CLI (Command-Line Interface). This interface is a command-line driven utility that 
      starts at the beginning of the resimulation. Its purpose is to allow the user to step through simulation execution and view 
      the contents of signals, time, scopes, code and internal thread queues for the purposes of debugging and/or understanding 
      Covered. This utility works much in the same way as simulator CLIs and the GDB debugging utility.
    </para>
    
    <sect2 id="section.cli.building">
      <title>Building Covered for the CLI</title>
      <para>
        Because interactive command-line debugging has a small performance penalty when compiled in and is closely associated with 
        the verbose debug output option, Covered requires the user to specify an option to the configuation/build process to enable 
        this feature. To enable the CLI, simply specify the <emphasis role="bold"><code>--enable-debug</code></emphasis> option to the configure 
        script. This will cause Covered to compile in CLI capabilities and enable the user of the -cli score command option.
      </para>
    </sect2>
    
    <sect2 id="section.cli.using">
      <title>Using the CLI</title>
      <para>
        To allow the score command to use the CLI for interactive resimulation, simply specify the 
        <emphasis role="bold"><code>-cli [<emphasis>filename</emphasis>]</code></emphasis> option to the score command. If filename is 
        specified to this option, the contents of this file will be parsed and executed once the score command has reached the 
        resimulation process. The contents of this file are a series of CLI commands (one command per line) in ASCII format and can be 
        automatically produced with the "<code>savehist</code>" CLI command (see below). This feature allows a user to quickly save off 
        the CLI commands made during one score run and reuse them in a subsequent score run without having to remember and manually input 
        the same commands.
      </para>
      <para>
        Once the -cli option is invoked, Covered will run the score command until it gets to the beginning of the resimulation process. 
        At this time, if the optional filename is specified, it will parse the contents of this file and execute the CLI commands found 
        there until all commands are executed. If filename was not specified, a prompt will be displayed and the resimulation execution 
        will halt until the user has specified otherwise via command-line options. After entering a command-line option, simply press 
        return to invoke that command. In the event that the command was a step, next or continue option, resimulation will resume 
        until it reaches the next stop point.
      </para>
      <para>
        During resimulation, if the -cli option is specified to the score command, the user may stop simulation at any time by hitting
        <emphasis role="bold">Ctrl-C</emphasis>.  This will stop the simulation and display a CLI prompt where the user may continue
        to interact with the simulation.
      </para>
    </sect2>
    
    <sect2 id="section.cli.commands">
      <title>CLI commands</title>
      <para>
        The following is a list of all of the CLI options available to the user:
      </para>
      <table frame="all" id="table.cli.commands">
        <title>CLI Command-line Options</title>
        <tgroup cols='2' align='left' colsep='1' rowsep='1'>
          <colspec colwidth='1*'/>
          <colspec colwidth='2*'/>
          <thead>
            <row>
              <entry>Option</entry>
              <entry>Description</entry>
            </row>
          </thead>
          <tbody>
            <row>
              <entry>
                step [<emphasis>num</emphasis>]
              </entry>
              <entry>
                Advances to the next statement if <emphasis>num</emphasis> is not specified; otherwise, advances <emphasis>num</emphasis> 
                statements before returning to the CLI prompt.
              </entry>
            </row>
            <row>
              <entry>
                next [<emphasis>num</emphasis>]
              </entry>
              <entry>
                Advances to the next timestep if <emphasis>num</emphasis> is not specified; otherwise, advances <emphasis>num</emphasis> 
                timesteps before returning to the CLI prompt.
              </entry>
            </row>
            <row>
              <entry>
                goto time <emphasis>num</emphasis>
              </entry>
              <entry>
                Simulates to the given timestep (or the next timestep after the given value if the timestep is not executed) specified by 
              <emphasis>num</emphasis>.
              </entry>
            </row>
            <row>
              <entry>
                goto line [<emphasis>filename</emphasis>:]<emphasis>num</emphasis>
              </entry>
              <entry>
                Simulates until the specified line is the next line to be executed.  If <emphasis>filename</emphasis> is specified,
                the line specified by <emphasis>num</emphasis> within that file is the line to stop on.  If <emphasis>filename</emphasis>
                if not specified, the current filename is used.
              </entry>
            </row>
            <row>
              <entry>
                goto expr <emphasis>name bool_op value</emphasis>
              </entry>
              <entry>
                Simulates until the given expression is evaluated to true where <emphasis>name</emphasis> is the name of a signal in the
                design to evaluate, <emphasis>bool_op</emphasis> is a boolean operation (i.e., ==, !=, ===, !==, <![CDATA[<, <=, >, >=]]>), and
                <emphasis>value</emphasis> is a legal Verilog value (i.e., 30, 4'h0, etc.).
              </entry>
            </row>
            <row>
              <entry>
                run
              </entry>
              <entry>
                Runs the simulation to completion.
              </entry>
            </row>
            <row>
              <entry>
                continue
              </entry>
              <entry>
                Continues running the simulation to completion.
              </entry>
            </row>
            <row>
              <entry>
                thread active
              </entry>
              <entry>
                Displays the current state of the internal active simulation queue. This queue consists of process threads that will be executed 
                in the current timestep.
              </entry>
            </row>
            <row>
              <entry>
                thread delayed
              </entry>
              <entry>
                Displays the current state of the internal delayed simulation queue. This queue consists of process threads that will be executed 
                at a later time as dictated by a delay statement.
              </entry>
            </row>
            <row>
              <entry>
                thread waiting
              </entry>
              <entry>
                Displays the current state of the internal waiting simulation queue. This queue consists of process threads that are not active 
                or delayed but may be activated by a value change in one of the signals in its expression tree.
              </entry>
            </row>
            <row>
              <entry>
                thread all
              </entry>
              <entry>
                Displays the current state of all process threads in the simulator.
              </entry>
            </row>
            <row>
              <entry>
                current
              </entry>
              <entry>
                Displays the current scope, block, filename and line number of the statement that is about to be executed in the active queue.
              </entry>
            </row>
            <row>
              <entry>
                time
              </entry>
              <entry>
                Displays the current simulation time.
              </entry>
            </row>
            <row>
              <entry>
                signal <emphasis>name</emphasis>
              </entry>
              <entry>
                Displays the current value of the given net/variable.
              </entry>
            </row>
            <row>
              <entry>
                expr <emphasis>num</emphasis>
              </entry>
              <entry>
                Displays the given expression and its current value where <emphasis>num</emphasis> is the ID of the expression to output.
              </entry>
            </row>
            <row>
              <entry>
                debug [less | more | off]
              </entry>
              <entry>
                Specifies the amount of debug information that is output during simulation.  The value of 'less' only outputs the current
                statement that is being executed (along with line number).  The value of 'more' outputs verbose output that is really
                only useful for the developer's of Covered.  The value of 'off' turns off all debug output during simulation.  If
                'less', 'more', or 'off' is not specified, displays the current debug mode.
              </entry>
            </row>
            <row>
              <entry>
                list [<emphasis>num</emphasis>]
              </entry>
              <entry>
                Lists the contents of the file where the current statement is to be executed. If <emphasis>num</emphasis> is specified, 
                outputs the given number of lines; otherwise, outputs 10 lines.
              </entry>
            </row>
            <row>
              <entry>
                savehist <emphasis>filename</emphasis>
              </entry>
              <entry>
                Saves the current history to the specified file.
              </entry>
            </row>
            <row>
              <entry>
                history [(<emphasis>num</emphasis> | all)]
              </entry>
              <entry>
                Displays the last 10 lines of command-line history. If 'all' is specified, the entire history contents will be displayed. 
                If <emphasis>num</emphasis> is specified, the last <emphasis>num</emphasis> commands will be displayed.
              </entry>
            </row>
            <row>
              <entry>
                !<emphasis>num</emphasis>
              </entry>
              <entry>
                Executes the command at the <emphasis>num</emphasis> position in history.
              </entry>
            </row>
            <row>
              <entry>
                !!
              </entry>
              <entry>
                Executes the last valid command.
              </entry>
            </row>
            <row>
              <entry>
                help
              </entry>
              <entry>
                Displays the available command-line options.
              </entry>
            </row>
            <row>
              <entry>
                quit
              </entry>
              <entry>
                Ends simulation immediately.
              </entry>
            </row>
          </tbody>
        </tgroup>
      </table>
    </sect2>
  </sect1>
  
  <sect1 id="section.profiling">
    <title>Source Code Profiling</title>
    <para>
      The built-in source code profiling facility allows the user to run any Covered command and understand performance metrics 
      about the internal Covered source code, such as how many times a given function was called, how much wall-clock time was 
      spent executing a given function, how many times a function allocated and deallocated memory from the heap, etc. This 
      information can be useful in understanding where performance bottlenecks are during a given Covered command run. This 
      feature does not provide the end-user any useful information about the design that they are testing.
    </para>
    
    <sect2 id="section.profiling.building">
      <title>Building Covered for Profiling</title>
      <para>
        Because internal source code profiling is not a function of obtaining Verilog code coverage and adds a performance 
        penalty for being compiled in and used, Covered requires the user to specify an option to the configuration/build 
        process to enable this feature. To enable internal source code profiling, simply specify the 
        <emphasis role="bold"><code>--enable-profiling</code></emphasis> option to the configure script. This will cause Covered to 
        compile in profiling capabilities and enable the use of the -P global option.
      </para>
      <note>
        <para>
          If the user has not specified the --enable-profiling option to the configuration script but proceeds to specify the -P 
          global option, Covered will emit a warning message that it is unable to do profiling due to the lack of the 
          --enable-profiling option being specified. It will then proceed to ignore the -P option.
        </para>
      </note>
    </sect2>
    
    <sect2 id="section.profiling.using">
      <title>Using Source Code Profiling</title>
      <para>
        Once Covered has had profiling functionality configured and built into it, the user may optionally enable profiling for any 
        command by specifying the <emphasis role="bold"><code>-P [<emphasis>filename</emphasis>]</code></emphasis> global option. If 
        the -P option is specified without a filename associated with it, the profiling report generated from the command run will 
        be output to a file called "covered.prof" in the same directory where Covered was run. If a filename is associated with the 
        -P option, the contents of the profiling report will be output to that file.
      </para>
      <note>
        <para>
          The specified filename can be anything except "score", "merge" or "report" as this name will be interpreted by Covered's 
          command-line parser to indicate the type of command being run. If one of these command keywords are specified after the 
          -P option, it is assumed that the user has not specified a filename and the contents of the profiling report will be sent 
          to the default file of "covered.prof".
        </para>
      </note>
    </sect2>
    
    <sect2 id="section.profiling.report">
      <title>Understanding the Profiling Report</title>
      <para>
        After a command has been run with the global -P option specified, a report file will contain several profiling statistics, 
        including the following:
      </para>
      <para>
        <orderedlist>
          <listitem><para>The amount of time spent running the entire command</para></listitem>
          <listitem><para>The number of times each executed function was called</para></listitem>
          <listitem><para>The total amount of wall clock time spent executing each function</para></listitem>
          <listitem><para>The average amount of time spent executing each function</para></listitem>
          <listitem><para>The number of times each function allocated heap memory</para></listitem>
          <listitem><para>The number of times each function deallocated heap memory</para></listitem>
        </orderedlist>
      </para>
      <para>
        In addition to providing this information on a per function basis, the profiling report also provides the information 
        in three different sections with each function ordered from most to least by the following statistic columns:
      </para>
      <para>
        <orderedlist>
          <listitem><para>The number of times each executed function was called</para></listitem>
          <listitem><para>The total amount of wall clock time spent executing each function</para></listitem>
          <listitem><para>The average amount of time spent executing each function</para></listitem>
        </orderedlist>
      </para>
      <para>
        By ordering this information, it will help the users and developers determine where the performance bottlenecks in execution 
        are for a given command run.
      </para>
    </sect2>
  </sect1>
</chapter>