drsuapi_dissect_element_DsReplicaObjectIdentifier_dn parents append
[wireshark-sm.git] / doc / wsug_src / wsug_telephony.adoc
blob98d71a229318c23797599e0f93508148c67e2a42
1 // WSUG Chapter Telephony
3 [#ChTelephony]
5 == Telephony
7 [#ChTelIntroduction]
9 === Introduction
11 Wireshark provides a wide range of telephony related network statistics which
12 can be accessed via the menu:Telephony[] menu.
14 These statistics range from specific signaling protocols, to analysis of
15 signaling and media flows. If encoded in a compatible encoding the media flow
16 can even be played.
18 The protocol specific statistics windows display detailed information of
19 specific protocols and might be described in a later version of this document.
21 Some of these statistics are described at the
22 {wireshark-wiki-url}Statistics pages.
24 [#ChTelPlayingCalls]
26 === Playing VoIP Calls
28 The tool for playing VoIP calls is called <<ChTelRtpPlayer,RTP Player>>. It shows RTP streams and its waveforms, allows play stream and export it as audio or payload to file. Its capabilities depend on supported codecs.
30 ==== Supported codecs
32 RTP Player is able to play any codec supported by an installed plugin. The codecs supported by RTP Player depend on the version of Wireshark you're using. The official builds contain all of the plugins maintained by the Wireshark developers, but custom/distribution builds might not include some of those codecs. To check your Wireshark installation's installed codec plugins, do the following:
34 * Open menu:Help[About Wireshark] window
35 * Select the menu:Plugins[] tab
36 * In the menu:Filter by type[] menu on the top-right, select codec
38 .List of supported codecs
39 image::images/ws-about-codecs.png[{screenshot-attrs}]
41 ==== Work with RTP streams - Playlist
43 Wireshark can be used for RTP stream analysis. User can select one or more streams which can be played later. RTP Player window maintains playlist (list of RTP streams) for this purpose.
45 Playlist is created empty when RTP Player window is opened and destroyed when window is closed. RTP Player window can be opened on background when not needed and put to front later. During its live, playlist is maintained.
47 When RTP Player window is opened, playlist can be modified from other tools (Wireshark windows) in three ways:
49 * button menu:Play Streams[Set playlist] clears existing playlist and adds streams selected in the tool.
50 * button menu:Play Streams[Add to playlist] adds streams selected in the tool to playlist. Duplicated streams are not inserted again.
51 * button menu:Play Streams[Remove from playlist] removes streams selected in the tool from playlist, if they are in the playlist.
53 .btn:[Play Streams] button with opened action menu
54 image::images/ws-tel-rtp-player_button.png[]
56 btn:[Play Streams] button can be clicked directly and opens RTP Player window directly with btn:[Set playlist] action. All actions can be selected with the small down arrow next to the button.
58 When the playlist is empty, there is no difference between btn:[Set playlist] and btn:[Add to playlist]. When the RTP Player window is not opened, all three actions above open it.
60 btn:[Remove from playlist] is useful e.g. in case user selected all RTP streams and wants to remove RTP streams from specific calls found with menu:VoIPCalls[].
62 Tools below can be used to maintain content of playlist, they contain btn:[Play Streams] button. You can use one of procedures (Note: btn:[Add to playlist] action is demonstrated):
64 * Open menu:Telephony[RTP > RTP Streams] window, it will show all streams in the capture. Select one or more streams and then press btn:[Play Streams]. Selected streams are added to playlist.
65 * Select any RTP packet in packet list, open menu:Telephony[RTP > Stream Analysis] window. It will show analysis of selected forward stream and its reverse stream (if btn:[Ctrl] is pressed during window opening). Then press btn:[Play Streams]. Forward and reverse stream is added to playlist.
66 ** menu:RTP Stream Analysis[] window can be opened from other tools too.
67 * Open menu:Telephony[VoIP Calls] or menu:Telephony[SIP Flows] window, it will show all calls. Select one or more calls and then press btn:[Play Streams]. It will add all RTP streams related to selected calls to playlist.
68 * Open btn:[Flow Sequence] window in menu:Telephony[VoIP Calls] or menu:Telephony[SIP Flows] window, it will show flow sequence of calls. Select any RTP stream and then press btn:[Play Streams]. It will add selected RTP stream to playlist.
70 .Tools for modifying playlist in RTP Player window
71 image::images/ws-tel-playlist.png[]
73 [NOTE]
74 ====
75 Same approach with set/add/remove actions is used for RTP Stream Analysis window. The playlist is there handled as different tabs in the window, see <<ChTelRTPAnalysis,RTP Stream Analysis>> window.
76 ====
78 [#ChTelPlayingCallsLive]
80 ==== Playing audio during live capture
82 Decoding RTP payload and showing waveforms is time consuming task. To speedup it RTP Player window uses copy of packet payload for all streams in the playlist. During live capture the dialog is not refreshed automatically as other Wireshark dialogs, but user must initiate it.
84 The copy is created or refreshed and dialog updated:
86 * Every time window is opened.
87 * Every time a new stream is added or set.
88 * During live capture, when btn:[Refresh streams] is pressed.
89 * Every time live capture is finished/stopped by a user.
91 When capture file is opened (no live capturing), streams are read complete, no user action is required. Button btn:[Refresh streams] is disabled as it is useless.
93 When live capture is running, streams are read only till "now" and are shown. When stream is continuous and user would like to see additional part, they must press btn:[Refresh stream]. When the user ends live capture, view is refreshed and button is disabled.
95 [NOTE]
96 ====
97 RTP Player dialog stays open even live capture is stopped and then started again. Play list stays unchanged. Therefore, btn:[Refresh stream] tries to read same streams as before and shows them if they are still running. Past part of them (from previous live capture) is lost.
98 ====
100 ==== RTP Decoding Settings
102 RTP is carried usually in UDP packets with random source and destination ports. Therefore, Wireshark can only recognize RTP streams based on VoIP signaling, e.g., based on SDP messages in SIP signaling. If signaling is not captured, Wireshark shows just UDP packets. However, there are multiple settings which help Wireshark recognize RTP even when there is no related signaling.
104 You can use <<ChAdvDecodeAsFig,Decode As...>> function from menu:Analyze[Decode As...] menu or in mouse context menu. Here you can set that traffic on specific source or destination should be decoded as RTP. You can save settings for later use.
106 Use of menu:Decode As...[] menu works fine, but is arduous for many streams.
108 You can enable heuristic dissector menu:rtp_udp[] in menu:Analyze[Enabled Protocols...]. See <<ChCustProtocolDissectionSection>> for details. Once menu:rtp_udp[] is enabled, Wireshark tries to decode every UDP packet as RTP. If decoding is possible, packet (and entire UDP stream) is decoded as RTP.
110 When an RTP stream uses a well-known port, the heuristic dissector ignores it. So you might miss some RTP streams. You can enable setting for udp protocol menu:Preferences[Protocols > udp > Try heuristic sub-dissectors first], see <<ChCustPreferencesSection>>. In this case heuristics dissector tries to decode UDP packet even it uses a well-known port.
112 [NOTE]
113 ====
114 Take into account that heuristics is just simple "test" whether packet can be read as RTP. It can be false positive and you can see decoded as RTP more UDP packets than expected.
116 When you enable menu:udp[Try heuristic sub-dissectors first], it increases possibility of false positives. If you capture all traffic in network, false positives rate can be quite high.
117 ====
119 RTP Player must store decoded data somewhere to be able to play it. When data are decoded, there are audio samples and dictionary for fast navigation. Both types of data are stored in memory for default, but you can configure Wireshark to store it on disk. There are two settings:
121 * ui.rtp_player_use_disk1 - When set to FALSE (default), audio samples are kept in memory. When set to TRUE, audio samples are stored on temporary file.
122 * ui.rtp_player_use_disk2 - When set to FALSE (default), dictionary is kept in memory. When set to TRUE, dictionary is stored on temporary file.
124 When any data are configured to be stored on disk, one file is created for each stream. Therefore, there might be up to two files for one RTP stream (audio samples and dictionary). If your OS or user has OS enforced limit for count of opened files (most of Unix/Linux systems), you can see fewer streams that was added to playlist. Warnings are printed on console in this case and you will see fewer streams in the playlist than you send to it from other tools.
126 For common use you can use default settings - store everything in memory. When you will be out of memory, switch ui.rtp_player_use_disk1 to TRUE first - it saves much more memory than ui.rtp_player_use_disk2.
129 ==== VoIP Processing Performance and Related Limits
131 Processing of RTP and decoding RTP voice takes resources. There are raw estimates you can use as guidelines...
133 RTP Streams window can show as many streams as found in the capture. Its performance is limited just by memory and CPU.
135 RTP Player can handle 1000+ streams, but take into account that waveforms are very small and difficult to recognize in this case.
137 RTP Player plays audio by OS sound system and OS is responsible for mixing audio when multiple streams are played. In many cases OS sound system has limited count of mixed streams it can play/mix. RTP Player tries to handle playback failures and show warning. If it happens, just mute some streams and start playback again.
139 RTP Analysis window can handle 1000+ streams, but it is difficult to use it with so many streams - it is difficult to navigate between them. It is expected that RTP Analysis window will be used for analysis of lower tens of streams.
142 [#ChTelVoipCalls]
144 === VoIP Calls Window
146 The VoIP Calls window shows a list of all detected VoIP calls in the captured
147 traffic. It finds calls by their signaling and shows related RTP streams. The current VoIP supported protocols are:
149 * H.323
150 * IAX2
151 * ISUP
152 * MGCP/MEGACO
153 * SIP
154 * SKINNY
155 * UNISTIM
157 See {wireshark-wiki-url}VOIPProtocolFamily[VOIPProtocolFamily] for an overview of the used VoIP protocols.
159 VoIP Calls window can be opened as window showing all protocol types (menu:Telephony[VoIP Calls] window) or limited to SIP messages only (menu:Telephony[SIP Flows] window).
161 .VoIP Calls window
162 image::images/ws-tel-voip-calls.png[{screenshot-attrs}]
164 User can use shortcuts:
166 * Selection
167 ** kbd:[Ctrl + A] - Select all streams
168 ** kbd:[Ctrl + I] - Invert selection
169 ** kbd:[Ctrl + Shift + A] - Select none
170 ** Note: Common kbd:[Mouse click], kbd:[Shift + Mouse click] and kbd:[Ctrl + Mouse click] works too
171 * On selected call/calls
172 ** kbd:[S] - Selects stream/streams related to call in RTP Streams window (if not opened, it opens it and put it on background).
173 ** kbd:[D] - Deselects stream/streams related to call in RTP Streams window (if not opened, it opens it and put it on background).
175 Available controls are:
177 * btn:[Limit to display filter] filters calls just to ones matching display filter. When display filter is active before window is opened, checkbox is checked.
178 * btn:[Time of Day] switches format of shown time between relative to start of capture or absolute time of received packets.
179 * btn:[Flow Sequence] opens <<ChStatFlowGraph,Flow Sequence>> window and shows selected calls in it.
180 * btn:[Prepare Filter] generates display filter matching to selected calls (signaling and RTP streams) and apply it.
181 * btn:[Play Streams] opens <<ChTelRtpPlayer,RTP Player>> window. Actions btn:[Set], btn:[Add] and btn:[Remove] are available.
182 * btn:[Copy] copies information from table to clipboard in CSV or YAML.
184 [#ChTelANSI]
186 === ANSI
188 This menu shows groups of statistic data for mobile communication protocols according to ETSI GSM standards.
190 ==== A-I/F BSMAP Statistics Window
192 The A-Interface Base Station Management Application Part (BSMAP) Statistics window shows the messages list and the number of the captured messages. There is a possibility to filter the messages, copy or save the date into a file.
194 ==== A-I/F DTAP Statistics Window
196 The A-Interface Direct Transfer Application Part (DTAP) Statistics widow shows the messages list and the number of the captured messages. There is a possibility to filter the messages, copy or save the date into a file.
198 [#ChTelGSM]
200 === GSM Windows
202 The Global System for Mobile Communications (GSM) is a standard for mobile networks. This menu shows a group of statistic data for mobile communication protocols according to ETSI GSM standard.
204 [#ChTelIAX2Analysis]
206 === IAX2 Stream Analysis Window
208 The “IAX2 Stream Analysis” window shows statistics for the forward and reverse
209 streams of a selected IAX2 call along with a graph.
211 [#ChTelISUPMessages]
213 === ISUP Messages Window
215 Integrated Service User Part (ISUP) protocol provides voice and non-voice signaling for telephone communications. ISUP Messages menu opens the window which shows the related statistics. The user can filter, copy or save the data into a file.
217 [#ChTelLTE]
219 === 3GPP Uu
221 [#ChTelLTEMACTraffic]
223 ==== 3GPP MAC Traffic Statistics Window
225 Statistics of the captured LTE or NR MAC traffic. This window will summarize the
226 MAC traffic found in the capture.
228 .The “3GPP MAC Traffic Statistics” window
229 image::images/ws-stats-lte-mac-traffic.png[{screenshot-attrs}]
231 Each row in the top pane
232 shows statistical highlights for exactly one UE/C-RNTI. Opening a UE item shows details of each logical channel identifier of that UE.
234 The bottom pane shows statistics for common channels, and controls to apply more detailed display filters to the packet list.
236 [#ChTelLTERLCGraph]
238 ==== 3GPP RLC Graph Window
240 The RLC Graph menu launches a graph which shows LTE/NR Radio Link Control protocol sequence numbers changing over time along with (for AM) acknowledgements
241 received in the opposite direction.
243 NOTE: That graph shows data of a single bearer and direction. This graph may also be launched from the `RLC Statistics` window.
245 .The RLC Graph window
246 image::images/ws-rlc-graph.png[{screenshot-attrs}]
248 [.small]#_The image of the RLC Graph is borrowed from link:{wireshark-wiki-url}RLC-LTE[the Wireshark wiki]._#
250 [#ChTelLTERLCTraffic]
252 ==== RLC Statistics Window
254 Statistics of the captured LTE/NR RLC traffic. This window will summarize the
255 RLC traffic found in the capture.
257 .The “LTE RLC Traffic Statistics” window
258 image::images/ws-stats-lte-rlc-traffic.png[{screenshot-attrs}]
260 A check-box controls whether this window should include RLC PDUs logged within
261 MAC PDUs or not. This will affect both the PDUs counted as well as the display
262 filters generated (see below).
264 The upper list shows summaries of each active UE. Opening up a UE entry will
265 show the same information broken down by individual bearers.
267 The lower part of the windows allows display filters to be generated and set for
268 the selected bearer/channel. Note that in the case of Acknowledged Mode channels, if a
269 single direction is chosen, the generated filter will show data in that
270 direction and control PDUs in the opposite direction.
272 [#ChTelMTP3]
274 === MTP3 Windows
276 The Message Transfer Part level 3 (MTP3) protocol is a part of the Signaling System 7 (SS7). The Public Switched Telephone Networks use it for reliable, unduplicated and in-sequence transport of SS7 messaging between communication partners.
278 This menu shows MTP3 Statistics and MTP3 Summary windows.
280 [#ChTelOsmux]
282 === Osmux Windows
284 OSmux is a multiplex protocol designed to reduce bandwidth usage of satellite-based GSM systems's voice (RTP-AMR) and signaling traffic. The OSmux menu opens the packet counter window with the related statistic data. The user can filter, copy or save the data into a file.
286 [#ChTelRTP]
288 === RTP
290 [#ChTelRTPStreams]
292 ==== RTP Streams Window
294 The RTP streams window shows all RTP streams in capture file. Streams can be selected there and on selected streams other tools can be initiated.
296 .The “RTP Streams” window
297 image::images/ws-tel-rtp-streams.png[{screenshot-attrs}]
299 User can use shortcuts:
301 * Selection
302 ** kbd:[Ctrl + A] - Select all streams
303 ** kbd:[Ctrl + I] - Invert selection
304 ** kbd:[Ctrl + Shift + A] - Select none
305 ** Note: Common kbd:[Mouse click], kbd:[Shift + Mouse click] and kbd:[Ctrl + Mouse click] works too
306 * Find Reverse
307 ** kbd:[R] - Try search for reverse streams related to already selected streams. If found, selects them in the list too.
308 ** btn:[Shift+R] - Select all pair streams (forward/reverse relation).
309 ** btn:[Ctrl+R] - Select all single streams (no reverse stream does exist).
310 * kbd:[G] - Go to packet of stream under the mouse cursor.
311 * kbd:[M] - Mark all packets of selected streams.
312 * kbd:[P] - Prepare filter matching selected streams and apply it.
313 * kbd:[E] - Export selected streams in RTPDump format.
314 * kbd:[A] - Open <<ChTelRTPAnalysis,RTP Stream Analysis>> window and add selected streams to it.
316 Available controls are:
318 * Find Reverse
319 ** btn:[Find Reverse] search for reverse stream of every selected stream. If found, selects it in the list too.
320 ** btn:[Find All Pairs] select all streams which have forward/reverse relation.
321 ** btn:[Find Only Single] select all streams which are single - have no reverse stream.
322 * btn:[Analyze] opens <<ChTelRTPAnalysis,RTP Stream Analysis>> window. Actions btn:[Set], btn:[Add] and btn:[Remove] are available.
323 * btn:[Prepare Filter] prepares filter matching selected streams and apply it.
324 * btn:[Play Streams] opens <<ChTelRtpPlayer,RTP Player>> window. Actions btn:[Set], btn:[Add] and btn:[Remove] are available.
325 * btn:[Copy] copies information from table to clipboard in CSV or YAML.
326 * btn:[Export] exports selected streams in RTPDump format.
329 [#ChTelRTPAnalysis]
331 ==== RTP Stream Analysis Window
333 The RTP analysis function takes the selected RTP streams and generates a list of
334 statistics on them including a graph.
336 The menu:Telephony[RTP > RTP Stream Analysis] menu item is enabled only when the
337 selected packet is an RTP packet. When the action is selected, the RTP Stream
338 Analysis window is opened (if not already) and the RTP stream of the current
339 packet is added for analysis. If btn:[Ctrl] is pressed when selecting the
340 menu item, other RTP streams on the same addresses and ports (in both forward
341 and reverse direction) are scanned for and added to the window too if found.
343 Every stream is shown on its own tab. Tabs are numbered as streams are added
344 and each tooltip shows the identification of the stream. When a tab is closed,
345 its number is not reused. The tab color matches the color of the corresponding
346 graph on the graph tab.
348 .The “RTP Stream Analysis” window
349 image::images/ws-tel-rtpstream-analysis_1.png[{screenshot-attrs}]
351 .Error indicated in “RTP Stream Analysis” window
352 image::images/ws-tel-rtpstream-analysis_3.png[{screenshot-attrs}]
354 Per packet statistic shows:
356 * Packet number
357 * Sequence number
358 * Delta (ms) to last packet
359 * Jitter (ms)
360 * Skew
361 * Bandwidth
362 * Marker - packet is marked in RTP header
363 * Status - information related to the packet. E. g. change of codec, DTMF number, warning about incorrect sequence number.
365 Side panel left to packet list shows stream statistics:
367 * Maximal delta and at which packet it occurred
368 * Maximal jitter
369 * Mean jitter
370 * Maximal skew
371 * Count of packets
372 * Count of lost packets - calculated from sequence numbers
373 * When the stream starts and first packet number
374 * Duration of the stream
375 * Clock drift
376 * Frequency drift
378 [NOTE]
379 ====
380 Some statistic columns are calculated only when Wireshark is able to decode codec of RTP stream.
381 ====
383 Available shortcuts are:
385 * kbd:[G] - Go to selected packet of stream in packet list
386 * kbd:[N] - Move to next problem packet
388 Available controls are:
390 * Prepare Filter
391 ** btn:[Current Tab] prepares filter matching current tab and applies it.
392 ** btn:[All Tabs] prepares filter matching all tabs and applies it.
393 * btn:[Play Streams] opens <<ChTelRtpPlayer,RTP Player>> window. Actions btn:[Set], btn:[Add] and btn:[Remove] are available.
394 * btn:[Export] allows export current stream or all streams as CSV or export graph as image in multiple different formats (PDF, PNG, BMP and JPEG).
396 .Graph in “RTP Stream Analysis” window
397 image::images/ws-tel-rtpstream-analysis_2.png[{screenshot-attrs}]
399 Graph view shows graph of:
401 * jitter
402 * difference - absolute value of difference between expected and real time of packet arrival
403 * delta - time difference from reception of previous packet
405 for every stream. Checkboxes below graph are enabling or disabling showing of a graph for every stream. btn:[Stream X] checkbox enables or disables all graphs for the stream.
407 [NOTE]
408 ====
409 Stream Analysis window contained tool for save audio and payload for analyzed streams. This tool was moved in Wireshark 3.5.0 to <<ChTelRtpPlayer,RTP Player>> window. New tool has more features.
410 ====
412 [#ChTelRtpPlayer]
414 ==== RTP Player Window
416 The RTP Player function is a tool for playing VoIP calls. It shows RTP streams
417 and their waveforms, and can play the streams and export them to file as audio
418 or raw payload. See related concepts in <<ChTelPlayingCalls>>.
420 The menu:Telephony[RTP > RTP Player] menu item is enabled only when the
421 selected packet is an RTP packet. When the action is selected, the RTP Player
422 window is opened (if not already) and the RTP stream of the current packet is
423 added to the playlist. If btn:[Ctrl] is pressed when selecting the menu item,
424 other RTP streams on the same addresses and ports (in both forward and reverse
425 direction) are scanned for and added to the playlist too if found.
427 .RTP Player window
428 image::images/ws-tel-rtp-player_1.png[{screenshot-attrs}]
430 RTP Player Window consists of three parts:
432 . Waveform view
433 . Playlist
434 . Controls
436 Waveform view shows visual presentation of RTP stream. Color of waveform and playlist row are matching. Height of wave shows volume.
438 Waveform shows error marks for Out of Sequence, Jitter Drops, Wrong Timestamps and Inserted Silence marks if it happens in a stream.
440 .Waveform with error marks
441 image::images/ws-tel-rtp-player_3.png[{screenshot-attrs}]
443 Playlist shows information about every stream:
445 * Play - Audio routing
446 * Source Address, Source Port, Destination Address, Destination Port, SSRC
447 * Setup Frame
448 ** SETUP <number> is shown, when there is known signaling packet. Number is packet number of signaling packet. Note: Word SETUP is shown even RTP stream was initiated e. g. by SKINNY where no SETUP message exists.
449 ** RTP <number> is shown, when no related signaling was found. Number is packet number of first packet of the stream.
450 * Packets - Count of packets in the stream.
451 * Time Span - Start - Stop (Duration) of the stream
452 * SR - Sample rate of used codec
453 * PR - Decoded play rate used for stream playing
454 * Payloads - One or more payload types used by the stream
456 [NOTE]
457 ====
458 When rtp_udp is active, most of streams shows just RTP <number> even there is setup frame in capture.
460 When RTP stream contains multiple codecs, SR and PR is based on first observed coded. Later codecs in stream are resampled to first one.
461 ====
463 Controls allow a user to:
465 * btn:[Start]/btn:[Pause]/btn:[Stop] playing of unmuted streams
466 * btn:[>>] enabling/disabling silence skipping
467 ** Min silence - Minimal duration of silence to skip in seconds. Shorter silence is played as it is.
468 * Select btn:[Output audio device] and btn:[Output audio rate]
469 * Select btn:[Playback Timing]
470 ** Jitter Buffer - Packets outside btn:[Jitter Buffer] size are discarded during decoding
471 ** RTP Timestamp - Packets are ordered and played by its Timestamp, no Jitter Buffer is used
472 ** Uninterrupted Mode - All gaps (e. g. Comfort Noise, lost packets) are discarded therefore audio is shorted than timespan
473 * btn:[Time of Day] selects whether waveform timescale is shown in seconds from start of capture or in absolute time of received packets
474 * btn:[Refresh streams] refreshes streams during live capture (see <<ChTelPlayingCallsLive>>). Button is disabled when no live capture is running.
475 * Inaudible streams
476 ** btn:[Select] select all inaudible streams (streams with zero play rate)
477 ** btn:[Deselect] deselect all inaudible streams (streams with zero play rate)
478 * btn:[Analyze] open <<ChTelRTPAnalysis,RTP Stream Analysis>> window. Actions btn:[Set], btn:[Add] and btn:[Remove] are available.
479 * btn:[Prepare Filter] prepare filter matching selected streams and apply it.
480 * btn:[Export] - See <<tel-rtp-export>>.
482 [NOTE]
483 ====
484 RTP Player detects silence just by missing voice samples (Comfort Noise, interrupted RTP, missing RTP, ...) or when some streams are muted.
485 ====
487 .RTP stream state indication
488 image::images/ws-tel-rtp-player_2.png[{screenshot-attrs}]
490 Waveform view and playlist shows state of a RTP stream:
492 . stream is muted (dashed waveform, menu:Muted[] is shown in Play column) or unmuted (non-dashed waveform, audio routing is shown in Play column)
493 . stream is selected (blue waveform, blue row)
494 . stream is below mouse cursor (bold waveform, bold font)
496 User can control to where audio of a stream is routed to:
498 * L - Left channel
499 * L+R - Left and Right (Middle) channel
500 * R - Left channel
501 * P - Play (when mono soundcard is available only)
502 * M - Muted
504 Audio routing can be changed by double-clicking on first column of a row, by shortcut or by menu.
506 User can use shortcuts:
508 * Selection
509 ** kbd:[Ctrl + A] - Select all streams
510 ** kbd:[Ctrl + I] - Invert selection
511 ** kbd:[Ctrl + Shift + A] - Select none
512 ** Note: Common kbd:[Mouse click], kbd:[Shift + Mouse click] and kbd:[Ctrl + Mouse click] works too
513 * Go to packet
514 ** kbd:[G] - Go to packet of stream under the mouse cursor
515 ** kbd:[Shift + G] - Go to setup packet of stream under the mouse cursor
516 * Audio routing
517 ** kbd:[M] - Mute all selected streams
518 ** kbd:[Shift + M] - Unmute all selected streams
519 ** kbd:[Ctrl + M] - Invert muting of all selected streams
520 * kbd:[P] - Play audio
521 * kbd:[S] - Stop playing
522 * kbd:[Del] or kbd:[Ctrl + X] - Remove all selected streams from playlist
523 * Inaudible steams
524 ** kbd:[N] - Select all inaudible streams
525 ** kbd:[Shift + N] - Deselect all inaudible streams
527 [#tel-rtp-export]
529 ===== Export
531 [NOTE]
532 ====
533 menu:Export[] was moved from menu:RTP Stream Analysis[] window to menu:RTP Player[] window in 3.5.0.
535 Wireshark is able to export decoded audio in .au or .wav file format. Prior to version 3.2.0, Wireshark only supported exporting audio using the G.711 codec. From 3.2.0 it supports audio export using any codec with 8000 Hz sampling. From 3.5.0 is supported export of any codec, rate is defined by Output Audio Rate.
536 ====
538 Export options available:
540 * for one or more selected non-muted streams
541 ** From cursor - Streams are saved from play start cursor. If some streams are shorter, they are removed from the list before save and count of saved streams is lower than count of selected streams.
542 ** Stream Synchronized Audio - File starts at the begin of earliest stream in export, therefore there is no silence at beginning of exported file.
543 ** File Synchronized Audio - Streams starts at beginning of file, therefore silence can be at start of file.
544 * for just one selected stream
545 ** Payload - just payload with no information about coded is stored in the file
547 Audio is exported as multi-channel file - one channel per RTP stream. One or two channels are equal to mono or stereo, but Wireshark can export e.g., 100 channels. For playing a tool with multi-channel support must be used (e.g., https://www.audacityteam.org/).
549 Export of payload function is useful for codecs not supported by Wireshark.
551 [NOTE]
552 ====
553 Default value of btn:[Output Audio Rate] is btn:[Automatic]. When multiple codecs with different codec rates are captured, Wireshark decodes each stream with its own play audio rate. Therefore, each stream can have a different audio rate. If you attempt to export audio when there are multiple audio rates, it will fail because .au or .wav require a fixed audio rate.
555 In this case user must manually select one of rates in btn:[Output Audio Rate], streams will be resampled and audio export succeeds.
556 ====
558 [#ChTelRTSP]
560 === RTSP Window
562 In the Real Time Streaming Protocol (RTSP) menu the user can check the Packet Counter window. It shows Total RTCP Packets and divided into RTSP Response Packets, RTSP Request Packets and Other RTSP packets. The user can filter, copy or save the data into a file.
564 [#ChTelSCTP]
566 === SCTP Windows
568 Stream Control Transmission Protocol (SCTP) is a computer network protocol which provides a message transfer in telecommunication in the transport layer. It overcomes some lacks of User Datagram Protocol (UDP) and Transmission Control Protocol (TCP). The SCTP packets consist of the _common header_ and the _data chunks_.
570 The SCTP Analyze Association window shows the statistics of the captured packets between two Endpoints. You can check the different chunk types by pressing btn:[Chunk Statistics] button in the `Statistics` tab. In the `Endpoint` tabs you can see various statistics, such as IP addresses, ports and others. You can also check different graphs here.
572 .SCTP Analyze Association window
573 image::images/ws-sctp-1-association.png[{screenshot-attrs}]
575 The SCTP Associations window shows the table with the data for captured packets, such as port and counter. You can also call for the SCTP Analyze Association window by pressing the btn:[Analyze] button.
577 .SCTP Associations window
578 image::images/ws-sctp.png[{screenshot-attrs}]
580 [#ChTelSMPPOperations]
582 === SMPP Operations Window
584 Short Message Peer-to-Peer (SMPP) protocol uses TCP protocol as its transfer for exchanging Short Message Service (SMS) Messages, mainly between Short Message Service Centers (SMSC). The dissector determines whether the captured packet is SMPP or not by using the heuristics in the fixed header. The SMPP Operations window displays the related statistical data. The user can filter, copy or save the data into a file.
586 [#ChTelUCPMessages]
588 === UCP Messages Window
590 The Universal Computer Protocol (UCP) plays role in transferring Short Messages between a Short Message Service Centre (SMSC) and an application, which is using transport protocol, such as TCP or X.25. The UCP Messages window displays the related statistical data. The user can filter, copy or save the data into a file.
592 [#ChTelH225]
594 === H.225 Window
596 H.225 telecommunication protocol which is responsible for messages in call signaling and media stream packetization for packet-based multimedia communication systems. The H.225 window shows the counted messages by types and reasons. The user can filter, copy or save the data into a file.
598 [#ChTelSIPFlows]
600 === SIP Flows Window
602 Session Initiation Protocol (SIP) Flows window shows the list of all captured SIP transactions, such as client registrations, messages, calls and so on.
604 This window will list both complete and in-progress SIP transactions.
606 Window has same features as <<ChTelVoipCalls,VoIP Calls>> window.
608 [#ChTelSIPStatistics]
610 === SIP Statistics Window
612 SIP Statistics window shows captured SIP transactions. It is divided into SIP Responses and SIP Requests. In this window the user can filter, copy or save the statistics into a file.
614 [#ChTelWAPWSPPacketCounter]
616 === WAP-WSP Packet Counter Window
618 The WAP-WSP Packet Counter menu displays the number of packets for each Status Code and PDU Type in Wireless Session Protocol traffic. The user can filter, copy or save the data into a file.
620 // End of WSUG Chapter Telephony