File: dlt_viewer_user_manual.txt

package info (click to toggle)
dlt-viewer 2.23.0%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 7,432 kB
  • sloc: cpp: 27,832; ansic: 4,454; xml: 491; sh: 154; makefile: 75
file content (445 lines) | stat: -rw-r--r-- 18,709 bytes parent folder | download | duplicates (5)
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
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
DLT Viewer User Manual
======================
Alexander Wenzel <Alexander.AW.Wenzel@bmw.de>
v0.0.4, February 2016: Updates and improvements for current DLT Viewer state
// v0.0.3, April 2013: Added Filetransfer commandline description
// v0.0.2, December 2012: Converted to asciidoc

:toc:

image::images/genivi_chrome_1_transparent.png[width=128]

Introduction
------------

Purpose
~~~~~~~
The DLT Viewer tool can decode, view and store DLT messages
generated by DLT Daemon. The DLT Viewer tool enables the software developer and
the tester of the device to view and control the log and trace information. It is
not the goal of GENIVI to provide full functional analyzing tools for traces,
but to provide a basic set of utilities to visualize, control and test all features of the
DLT Daemon component in a simple way. The DLT Daemon component and the DLT Viewer
are based on the AUTOSAR 4.0 standard DLT.

We try to keep the GUI simple for an effective and efficient workflow, but also to
integrate as much functionality as needed.

Feature List
~~~~~~~~~~~~
- Graphical User Interface
    * Menu and toolbar
    * Project widget
    * DLT Message Table
    * DLT Viewer Plugin
    * Footer with information about the current file etc.
- View DLT files
    * Drag and Drop support
    * Recent files selection
    * Temporary files support
    * Append files
    * Index cache of already opened DLT files
    * Default DLT file loading
    * Open multiple files (v2.10.1)
- Retrieve DLT messages from targets and store them in DLT files
    * Serial connections
    * TCP/IP connections
    * Multiple parallel connections
    * Autoconnect to targets
    * Configure log levels and trace status
    * Store configuration in target
    * Reset the target's configuration
    * Organise connections in projects
- Filter DLT messsages for analysing
    * Support to show only a defined subset of the messages
    * Complex filter configurations
    * Save and restore filter configurations
    * Multiple default filter configurations
    * Markers to highlight specific messages
    * Filter index cache of already filtered DLT files
    * Regular expressions
    * Sorting by time (v2.10.1)
- Clipboard support
    * Copy selected DLT messages to clipboard
- Export of DLT files in multiple formats
    * Supported formats:
        ** DLT format with selection
        ** ASCII format
        ** CSV format
    * Select the messages to be exported
        ** All messages
        ** Filtered messages
        ** Marked messages
- Search DLT messages
    * Step by step search
    * Search export view
    * Search by regular expressions
- Project configurations
    * Control log levels
    * Organise configurations in projects
    * Save and restore projects
    * Recent projects selection
    * Select displayed columns
    * Default project loading
    * Automatic timezone synchronisation (v2.10.1)
- Plugin configurations
    * Decoder plugins to decode messages
    * Viewer plugins to show more detailed information and analyse logs. Viewer plugins provide extra widgets to visualize data
    * Control plugins to control applications on the target
    * Available plugins
        ** DLT Viewer Plugin
        ** Non Verbose Mode Plugin
        ** Filetransfer Plugin
        ** DLT Statistic Plugin
        ** DLT System Viewer Plugin
- Command line support
    * Silent mode
    * Loading project
    * Loading DLT file
    * Using filter configuration
    * Export DLT files to ASCII
    * Execute commands in plugins
- Plugins programming guide


DLT Viewer GUI
--------------
Layout
~~~~~~
image::images/main_window_plain.png[width="100%"]

The screenshot above will give you a quick impression about how the Viewer
could look. The Viewer is based on Qt, so there are widgets you can move
around and resize as you like. Your settings of position and size of the
widgets are stored when you close the Viewer so that you have exactly the
same window when you launch the Viewer the next time.

To get a better understanding about the DLT Viewer parts the screenshot
below marks the relevant areas followed by a description.

image::images/main_window_annotated.png[width="100%"]

[width="100%",style="asciidoc",cols="<5%,<15%,<80%",frame="topbot",options="header"]
|=============================================================================
|Nr|Title|Description
|image:images/Mark1.png[width="64"]|Menu and Toolbar|In the window title you can find the absolute path of your
project file (if a file is used) and the project name. If you start the DLT Viewer with no default
project file it will create an unnamed project. After the project name you
can read the version of the DLT Viewer. In any case of contact with the
development team, please report the version of the DLT Viewer.

The menu consists of:

* *File* + 
    Open and save files, access DLT Viewer settings etc.
* *Search* + 
    Search for specific messages in the current log.
* *Project* + 
    Create, open and save DLT Viewer projects.
* *Config* + 
    Add, edit and remove ECUs, applications and contexts.
* *DLT* + 
    Additional functions concerning the DLT daemon and the current configuration.
* *Filter* + 
    Create, open and save filters for the message log.
* *Plugin* + 
    Enable, show and edit plugins.
* *View* + 
    Select the visible components of the DLT Viewer.
* *Help* + 
    Get information and help for the DLT Viewer.

The menu provides main functions to the user. Many menu functions are also easily accessible through the toolbar.
Hover the cursor over toolbar buttons to see their functions.
|image:images/Mark2.png[width="64"]|Project Panel

* Config 
* Filter 
* Plugin |The project widget allows you to configure and control the project,
load an existing project, save a changed configuration to the DLT Daemon and
more. The project panel is split into three tabs:

* The "Config" tab, which contains all connected ECUs/Devices. Each Device contains
its connected applications. Each application contains its used contexts.
* The "Filter" tab lets you configure filters and markers, which are used to show or
mark only a defined subset of DLT messages in the log.
* The "Plugin" tab shows the available DLT Viewer plugins. The development team provides a
plugin SDK to you. You are able to write your own DLT Viewer plugins to decode
messages, display an extra GUI panel or control the Viewer and target applications. More information about the Plugin SDK can be found here: + 
http://projects.genivi.org/diagnostic-log-trace/sites/projects.genivi.org.diagnostic-log-trace/files/dlt_viewer_plugins_programming_guide.html

In the settings you can select a default project, which is loaded during start-up.
|image:images/Mark3.png[width="64"]|DLT Message Table|In the DLT Message Table you
see all DLT messages in the current DLT log file. Newly received DLT messages are written to the end of the log file.
If the _AutoScroll_ option is enabled in the settings, the table will scroll along with
new DLT messages while they are received.

The columns in the message table are:

* *Index* + 
    Index of the DLT message in the DLT log file.
* *Time* + 
    Time when the message was received.
* *Timestamp* + 
    Time when the message was sent, measured since the startup of the target.
* *Count* + 
    Cyclical counter, one per context. Can be used to detect lost messages.
* *Ecuid* + 
    Name of the sending ECU. Defined in the "Projects" tab.
* *Apid* + 
    Indetifier of the message sender application. Defined by the sending application.
* *Ctid* +
    Context indentifier of the message sender. Defined by the sending application.
* *Type* + 
    Type of the message (Log / Trace).
* *Subtype* + 
    Log level or trace type.
* *Mode* + 
    Verbose or Non-Verbose.
* *Args* + 
    The number of arguments in the payload of the message.
* *Payload* + 
    The payload shows all parameters of the log message as text.

If a filter is configured, you will see only DLT messages which match
this filter. Remove or disable all filters if you want to see all messages.
If there are decoder plugins and a DLT message matches one of these plugins, the decoded
payload is displayed instead of the raw payload.
DLT log files can be loaded and saved in the file menu.
|image:images/Mark4.png[width="64"]|Plugin Widgets|Viewer plugins provide one or more widgets to
display additional data. You can choose which plugins are to be shown in the "Plugin" tab.
|image:images/Mark5.png[width="64"]|Footer|The footer shows information about the current log file
and the build version and options of the DLT Viewer.
|=============================================================================

Project Panel
~~~~~~~~~~~~~

Config Tab
^^^^^^^^^^

image:images/project_widget.png[]

In the config tab you can see a hierarchical list of all configured devices,
applications and contexts.

* The ECU item lists the ID of the ECU, its status (red = offline, yellow = connecting,
green = online), a description of the ECU including the connection interface, the default
log level and the default trace status.
* The application item lists the ID and the description of the application.
* The context item lists the ID, the description, the log level and the trace
status of the context.

Double clicking an item lets you configure it. Right clicking an item gets you a context menu, depending on the type of the item:

- Right click on empty space: + 
    image:images/ecu_add.png[]

- Right click on an ECU: + 
    image:images/ecu_context_menu.png[]

- Right click on an application: + 
    image:images/app_context_menu.png[]

- Right click on a context: + 
    image:images/ctx_context_menu.png[]


Filter Tab
^^^^^^^^^^

image:images/filter_widget.png[]

The Filter list gives you an overview of all configured filters. Only DLT messages which match the enabled filters are displayed.
Double clicking a filter item lets you change the filter. Each filter can be customized to include or exclude messages, to check for
specific ECUs, applications or contexts, for header and payload content and more. It is also possible to create marker filters, which don't
include or exclude any messages but highlight them in a selected color.

By right clicking you get the following context menu:

image:images/filter_context_menu.png[]

Both the "Load Filter" and the "Append Filter" option will load a saved filter file, but "Load Filter" will reset your current filter list while appending keeps it.

The filters you set will apply to all incoming or loaded DLT messages. If you also want to apply the filters to previously logged messages, hit the
"Apply Configuration" button on the top of the "Filter" tab.

Plugin Tab
^^^^^^^^^^

image:images/plugin_widget.png[]

The plugin list shows all loaded plugins. 
Plugins are used to decode DLT messages, to provide additional graphical widgets, to control the viewer, to send injection messages to target applications or a mixture of all these. Double clicking a
plugin item creates a popup window which lets you enable/disable the plugin and select a configuration file for it.

* The "Name" column shows the name of each plugin. This name is provided by the plugin itself.
* The "Interface" column tells you the type of the plugin (or more precisely: what interfaces it implements). For each plugin this column shows a combination of "View", "Decode", "Ctrl" and "Command".
* The "Status" column shows which plugins are enabled and visible. Only plugins that implement the "View" interface can have the status "Visible".
* The "Info" column lists the number of description items for each plugin. The description items can be seen by expanding plugin items that have an arrow next to them.
* The "File" column tells you the path of the configuration file or files for plugins that have such a file or files selected. Double click on plugin items to choose configuration files for them.

Plugin overview
~~~~~~~~~~~~~~~

The feature set of the DLT Viewer can be easily extended with DLT Viewer plugins.
Plugins have full read access to trace messages, they can decode messages,
provide additional representations inside the DLT Viewer GUI, control the Viewer or send injection messages to target applications,
depending on which DLT interfaces the respective plugin implements. It's easy to write your own DLT Viewer plugin, examples are provided in the DLT Viewer source code.

Plugin SDK
^^^^^^^^^^

You can find a more detailed documenation of all plugin interfaces in the "Dlt Viewer Plugins Programming Guide": +
http://projects.genivi.org/diagnostic-log-trace/sites/projects.genivi.org.diagnostic-log-trace/files/dlt_viewer_plugins_programming_guide.html

Here is an overview of the some useful plugins:

Non Verbose Mode Plugin
^^^^^^^^^^^^^^^^^^^^^^^

Interface::
    * QDLTPluginInterface
    * QDLTPluginDecoderInterface
Description::
    Decodes the DLT non-verbose messages after a catalog file has been loaded.


DLT Viewer Plugin
^^^^^^^^^^^^^^^^^

Interface::
    * QDLTPluginInterface
    * QDltPluginViewerInterface
Description::
    Advanced visual representation for selected log messages.
Screenshot::
    image:images/Viewer_plugin.png[]


Filetransfer Plugin
^^^^^^^^^^^^^^^^^^^

*Widget:*

Interface::
    * QDLTPluginInterface
    * QDltPluginViewerInterface
    * QDltPluginControlInterface
Description::
    Files like screenshots, coredumps etc. logged by a DLT Filetransfer application
    can be viewed and saved with this plugin.
Screenshot::
    image:images/filetransfer_plugin.png[]

*Command line usage:*

You can use the Filetransfer Plugin to extract files out of a stored dlt file.
To do this, call the Viewer with this command:

[dlt_Viewer.exe] -p project_filetransfer.dlp -l filewithattachements.dlt -e "Filetransfer Plugin|export|[path_to_extract]"

* [dlt_Viewer.exe] + 
    The executable of the DLT Viewer. E.g. dlt_Viewer.exe in Windows, dlt_Viewer in Linux
* project_filetransfer.dlp: + 
    A project, which has the filetransfer properly configured, by setting a valid plugin xml.
* filewithattachements.dlt: + 
    Path to a dlt trace file. If it contains embedded files, they will be extracted
* -e: + 
    triggers a plugin command
* "Filetransfer Plugin: + 
    Filetransfer Plugin will be called for the command interface
* export: + 
    the export function is called
* [path_to_extract]": + 
    Path to the folder where you want to extract all file dumps. If you apply this for a lot of files, think about using individual paths, to avoid overwriting files with identical names.


Install, remove, enable and disable plugins on Windows
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The DLT Viewer will look for plugins in two places. The first place is the
"plugins" folder inside the main application path. After that, if "pluginsPath" is
defined in the DLT Viewer settings, the application will also look in this specified location for plugins.

You can install plugins by putting them into one of the directories mentioned,
and uninstall them by removing them from these directories.

It is also possible to enable or disable plugins in the DLT Viewer itself.
To do this, double-click or right-click on a plugin in the "Plugins" tab. You will get a
drop-down menu for enabling and disabling the plugin. When enabled,
messages are passed to the plugin. When disabled, the plugin will be ignored in
the message processing chain. For plugins that implement the "viewer" interface,
there is also a third selection, "Enable and Show", which brings up the UI widget of
this plugin.

Install, remove, enable and disable plugins on Linux
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Under Linux, organizing plugins works in a similar fashion. In addition to the previously mentioned folders,
the Linux version will also look into "/usr/share/dlt-Viewer/plugins" for any plugins.
You will need to have root permissions to modify the plugin directories that are installed system-wide.
To organize plugins without root permissions, you can set the user defined plugin directory in the DLT Viewer
settings to some other path, e.g. somewhere in your home directory.

Best Practices
--------------

Connect to ECU
~~~~~~~~~~~~~~

Press the connect button to connect to the target:
image:images/connect_button.png[]

If no ECU is configured, the ECU configuration dialog appears. Select the
"Interface Type" you want to use (TCP or serial).

image:images/ecu_dialog.png[]

If you choose a TCP connection configure the Hostname of the target ECU.

image:images/ecu_dialog_tcp.png[]

If you choose a serial connection, select the serial port. Check the COM port,
where your serial device is connected in your Windows configuration. A drop down
list provides a list of examples for the port configuration.

image:images/ecu_dialog_serial.png[]

If you select "OK" the DLT Viewer will try to connect to the ECU.
The ECU Id shows "online" (green) as soon as the DLT Viewer is connected to the
specified device.
All received DLT messages should then be displayed in DLT message table.


Available List of Contexts
~~~~~~~~~~~~~~~~~~~~~~~~~~

When you are connected to an ECU, you can get a list of available contexts
in the ECU. Select an ECU item in the Config window. Right click on the
selected ECU and select the context menu item "DLT Get Log Info".
The DLT Viewer then sends a request to the target and receives a result
with all available contexts and their log levels. The list of available contexts is added
to your "Config" list.

Working with DLT Log Files
~~~~~~~~~~~~~~~~~~~~~~~~~~

When you start the DLT Viewer, a temporary log file is created.
All received DLT messages get stored in this temporary log file and
shown in the DLT message table.
Select the menu option "File"->"Save As" to copy your temporary log file to a
file you have selected. Select "File"->"New" if you want to create and save a new,
empty log file.

Non Verbose Mode Description
~~~~~~~~~~~~~~~~~~~~~~~~~~~~

If you receive DLT messages in non verbose mode, you need to decode them
to see their plain text. To do this, go to the "Plugin" tab in the "Project" panel.
Double click on the plugin "Non Verbose Mode Plugin". In the dialog that appears,
you can open a configuration file to load. Use this to load a non verbose XML description file,
which corresponds to your software on the ECU. Hit "OK" and the Plugin shows a list of all available
non verbose messages. As soon as you select a DLT message you can view the
decoded information. Incoming messages that fit the description file will now get decoded. To also
decode the already received messages, hit "Apply Configuration" on the top of the "Plugin" tab.