Wireshark 4.7.0
The Wireshark network protocol analyzer
Loading...
Searching...
No Matches
proto.h
Go to the documentation of this file.
1/* proto.h
2 * Definitions for protocol display
3 *
4 * Wireshark - Network traffic analyzer
5 * By Gerald Combs <gerald@wireshark.org>
6 * Copyright 1998 Gerald Combs
7 *
8 * SPDX-License-Identifier: GPL-2.0-or-later
9 */
10
11
22#pragma once
23#include "wsutil/nstime.h"
24#include "tvbuff.h"
25#include <wsutil/value_string.h>
26#include "packet_info.h"
27#include "ftypes/ftypes.h"
28#include "register.h"
29#include "ws_symbol_export.h"
30#include "ws_attributes.h"
31
32#ifdef __cplusplus
33extern "C" {
34#endif /* __cplusplus */
35
45WS_DLL_PUBLIC int hf_text_only;
46
48#define ITEM_LABEL_LENGTH 240
49
50#define ITEM_LABEL_UNKNOWN_STR "Unknown"
51
52struct expert_field;
53
54/* Type-check that 'x' is compatible with 'type', should give compiler warnings otherwise. */
55#define cast_same(type, x) (0 ? (type)0 : (x))
56
58#define VALS(x) (cast_same(const struct _value_string*, (x)))
59
61#define VALS64(x) (cast_same(const struct _val64_string*, (x)))
62
64#define VALS_EXT_PTR(x) (cast_same(value_string_ext*, (x)))
65
67#define TIME_VALS(x) (cast_same(const struct _time_value_string*, (x)))
68
70#define TFS(x) (cast_same(const struct true_false_string*, (x)))
71
73#define UNS(x) (cast_same(const struct unit_name_string*, (x)))
74
75typedef void (*custom_fmt_func_t)(char *, uint32_t);
76
77typedef void (*custom_fmt_func_64_t)(char *, uint64_t);
78
79typedef void (*custom_fmt_func_double_t)(char *, double);
80
88#define CF_FUNC(x) ((const void *) (size_t) (x))
89
92#define RVALS(x) (cast_same(const struct _range_string*, (x)))
93
95#define FRAMENUM_TYPE(x) GINT_TO_POINTER(x)
96
97struct _protocol;
98
100typedef struct _protocol protocol_t;
101
112WS_DLL_PUBLIC WS_NORETURN
113void proto_report_dissector_bug(const char *format, ...)
114 G_GNUC_PRINTF(1, 2);
115
116#define REPORT_DISSECTOR_BUG(...) \
117 proto_report_dissector_bug(__VA_ARGS__)
118
122#ifdef _MSC_VER
123/* XXX - Is there a way to say "quit checking at this point"? */
124#define __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(expression) \
125 ; __analysis_assume(expression);
126#else
127#define __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(expression)
128#endif
129
141#define __DISSECTOR_ASSERT_STRINGIFY(s) # s
142
143#define __DISSECTOR_ASSERT(expression, file, lineno) \
144 (REPORT_DISSECTOR_BUG("%s:%u: failed assertion \"%s\"", \
145 file, lineno, __DISSECTOR_ASSERT_STRINGIFY(expression)))
146
147#define __DISSECTOR_ASSERT_HINT(expression, file, lineno, hint) \
148 (REPORT_DISSECTOR_BUG("%s:%u: failed assertion \"%s\" (%s)", \
149 file, lineno, __DISSECTOR_ASSERT_STRINGIFY(expression), hint))
150
151#define DISSECTOR_ASSERT(expression) \
152 ((void) ((expression) ? (void)0 : \
153 __DISSECTOR_ASSERT (expression, __FILE__, __LINE__))) \
154 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(expression)
155
163#define DISSECTOR_ASSERT_HINT(expression, hint) \
164 ((void) ((expression) ? (void)0 : \
165 __DISSECTOR_ASSERT_HINT (expression, __FILE__, __LINE__, hint))) \
166 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(expression)
167
168#if 0
169/* win32: using a debug breakpoint (int 3) can be very handy while debugging,
170 * as the assert handling of GTK/GLib is currently not very helpful */
171#define DISSECTOR_ASSERT(expression) \
172{ if(!(expression)) _asm { int 3}; }
173#endif
174
183#define DISSECTOR_ASSERT_NOT_REACHED() \
184 (REPORT_DISSECTOR_BUG("%s:%u: failed assertion \"DISSECTOR_ASSERT_NOT_REACHED\"", \
185 __FILE__, __LINE__))
186
206#define __DISSECTOR_ASSERT_CMPINT(a, op, b, type, fmt) \
207 (REPORT_DISSECTOR_BUG("%s:%u: failed assertion " #a " " #op " " #b " (" fmt " " #op " " fmt ")", \
208 __FILE__, __LINE__, (type)a, (type)b))
209
210#define DISSECTOR_ASSERT_CMPINT(a, op, b) \
211 ((void) ((a op b) ? (void)0 : \
212 __DISSECTOR_ASSERT_CMPINT (a, op, b, int64_t, "%" PRId64))) \
213 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(a op b)
214
220#define DISSECTOR_ASSERT_CMPUINT(a, op, b) \
221 ((void) ((a op b) ? (void)0 : \
222 __DISSECTOR_ASSERT_CMPINT (a, op, b, uint64_t, "%" PRIu64))) \
223 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(a op b)
224
228#define DISSECTOR_ASSERT_CMPUINTHEX(a, op, b) \
229 ((void) ((a op b) ? (void)0 : \
230 __DISSECTOR_ASSERT_CMPINT (a, op, b, uint64_t, "0x%" PRIX64))) \
231 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(a op b)
232
233/*
234 * This is similar to DISSECTOR_ASSERT(hfinfo->type == type) except that
235 * it will report the name of the field with the wrong type as well as
236 * the type.
237 *
238 * @param hfinfo The hfinfo for the field being tested
239 * @param type The type it's expected to have
240 */
241#define __DISSECTOR_ASSERT_FIELD_TYPE(hfinfo, t) \
242 (REPORT_DISSECTOR_BUG("%s:%u: field %s is not of type "#t, \
243 __FILE__, __LINE__, (hfinfo)->abbrev))
244
245#define DISSECTOR_ASSERT_FIELD_TYPE(hfinfo, t) \
246 ((void) (((hfinfo)->type == t) ? (void)0 : \
247 __DISSECTOR_ASSERT_FIELD_TYPE ((hfinfo), t))) \
248 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT((hfinfo)->type == t)
249
250#define DISSECTOR_ASSERT_FIELD_TYPE_IS_INTEGRAL(hfinfo) \
251 ((void) ((FT_IS_INTEGER((hfinfo)->type)) ? (void)0 : \
252 REPORT_DISSECTOR_BUG("%s:%u: field %s is not of type FT_CHAR or an FT_{U}INTn type", \
253 __FILE__, __LINE__, (hfinfo)->abbrev))) \
254 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(FT_IS_INTEGER((hfinfo)->type))
255
256#define __DISSECTOR_ASSERT_FIELD_TYPE_IS_STRING(hfinfo) \
257 (REPORT_DISSECTOR_BUG("%s:%u: field %s is not of type FT_STRING, FT_STRINGZ, FT_STRINGZPAD, FT_STRINGZTRUNC, or FT_UINT_STRING", \
258 __FILE__, __LINE__, (hfinfo)->abbrev))
259
260#define DISSECTOR_ASSERT_FIELD_TYPE_IS_STRING(hfinfo) \
261 ((void) (FT_IS_STRING((hfinfo)->type) ? (void)0 : \
262 __DISSECTOR_ASSERT_FIELD_TYPE_IS_STRING ((hfinfo)))) \
263 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT(FT_IS_STRING((hfinfo)->type))
264
265#define __DISSECTOR_ASSERT_FIELD_TYPE_IS_TIME(hfinfo) \
266 (REPORT_DISSECTOR_BUG("%s:%u: field %s is not of type FT_ABSOLUTE_TIME or FT_RELATIVE_TIME", \
267 __FILE__, __LINE__, (hfinfo)->abbrev))
268
269#define DISSECTOR_ASSERT_FIELD_TYPE_IS_TIME(hfinfo) \
270 ((void) (((hfinfo)->type == FT_ABSOLUTE_TIME || \
271 (hfinfo)->type == FT_RELATIVE_TIME) ? (void)0 : \
272 __DISSECTOR_ASSERT_FIELD_TYPE_IS_TIME ((hfinfo)))) \
273 __DISSECTOR_ASSERT_STATIC_ANALYSIS_HINT((hfinfo)->type == FT_ABSOLUTE_TIME || \
274 (hfinfo)->type == FT_RELATIVE_TIME)
275
276/*
277 * Encoding flags that apply to multiple data types.
278 */
279/*
280 * The encoding of a field of a particular type may involve more
281 * than just whether it's big-endian or little-endian and its size.
282 *
283 * For integral values, that's it, as 99.9999999999999% of the machines
284 * out there are 2's complement binary machines with 8-bit bytes,
285 * so the protocols out there expect that and, for example, any Unisys
286 * 2200 series machines out there just have to translate between 2's
287 * complement and 1's complement (and nobody's put any IBM 709x's on
288 * any networks lately :-)).
289 *
290 * However:
291 *
292 * for floating-point numbers, in addition to IEEE decimal
293 * floating-point, there's also IBM System/3x0 and PDP-11/VAX
294 * floating-point - most protocols use IEEE binary, but DCE RPC
295 * can use other formats if that's what the sending host uses;
296 *
297 * for character strings, there are various character encodings
298 * (various ISO 646 sets, ISO 8859/x, various other national
299 * standards, various DOS and Windows encodings, various Mac
300 * encodings, UTF-8, UTF-16, other extensions to ASCII, EBCDIC,
301 * etc.);
302 *
303 * for absolute times, there's UNIX time_t, UNIX time_t followed
304 * by 32-bit microseconds, UNIX time_t followed by 32-bit
305 * nanoseconds, DOS date/time, Windows FILETIME, NTP time, etc..
306 *
307 * We might also, in the future, want to allow a field specifier to
308 * indicate the encoding of the field, or at least its default
309 * encoding, as most fields in most protocols always use the
310 * same encoding (although that's not true of all fields, so we
311 * still need to be able to specify that at run time).
312 *
313 * So, for now, we define ENC_BIG_ENDIAN and ENC_LITTLE_ENDIAN as
314 * bit flags, to be combined, in the future, with other information
315 * to specify the encoding in the last argument to
316 * proto_tree_add_item(), and possibly to specify in a field
317 * definition (e.g., ORed in with the type value).
318 *
319 * Currently, proto_tree_add_item() treats its last argument as a
320 * Boolean - if it's zero, the field is big-endian, and if it's non-zero,
321 * the field is little-endian - and other code in epan/proto.c does
322 * the same. We therefore define ENC_BIG_ENDIAN as 0x00000000 and
323 * ENC_LITTLE_ENDIAN as 0x80000000 - we're using the high-order bit
324 * so that we could put a field type and/or a value such as a character
325 * encoding in the lower bits.
326 */
327#define ENC_BIG_ENDIAN 0x00000000
328#define ENC_LITTLE_ENDIAN 0x80000000
329
330#if G_BYTE_ORDER == G_LITTLE_ENDIAN
331 #define ENC_HOST_ENDIAN ENC_LITTLE_ENDIAN
332 #define ENC_ANTI_HOST_ENDIAN ENC_BIG_ENDIAN
333#else
334 #define ENC_HOST_ENDIAN ENC_BIG_ENDIAN
335 #define ENC_ANTI_HOST_ENDIAN ENC_LITTLE_ENDIAN
336#endif
337
338/*
339 * For protocols (FT_PROTOCOL), aggregate items with subtrees (FT_NONE),
340 * opaque byte-array fields (FT_BYTES), and other fields where there
341 * is no choice of encoding (either because it's "just a bucket
342 * of bytes" or because the encoding is completely fixed), we
343 * have ENC_NA (for "Not Applicable").
344 */
345#define ENC_NA 0x00000000
346
347/*
348 * Encoding for character strings - and for character-encoded values
349 * for non-string types.
350 *
351 * Historically, the only place the representation mattered for strings
352 * was with FT_UINT_STRINGs, where we had false for the string length
353 * being big-endian and true for it being little-endian.
354 *
355 * We now have encoding values for the character encoding. The encoding
356 * values are encoded in all but the top bit (which is the byte-order
357 * bit, required for FT_UINT_STRING and for UCS-2 and UTF-16 strings)
358 * and the bottom bit (which we ignore for now so that programs that
359 * pass true for the encoding just do ASCII).
360 *
361 * For ENC_ASCII, we map ASCII characters with the high bit set to the UTF-8
362 * REPLACEMENT CHARACTER, and do the same for ENC_UTF_8 with invalid UTF-8
363 * sequences. We should also map 0x00 to that as well - null-terminated and
364 * null-padded strings never have NULs in them, but counted strings might.
365 * Either that, or strings should be counted, not null-terminated. Note
366 * that conversion of ASCII and UTF-8 can change the length of the string,
367 * as with any other encoding, due to REPLACEMENT CHARACTERs.
368 *
369 * For display, perhaps we should also map control characters to the
370 * Unicode glyphs showing the name of the control character in small
371 * caps, diagonally. (Unfortunately, those only exist for C0, not C1.)
372 *
373 * *DO NOT* add anything to this set that is not a character encoding!
374 */
375#define ENC_CHARENCODING_MASK 0x0000FFFE /* mask out byte-order bits and other bits used with string encodings */
376#define ENC_ASCII 0x00000000
377#define ENC_ISO_646_IRV ENC_ASCII /* ISO 646 International Reference Version = ASCII */
378#define ENC_UTF_8 0x00000002
379#define ENC_UTF_16 0x00000004
380#define ENC_UCS_2 0x00000006
381#define ENC_UCS_4 0x00000008
382#define ENC_ISO_8859_1 0x0000000A
383#define ENC_ISO_8859_2 0x0000000C
384#define ENC_ISO_8859_3 0x0000000E
385#define ENC_ISO_8859_4 0x00000010
386#define ENC_ISO_8859_5 0x00000012
387#define ENC_ISO_8859_6 0x00000014
388#define ENC_ISO_8859_7 0x00000016
389#define ENC_ISO_8859_8 0x00000018
390#define ENC_ISO_8859_9 0x0000001A
391#define ENC_ISO_8859_10 0x0000001C
392#define ENC_ISO_8859_11 0x0000001E
393/* #define ENC_ISO_8859_12 0x00000020 ISO 8859-12 was abandoned */
394#define ENC_ISO_8859_13 0x00000022
395#define ENC_ISO_8859_14 0x00000024
396#define ENC_ISO_8859_15 0x00000026
397#define ENC_ISO_8859_16 0x00000028
398#define ENC_WINDOWS_1250 0x0000002A
399#define ENC_3GPP_TS_23_038_7BITS_PACKED 0x0000002C
400#define ENC_3GPP_TS_23_038_7BITS ENC_3GPP_TS_23_038_7BITS_PACKED
401#define ENC_EBCDIC 0x0000002E
402#define ENC_MAC_ROMAN 0x00000030
403#define ENC_CP437 0x00000032
404#define ENC_ASCII_7BITS 0x00000034
405#define ENC_T61 0x00000036
406#define ENC_EBCDIC_CP037 0x00000038
407#define ENC_WINDOWS_1252 0x0000003A
408#define ENC_WINDOWS_1251 0x0000003C
409#define ENC_CP855 0x0000003E
410#define ENC_CP866 0x00000040
411#define ENC_ISO_646_BASIC 0x00000042
412#define ENC_BCD_DIGITS_0_9 0x00000044 /* Packed BCD, digits 0-9 */
413#define ENC_KEYPAD_ABC_TBCD 0x00000046 /* Keypad-with-a/b/c "telephony BCD" = 0-9, *, #, a, b, c */
414#define ENC_KEYPAD_BC_TBCD 0x00000048 /* Keypad-with-B/C "telephony BCD" = 0-9, B, C, *, # */
415#define ENC_3GPP_TS_23_038_7BITS_UNPACKED 0x0000004C
416#define ENC_ETSI_TS_102_221_ANNEX_A 0x0000004E /* ETSI TS 102 221 Annex A */
417#define ENC_GB18030 0x00000050
418#define ENC_EUC_KR 0x00000052
419#define ENC_APN_STR 0x00000054 /* The encoding the APN/DNN field follows 3GPP TS 23.003 [2] clause 9.1.*/
420#define ENC_DECT_STANDARD_8BITS 0x00000056 /* DECT standard character set as defined in ETSI EN 300 175-5 Annex D */
421#define ENC_DECT_STANDARD_4BITS_TBCD 0x00000058 /* DECT standard 4bits character set as defined in ETSI EN 300 175-5 Annex D (BCD with 0xb = SPACE)*/
422#define ENC_EBCDIC_CP500 0x00000060
423/*
424 * TODO:
425 *
426 * packet-bacapp.c refers to two currently unsupported character sets (where
427 * we just use ASCII currently):
428 *
429 * "IBM MS DBCS" - At the very least could be any IBM/MS Double Byte
430 * Character Set for CJK (4 major ones), but also could just be any non
431 * Unicode and non ISO-8859-1 code page. This would be supported via the
432 * various code pages.
433 * JIS C 6226 / JIS X 0206 - Does this refer to ISO-2022-JP, SHIFT-JIS, or
434 * EUC-JP, which are all encoding schemes that support the JIS X 0206
435 * character set?
436 *
437 * As those are added, change code such as the code in packet-bacapp.c
438 * to use them.
439 *
440 * There's also some other code (e.g., packet-smpp.c) that just ignores
441 * strings if it determines that they are in an unsupported encoding, such
442 * as various encodings of Japanese mentioned above, for example.
443 *
444 */
445
446/*
447 * This is a modifier for FT_UINT_STRING and FT_UINT_BYTES values;
448 * it indicates that the length field should be interpreted as per
449 * sections 2.5.2.11 Octet String through 2.5.2.14 Long Character
450 * String of the ZigBee Cluster Library Specification, where if all
451 * bits are set in the length field, the string has an invalid value,
452 * and the number of octets in the value is 0.
453 */
454#define ENC_ZIGBEE 0x40000000
455
456/*
457 * This is a modifier for ENC_UTF_16, ENC_UCS_2, and ENC_UCS_4
458 * indicating that if the first two (or four, for UCS-4) octets
459 * are a big-endian or little-endian BOM, use that to determine
460 * the serialization order and ignore the ENC_LITTLE_ENDIAN or
461 * ENC_BIG_ENDIAN flag. This can't collide with ENC_ZIGBEE because
462 * it could be used simultaneously.
463 */
464#define ENC_BOM 0x20000000
465
466/*
467 * For cases where either native type or string encodings could both be
468 * valid arguments, we need something to distinguish which one is being
469 * passed as the argument, because ENC_BIG_ENDIAN and ENC_ASCII are both
470 * 0x00000000. So we use ENC_STR_NUM or ENC_STR_HEX bit-or'ed with
471 * ENC_ASCII and its ilk.
472 */
473/* this is for strings with auto-detected base as with strtoul */
474#define ENC_STR_NUM 0x01000000
475/* this is for strings as hex "1a2b3c" */
476#define ENC_STR_HEX 0x02000000
477/* this is for strings as decimal "12345" */
478#define ENC_STR_DEC 0x04000000
479/* a convenience macro for any of the above */
480#define ENC_STRING 0x07000000
481/* Kept around for compatibility for Lua scripts; code should use ENC_CHARENCODING_MASK */
482#define ENC_STR_MASK 0x0000FFFE
483
484/*
485 * For cases where the number is allowed to have a leading '+'/'-'
486 * this can't collide with ENC_SEP_* because they can be used simultaneously
487 *
488 * XXX - this is not used anywhere in Wireshark's code, dating back to
489 * at least Wireshark 2.6 and continuing to the current version.
490 * Perhaps the intent was to use it in the future, but 1) I'm not sure
491 * why it would be combined with ENC_SEP_, as byte arrays have no sign
492 * but integral values do, and 2) if we were to support string encodings
493 * for integral types, presumably whether it's signed (FT_INTn) or
494 * unsigned (FT_UINTn) would suffice to indicate whether the value
495 * can be signed or not.
496 */
497#define ENC_NUM_PREF 0x00200000
498
499/*
500 * Encodings for byte arrays.
501 *
502 * For cases where the byte array is encoded as a string composed of
503 * pairs of hex digits, possibly with a separator character between
504 * the pairs. That's specified by the encoding having ENC_STR_HEX,
505 * plus one of these values, set.
506 *
507 * See hex_str_to_bytes_encoding() in epan/strutil.h for details.
508 */
509#define ENC_SEP_NONE 0x00010000
510#define ENC_SEP_COLON 0x00020000
511#define ENC_SEP_DASH 0x00040000
512#define ENC_SEP_DOT 0x00080000
513#define ENC_SEP_SPACE 0x00100000
514/* a convenience macro for the above */
515#define ENC_SEP_MASK 0x001F0000
516
517/* Encodings for BCD strings
518 * Depending if the BCD string has even or odd number of digits
519 * we may need to strip off the last digit/High nibble.
520 */
521#define ENC_BCD_ODD_NUM_DIG 0x00010000
522#define ENC_BCD_SKIP_FIRST 0x00020000
523
524/*
525 * Encodings for time values.
526 *
527 * Historically FT_TIMEs were only timespecs; the only question was whether
528 * they were stored in big- or little-endian format.
529 *
530 * For backwards compatibility, we interpret an encoding of 1 as meaning
531 * "little-endian timespec", so that passing true is interpreted as that.
532 *
533 * We now support:
534 *
535 * ENC_TIME_SECS_NSECS - 8, 12, or 16 bytes. For 8 bytes, the first 4
536 * bytes are seconds and the next 4 bytes are nanoseconds; for 12 bytes,
537 * the first 8 bytes are seconds and the next 4 bytes are nanoseconds;
538 * for 16 bytes, the first 8 bytes are seconds and the next 8 bytes are
539 * nanoseconds. If the time is absolute, the seconds are seconds since
540 * the UN*X epoch (1970-01-01 00:00:00 UTC). (I.e., a UN*X struct
541 * timespec with a 4-byte or 8-byte time_t or a structure with an
542 * 8-byte time_t and an 8-byte nanoseconds field.)
543 *
544 * ENC_TIME_NTP - 8 bytes; the first 4 bytes are seconds since the NTP
545 * epoch (1900-01-01 00:00:00 GMT) and the next 4 bytes are 1/2^32's of
546 * a second since that second. (I.e., a 64-bit count of 1/2^32's of a
547 * second since the NTP epoch, with the upper 32 bits first and the
548 * lower 32 bits second, even when little-endian.) A value of 0 is a
549 * special case representing unknown or unsynchronized time. Per the
550 * suggestion in RFC 4330, if bit 0 is not set then the time is assumed
551 * to be in NTP Era 1, beginning on 2036-02-07 06:28:16 UTC. (I.e., the
552 * time displayed will be between 1968-01-20 03:14:08 UTC and
553 * 2104-02-26 09:42:24 UTC.) The 16 byte NTP date format and the 4 byte
554 * NTP short relative time format are not supported.
555 * Encodings that store only the seconds since the NTP epoch without
556 * fractional seconds should use ENC_TIME_SECS_NTP, described below.
557 *
558 * ENC_TIME_TOD - 8 bytes, as a count of microseconds since the System/3x0
559 * and z/Architecture epoch (1900-01-01 00:00:00 GMT).
560 *
561 * ENC_TIME_RTPS - 8 bytes; the first 4 bytes are seconds since the UN*X
562 * epoch and the next 4 bytes are 1/2^32's of a second since that
563 * second. (I.e., it's the offspring of a mating between UN*X time and
564 * NTP time). It's used by the Object Management Group's Real-Time
565 * Publish-Subscribe Wire Protocol for the Data Distribution Service.
566 *
567 * ENC_TIME_SECS_USECS - 8 bytes; the first 4 bytes are seconds and the
568 * next 4 bytes are microseconds. If the time is absolute, the seconds
569 * are seconds since the UN*X epoch. (I.e., a UN*X struct timeval with
570 * a 4-byte time_t.)
571 *
572 * ENC_TIME_SECS - 4 to 8 bytes, representing a value in seconds.
573 * If the time is absolute, it's seconds since the UN*X epoch.
574 *
575 * ENC_TIME_MSECS - 6 to 8 bytes, representing a value in milliseconds.
576 * If the time is absolute, it's milliseconds since the UN*X epoch.
577 *
578 * ENC_TIME_USECS - 8 bytes, representing a value in microseconds.
579 * If the time is absolute, it's microseconds since the UN*X epoch.
580 *
581 * ENC_TIME_NSECS - 8 bytes, representing a value in nanoseconds.
582 * If the time is absolute, it's nanoseconds since the UN*X epoch.
583 *
584 * ENC_TIME_SECS_NTP - 4 bytes, representing a count of seconds since
585 * the NTP epoch. As with ENC_TIME_NTP, times are assumed to be in
586 * the upper half of NTP Era 0 or the lower half of NTP Era 1.
587 *
588 * ENC_TIME_RFC_3971 - 8 bytes, representing a count of 1/64ths of a
589 * second since the UN*X epoch; see section 5.3.1 "Timestamp Option"
590 * in RFC 3971.
591 *
592 * ENC_TIME_MSEC_NTP - 6-8 bytes, representing a count of milliseconds since
593 * the NTP epoch. Similar to ENC_TIME_NTP, times before the midpoint of
594 * NTP Era 0 (1968-01-20) are assumed to represent the corresponding
595 * time in NTP Era 1 instead.
596 *
597 * ENC_TIME_MIP6 - 8 bytes; the first 48 bits are seconds since the UN*X epoch
598 * and the remaining 16 bits indicate the number of 1/65536's of a second
599 * since that second.
600 *
601 * ENC_TIME_MP4_FILE_SECS - 4-8 bytes, representing a count of seconds since
602 * January 1, 1904, 00:00:00 UTC.
603 *
604 * ENC_TIME_ZBEE_ZCL - 4-8 bytes, representing a count of seconds since
605 * January 1, 2000, 00:00:00 UTC.
606 */
607#define ENC_TIME_SECS_NSECS 0x00000000
608#define ENC_TIME_TIMESPEC 0x00000000 /* for backwards source compatibility */
609#define ENC_TIME_NTP 0x00000002
610#define ENC_TIME_TOD 0x00000004
611#define ENC_TIME_RTPS 0x00000008
612#define ENC_TIME_NTP_BASE_ZERO 0x00000008 /* for backwards source compatibility */
613#define ENC_TIME_SECS_USECS 0x00000010
614#define ENC_TIME_TIMEVAL 0x00000010 /* for backwards source compatibility */
615#define ENC_TIME_SECS 0x00000012
616#define ENC_TIME_MSECS 0x00000014
617#define ENC_TIME_SECS_NTP 0x00000018
618#define ENC_TIME_RFC_3971 0x00000020
619#define ENC_TIME_MSEC_NTP 0x00000022
620#define ENC_TIME_MIP6 0x00000024
621#define ENC_TIME_MP4_FILE_SECS 0x00000026
622#define ENC_TIME_CLASSIC_MAC_OS_SECS 0x00000026 /* for backwards source compatibility */
623#define ENC_TIME_NSECS 0x00000028
624#define ENC_TIME_USECS 0x00000030
625#define ENC_TIME_ZBEE_ZCL 0x00000032
626
627/*
628 * For cases where a string encoding contains a timestamp, use one
629 * of these (but only one). These values can collide with the ENC_SEP_
630 * values used when a string encoding contains a byte array, because
631 * you can't do both at the same time. They must not, however,
632 * overlap with the character encoding values.
633 */
634#define ENC_ISO_8601_DATE 0x00010000
635#define ENC_ISO_8601_TIME 0x00020000
636#define ENC_ISO_8601_DATE_TIME 0x00030000
637#define ENC_IMF_DATE_TIME 0x00040000 /* Internet Message Format - RFCs 822, 1123, 2822, 5322 */
638#define ENC_RFC_822 0x00040000 /* backwards compatibility */
639#define ENC_RFC_1123 0x00040000 /* backwards source compatibility - not binary */
640#define ENC_ISO_8601_DATE_TIME_BASIC 0x00100000
641/* a convenience macro for the above - for internal use only */
642#define ENC_STR_TIME_MASK 0x001F0000
643
644/*
645 * Encodings for variable-length integral types.
646 */
647
648/* Use varint format as described in Protobuf protocol
649 * https://developers.google.cn/protocol-buffers/docs/encoding
650 */
651#define ENC_VARINT_PROTOBUF 0x00000002
652/*
653 * Decodes a variable-length integer used in QUIC protocol
654 * See https://tools.ietf.org/html/draft-ietf-quic-transport-08#section-8.1
655 */
656#define ENC_VARINT_QUIC 0x00000004
657 /*
658 * Use "zig-zag" varint format as described in Protobuf protocol
659 * See https://developers.google.com/protocol-buffers/docs/encoding?csw=1#types
660 */
661#define ENC_VARINT_ZIGZAG 0x00000008
662/*
663 * Decodes a variable-length integer used in DTN protocols
664 * See https://www.rfc-editor.org/rfc/rfc6256.html
665 */
666#define ENC_VARINT_SDNV 0x00000010
667
668#define ENC_VARINT_MASK (ENC_VARINT_PROTOBUF|ENC_VARINT_QUIC|ENC_VARINT_ZIGZAG|ENC_VARINT_SDNV)
669
670/* Values for header_field_info.display */
671
672/* For integral types, the display format is a BASE_* field_display_e value
673 * possibly ORed with BASE_*_STRING */
674
676#define FIELD_DISPLAY_E_MASK 0xFF
677
721
722#define FIELD_DISPLAY(d) ((d) & FIELD_DISPLAY_E_MASK)
723
724#define FIELD_DISPLAY_IS_ABSOLUTE_TIME(d) \
725 (FIELD_DISPLAY(d) >= ABSOLUTE_TIME_LOCAL && FIELD_DISPLAY(d) <= ABSOLUTE_TIME_UNIX)
726
727/* Following constants have to be ORed with a field_display_e when dissector
728 * want to use specials value-string MACROs for a header_field_info */
729#define BASE_RANGE_STRING 0x00000100
730#define BASE_EXT_STRING 0x00000200
731#define BASE_VAL64_STRING 0x00000400
732
733#define BASE_ALLOW_ZERO 0x00000800
735#define BASE_UNIT_STRING 0x00001000
737#define BASE_NO_DISPLAY_VALUE 0x00002000
740#define BASE_PROTOCOL_INFO 0x00004000
742#define BASE_SPECIAL_VALS 0x00008000
744#define BASE_SHOW_ASCII_PRINTABLE 0x00010000
746#define BASE_SHOW_UTF_8_PRINTABLE 0x00020000
749#define IS_BASE_DUAL(b) ((b)==BASE_DEC_HEX||(b)==BASE_HEX_DEC)
750
752#define IS_BASE_PORT(b) (((b)==BASE_PT_UDP||(b)==BASE_PT_TCP||(b)==BASE_PT_DCCP||(b)==BASE_PT_SCTP))
753
763
766
769 /* ---------- set by dissector --------- */
770 const char *name;
771 const char *abbrev;
774 const void *strings;
778 uint64_t bitmask;
779 const char *blurb;
781 /* ------- set by proto routines (prefilled by HFILL macro, see below) ------ */
782 int id;
783 int parent;
787};
788
794#define HFILL -1, 0, HF_REF_TYPE_NONE, -1, NULL
795
796#define HFILL_INIT(hf) \
797 (hf).hfinfo.id = -1; \
798 (hf).hfinfo.parent = 0; \
799 (hf).hfinfo.ref_type = HF_REF_TYPE_NONE; \
800 (hf).hfinfo.same_name_prev_id = -1; \
801 (hf).hfinfo.same_name_next = NULL;
802
808
810typedef struct _item_label_t {
811 char representation[ITEM_LABEL_LENGTH];
812 size_t value_pos;
813 size_t value_len;
815
831
832
842typedef struct
843{
847
848/*
849 * Flag fields. Do not assign values greater than 0x000FFFFF unless you
850 * shuffle the expert information upward; see below.
851 */
852
858#define FI_HIDDEN 0x00000001
861#define FI_GENERATED 0x00000002
863#define FI_URL 0x00000004
864
866#define FI_LITTLE_ENDIAN 0x00000008
868#define FI_BIG_ENDIAN 0x00000010
870#define FI_BITS_OFFSET(n) (((n) & 63) << 5)
872/* if 0, it means that field takes fi->length * 8 */
873#define FI_BITS_SIZE(n) (((n) & 63) << 12)
875#define FI_VARINT 0x00040000
876
878#define FI_GET_FLAG(fi, flag) ((fi) ? ((fi)->flags & (flag)) : 0)
880#define FI_SET_FLAG(fi, flag) \
881 do { \
882 if (fi) \
883 (fi)->flags = (fi)->flags | (flag); \
884 } while(0)
886#define FI_RESET_FLAG(fi, flag) \
887 do { \
888 if (fi) \
889 (fi)->flags = (fi)->flags & ~(flag); \
890 } while(0)
891
892#define FI_GET_BITS_OFFSET(fi) (FI_GET_FLAG(fi, FI_BITS_OFFSET(63)) >> 5)
893#define FI_GET_BITS_SIZE(fi) (FI_GET_FLAG(fi, FI_BITS_SIZE(63)) >> 12)
894
897typedef struct {
898 GHashTable *interesting_hfids;
899 bool visible;
900 bool fake_protocols;
901 unsigned count;
902 struct _packet_info *pinfo;
903 tvbuff_t *idle_count_ds_tvb;
904 unsigned max_start;
905 unsigned start_idle_count;
907
909typedef struct _proto_node {
910 struct _proto_node *first_child;
911 struct _proto_node *last_child;
912 struct _proto_node *next;
913 struct _proto_node *parent;
914 const header_field_info *hfinfo;
915 field_info *finfo;
916 tree_data_t *tree_data;
918
923
924/*
925 * Expert information.
926 * This is in the flags field; we allocate this from the top down,
927 * so as not to collide with FI_ flags, which are allocated from
928 * the bottom up.
929 */
930
931/* expert severities */
932#define PI_SEVERITY_MASK 0x00F00000
934#define PI_COMMENT 0x00100000
936#define PI_CHAT 0x00200000
938#define PI_NOTE 0x00400000
940#define PI_WARN 0x00600000
942#define PI_ERROR 0x00800000
943
944/* expert "event groups" */
945#define PI_GROUP_MASK 0xFF000000
947#define PI_CHECKSUM 0x01000000
949#define PI_SEQUENCE 0x02000000
951#define PI_RESPONSE_CODE 0x03000000
953#define PI_REQUEST_CODE 0x04000000
955#define PI_UNDECODED 0x05000000
957#define PI_REASSEMBLE 0x06000000
959#define PI_MALFORMED 0x07000000
961#define PI_DEBUG 0x08000000
963#define PI_PROTOCOL 0x09000000
965#define PI_SECURITY 0x0a000000
967#define PI_COMMENTS_GROUP 0x0b000000
969#define PI_DECRYPTION 0x0c000000
971#define PI_ASSUMPTION 0x0d000000
973#define PI_DEPRECATED 0x0e000000
975#define PI_RECEIVE 0x0f000000
977#define PI_INTERFACE 0x10000000
979#define PI_DISSECTOR_BUG 0x11000000
980
981/*
982 * add more, see WSDG: 9.3. How to add an expert item:
983 * https://www.wireshark.org/docs/wsdg_html/#ChDissectExpertInfo
984 */
985
987#define PNODE_FINFO(proto_node) ((proto_node)->finfo)
988
990#define PITEM_FINFO(proto_item) PNODE_FINFO(proto_item)
991
993#define PTREE_FINFO(proto_tree) PNODE_FINFO(proto_tree)
994
996#define PNODE_HFINFO(proto_node) ((proto_node)->hfinfo)
997
999#define PITEM_HFINFO(proto_item) PNODE_HFINFO(proto_item)
1000
1002#define PTREE_HFINFO(proto_tree) PNODE_HFINFO(proto_tree)
1003
1005#define PTREE_DATA(proto_tree) ((proto_tree)->tree_data)
1006
1008#define PNODE_POOL(proto_node) ((proto_node)->tree_data->pinfo->pool)
1009
1015static inline bool proto_item_is_hidden(const proto_item *ti) {
1016 if (ti && PITEM_FINFO(ti)) {
1017 return FI_GET_FLAG(PITEM_FINFO(ti), FI_HIDDEN);
1018 }
1019 /* XXX - Is a NULL item hidden? */
1020 return true;
1021}
1022#define PROTO_ITEM_IS_HIDDEN(ti) proto_item_is_hidden((ti))
1023
1028static inline void proto_item_set_hidden(proto_item *ti) {
1029 if (ti) {
1031 }
1032}
1033#define PROTO_ITEM_SET_HIDDEN(ti) proto_item_set_hidden((ti))
1034
1038static inline void proto_item_set_visible(proto_item *ti) {
1039 if (ti) {
1041 }
1042}
1043#define PROTO_ITEM_SET_VISIBLE(ti) proto_item_set_visible((ti))
1044
1049static inline bool proto_item_is_generated(const proto_item *ti)
1050{
1051 if (ti) {
1053 }
1054 return false;
1055}
1056#define PROTO_ITEM_IS_GENERATED(ti) proto_item_is_generated((ti))
1057
1061static inline void proto_item_set_generated(proto_item *ti) {
1062 if (ti) {
1064 }
1065}
1066#define PROTO_ITEM_SET_GENERATED(ti) proto_item_set_generated((ti))
1067
1073static inline bool proto_item_is_url(const proto_item *ti)
1074{
1075 if (ti) {
1076 return FI_GET_FLAG(PITEM_FINFO(ti), FI_URL);
1077 }
1078 return false;
1079}
1080#define PROTO_ITEM_IS_URL(ti) proto_item_is_url((ti))
1081
1085static inline void proto_item_set_url(proto_item *ti) {
1086 if (ti) {
1088 }
1089}
1090#define PROTO_ITEM_SET_URL(ti) proto_item_set_url((ti))
1091
1097typedef void (*proto_tree_foreach_func)(proto_node *node, void *data);
1098
1105typedef bool (*proto_tree_traverse_func)(proto_node *node, void *data);
1106
1114WS_DLL_PUBLIC void proto_tree_children_foreach(proto_tree *tree,
1115 proto_tree_foreach_func func, void *data);
1116
1120typedef struct {
1124 void (*register_protoinfo)(void);
1125
1129 void (*register_handoff)(void);
1130} proto_plugin;
1131
1139WS_DLL_PUBLIC void proto_register_plugin(const proto_plugin *plugin);
1140
1146void proto_pre_init(void);
1147
1168void proto_init(GSList *register_all_plugin_protocols_list,
1169 GSList *register_all_plugin_handoffs_list,
1170 register_entity_func register_func, register_entity_func handoff_func,
1171 register_cb cb, void *client_data);
1172
1178extern void proto_cleanup(void);
1179
1185typedef void (*proto_execute_in_directory_func)(void* param);
1186
1197WS_DLL_PUBLIC void proto_execute_in_directory(const char* dir, proto_execute_in_directory_func func, void* param);
1198
1199
1213WS_DLL_PUBLIC bool proto_field_is_referenced(proto_tree *tree, int proto_id);
1214
1219WS_DLL_PUBLIC proto_tree* proto_item_add_subtree(proto_item *pi, const int idx) G_GNUC_WARN_UNUSED_RESULT;
1220
1224WS_DLL_PUBLIC proto_tree* proto_item_get_subtree(proto_item *pi);
1225
1229WS_DLL_PUBLIC proto_item* proto_item_get_parent(const proto_item *pi);
1230
1235WS_DLL_PUBLIC proto_item* proto_item_get_parent_nth(proto_item *pi, int gen);
1236
1241WS_DLL_PUBLIC void proto_item_set_text(proto_item *pi, const char *format, ...)
1242 G_GNUC_PRINTF(2,3);
1243
1248WS_DLL_PUBLIC void proto_item_append_text(proto_item *pi, const char *format, ...)
1249 G_GNUC_PRINTF(2,3);
1250
1255WS_DLL_PUBLIC void proto_item_prepend_text(proto_item *pi, const char *format, ...)
1256 G_GNUC_PRINTF(2,3);
1257
1261WS_DLL_PUBLIC void proto_item_set_len(proto_item *pi, const int length);
1262
1284WS_DLL_PUBLIC void proto_item_set_end(proto_item *pi, tvbuff_t *tvb, unsigned end);
1285
1290WS_DLL_PUBLIC int proto_item_get_len(const proto_item *pi);
1291
1297WS_DLL_PUBLIC void proto_item_set_bits_offset_len(proto_item *ti, int bits_offset, int bits_len);
1298
1311WS_DLL_PUBLIC char *proto_item_get_display_repr(wmem_allocator_t *scope, proto_item *pi);
1312
1319WS_DLL_PUBLIC proto_tree *proto_tree_create_root(packet_info *pinfo);
1320
1327void proto_tree_reset(proto_tree *tree);
1328
1334WS_DLL_PUBLIC void proto_tree_free(proto_tree *tree);
1335
1343WS_DLL_PUBLIC bool
1344proto_tree_set_visible(proto_tree *tree, bool visible);
1345
1349extern void
1350proto_tree_set_fake_protocols(proto_tree *tree, bool fake_protocols);
1351
1358extern void
1360
1366extern void
1368
1372WS_DLL_PUBLIC proto_item* proto_tree_get_parent(proto_tree *tree);
1373
1378
1382WS_DLL_PUBLIC proto_tree* proto_tree_get_root(proto_tree *tree);
1383
1388WS_DLL_PUBLIC void proto_tree_move_item(proto_tree *tree, proto_item *fixed_item, proto_item *item_to_move);
1389
1390
1400WS_DLL_PUBLIC void proto_tree_set_appendix(proto_tree *tree, tvbuff_t *tvb, int start, const int length);
1401
1402
1412WS_DLL_PUBLIC proto_item *
1414 const int start, int length, const unsigned encoding);
1415
1437WS_DLL_PUBLIC proto_item *
1438proto_tree_add_item(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1439 const int start, int length, const unsigned encoding);
1440
1453WS_DLL_PUBLIC proto_item *
1455 const int start, int length, const unsigned encoding, int *lenretval);
1456
1469WS_DLL_PUBLIC proto_item *
1470proto_tree_add_item_ret_length(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1471 const int start, int length, const unsigned encoding, int *lenretval);
1472
1504WS_DLL_PUBLIC proto_item *
1505proto_tree_add_item_ret_int(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1506 const int start, int length, const unsigned encoding, int32_t *retval);
1507
1520WS_DLL_PUBLIC proto_item *
1521proto_tree_add_item_ret_int64(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1522 const int start, int length, const unsigned encoding, int64_t *retval);
1523
1537WS_DLL_PUBLIC proto_item *
1538proto_tree_add_item_ret_uint(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1539 const int start, int length, const unsigned encoding, uint32_t *retval);
1540
1556WS_DLL_PUBLIC proto_item *
1557proto_tree_add_item_ret_uint32(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1558 const int start, int length, const unsigned encoding, uint32_t *retval);
1559
1572WS_DLL_PUBLIC proto_item *
1573proto_tree_add_item_ret_uint8(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1574 const int start, int length, const unsigned encoding, uint8_t *retval);
1575
1588WS_DLL_PUBLIC proto_item *
1589proto_tree_add_item_ret_uint16(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1590 const int start, int length, const unsigned encoding, uint16_t *retval);
1591
1604WS_DLL_PUBLIC proto_item *
1605proto_tree_add_item_ret_uint64(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1606 const int start, int length, const unsigned encoding, uint64_t *retval);
1607
1630WS_DLL_PUBLIC proto_item *
1631proto_tree_add_item_ret_varint(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1632 const int start, int length, const unsigned encoding, uint64_t *retval, int *lenretval);
1633
1646WS_DLL_PUBLIC proto_item *
1647proto_tree_add_item_ret_boolean(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1648 const int start, int length, const unsigned encoding, bool *retval);
1649
1663WS_DLL_PUBLIC proto_item *
1664proto_tree_add_item_ret_ipv4(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1665 const int start, int length, const unsigned encoding, ws_in4_addr *retval);
1666
1681WS_DLL_PUBLIC proto_item *
1682proto_tree_add_item_ret_ipv6(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1683 const int start, int length, const unsigned encoding, ws_in6_addr *retval);
1684
1699WS_DLL_PUBLIC proto_item *
1700proto_tree_add_item_ret_ether(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1701 const int start, int length, const unsigned encoding, uint8_t *retval);
1702
1716WS_DLL_PUBLIC proto_item *
1717proto_tree_add_item_ret_float(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1718 const int start, int length,
1719 const unsigned encoding, float *retval);
1720
1734WS_DLL_PUBLIC proto_item *
1735proto_tree_add_item_ret_double(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1736 const int start, int length,
1737 const unsigned encoding, double *retval);
1738
1768WS_DLL_PUBLIC proto_item *
1770 tvbuff_t *tvb, const int start, int length, const unsigned encoding,
1771 wmem_allocator_t *scope, const uint8_t **retval, int *lenretval);
1772
1800WS_DLL_PUBLIC proto_item *
1801proto_tree_add_item_ret_string(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1802 const int start, int length, const unsigned encoding,
1803 wmem_allocator_t *scope, const uint8_t **retval);
1804
1825WS_DLL_PUBLIC proto_item *
1827 tvbuff_t *tvb,
1828 const int start, int length, const unsigned encoding,
1829 wmem_allocator_t *scope, char **retval, int *lenretval);
1830
1848WS_DLL_PUBLIC proto_item *
1850 tvbuff_t *tvb,
1851 const int start, int length, const unsigned encoding,
1852 wmem_allocator_t *scope, char **retval);
1853
1869WS_DLL_PUBLIC proto_item *
1871 tvbuff_t *tvb,
1872 const int start, int length, const unsigned encoding,
1873 wmem_allocator_t *scope, char **retval);
1874
1883proto_item *
1884proto_tree_add_text_internal(proto_tree *tree, tvbuff_t *tvb, int start, int length, const char *format,
1885 ...) G_GNUC_PRINTF(5,6);
1886
1895proto_item *
1897 int length, const char *format, va_list ap) G_GNUC_PRINTF(5, 0);
1898
1908WS_DLL_PUBLIC proto_tree *
1909proto_tree_add_subtree(proto_tree *tree, tvbuff_t *tvb, int start, int length, int idx,
1910 proto_item **tree_item, const char *text);
1911
1922WS_DLL_PUBLIC proto_tree *
1923proto_tree_add_subtree_format(proto_tree *tree, tvbuff_t *tvb, int start, int length, int idx,
1924 proto_item **tree_item, const char *format, ...) G_GNUC_PRINTF(7,8);
1925
1927WS_DLL_PUBLIC proto_item *
1928proto_tree_add_format_text(proto_tree *tree, tvbuff_t *tvb, int start, int length);
1929
1931WS_DLL_PUBLIC proto_item *
1932proto_tree_add_format_wsp_text(proto_tree *tree, tvbuff_t *tvb, int start, int length);
1933
1943WS_DLL_PUBLIC proto_item *
1944proto_tree_add_none_format(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const int start,
1945 int length, const char *format, ...) G_GNUC_PRINTF(6,7);
1946
1956WS_DLL_PUBLIC proto_item *
1957proto_tree_add_protocol_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
1958 int length, const char *format, ...) G_GNUC_PRINTF(6,7);
1959
1968WS_DLL_PUBLIC proto_item *
1969proto_tree_add_bytes(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
1970 int length, const uint8_t* start_ptr);
1971
1982WS_DLL_PUBLIC proto_item *
1983proto_tree_add_bytes_with_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
1984 int length, const uint8_t *start_ptr, int ptr_length);
1985
2019WS_DLL_PUBLIC proto_item *
2020proto_tree_add_bytes_item(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2021 const unsigned start, unsigned length, const unsigned encoding,
2022 GByteArray *retval, unsigned *endoff, int *err);
2023
2037WS_DLL_PUBLIC proto_item *
2039 int start, int length, const uint8_t* start_ptr, const char *format,
2040 ...) G_GNUC_PRINTF(7,8);
2041
2054WS_DLL_PUBLIC proto_item *
2055proto_tree_add_bytes_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2056 int length, const uint8_t* start_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2057
2066WS_DLL_PUBLIC proto_item *
2067proto_tree_add_time(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2068 int length, const nstime_t* value_ptr);
2069
2100WS_DLL_PUBLIC proto_item *
2101proto_tree_add_time_item(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2102 const unsigned start, const unsigned length, const unsigned encoding,
2103 nstime_t *retval, unsigned *endoff, int *err);
2104
2105
2118WS_DLL_PUBLIC proto_item *
2120 int start, int length, nstime_t* value_ptr, const char *format, ...)
2121 G_GNUC_PRINTF(7,8);
2122
2135WS_DLL_PUBLIC proto_item *
2136proto_tree_add_time_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2137 int length, nstime_t* value_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2138
2147WS_DLL_PUBLIC proto_item *
2148proto_tree_add_ipxnet(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2149 int length, uint32_t value);
2150
2163WS_DLL_PUBLIC proto_item *
2165 int start, int length, uint32_t value, const char *format, ...)
2166 G_GNUC_PRINTF(7,8);
2167
2179WS_DLL_PUBLIC proto_item *
2180proto_tree_add_ipxnet_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2181 int length, uint32_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2182
2191WS_DLL_PUBLIC proto_item *
2192proto_tree_add_ipv4(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2193 int length, ws_in4_addr value);
2194
2207WS_DLL_PUBLIC proto_item *
2209 int start, int length, ws_in4_addr value, const char *format, ...)
2210 G_GNUC_PRINTF(7,8);
2211
2223WS_DLL_PUBLIC proto_item *
2224proto_tree_add_ipv4_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2225 int length, ws_in4_addr value, const char *format, ...) G_GNUC_PRINTF(7,8);
2226
2235WS_DLL_PUBLIC proto_item *
2236proto_tree_add_ipv6(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2237 int length, const ws_in6_addr *value_ptr);
2238
2251WS_DLL_PUBLIC proto_item *
2253 int start, int length, const ws_in6_addr *value_ptr, const char *format,
2254 ...) G_GNUC_PRINTF(7,8);
2255
2267WS_DLL_PUBLIC proto_item *
2268proto_tree_add_ipv6_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2269 int length, const ws_in6_addr *value_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2270
2279WS_DLL_PUBLIC proto_item *
2280proto_tree_add_ether(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2281 int length, const uint8_t* value);
2282
2295WS_DLL_PUBLIC proto_item *
2297 int start, int length, const uint8_t* value, const char *format, ...)
2298 G_GNUC_PRINTF(7,8);
2299
2311WS_DLL_PUBLIC proto_item *
2312proto_tree_add_ether_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2313 int length, const uint8_t* value, const char *format, ...) G_GNUC_PRINTF(7,8);
2314
2323WS_DLL_PUBLIC proto_item *
2324proto_tree_add_guid(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2325 int length, const e_guid_t *value_ptr);
2326
2339WS_DLL_PUBLIC proto_item *
2341 int start, int length, const e_guid_t *value_ptr, const char *format,
2342 ...) G_GNUC_PRINTF(7,8);
2343
2355WS_DLL_PUBLIC proto_item *
2356proto_tree_add_guid_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2357 int length, const e_guid_t *value_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2358
2367WS_DLL_PUBLIC proto_item *
2368proto_tree_add_oid(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2369 int length, const uint8_t* value_ptr);
2370
2383WS_DLL_PUBLIC proto_item *
2384proto_tree_add_oid_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2385 int start, int length, const uint8_t* value_ptr, const char *format,
2386 ...) G_GNUC_PRINTF(7,8);
2387
2399WS_DLL_PUBLIC proto_item *
2400proto_tree_add_oid_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2401 int length, const uint8_t* value_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2402
2422WS_DLL_PUBLIC proto_item *
2423proto_tree_add_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2424 int length, const char* value);
2425
2438WS_DLL_PUBLIC proto_item *
2440 int start, int length, const char* value, const char *format, ...)
2441 G_GNUC_PRINTF(7,8);
2442
2455WS_DLL_PUBLIC proto_item *
2456proto_tree_add_string_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2457 int length, const char* value, const char *format, ...) G_GNUC_PRINTF(7,8);
2458
2467WS_DLL_PUBLIC proto_item *
2468proto_tree_add_boolean(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2469 int length, uint64_t value);
2470
2483WS_DLL_PUBLIC proto_item *
2485 tvbuff_t *tvb, int start, int length, uint64_t value,
2486 const char *format, ...) G_GNUC_PRINTF(7,8);
2487
2499WS_DLL_PUBLIC proto_item *
2500proto_tree_add_boolean_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2501 int length, uint64_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2502
2511WS_DLL_PUBLIC proto_item *
2512proto_tree_add_float(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2513 int length, float value);
2514
2527WS_DLL_PUBLIC proto_item *
2529 int start, int length, float value, const char *format, ...)
2530 G_GNUC_PRINTF(7,8);
2531
2543WS_DLL_PUBLIC proto_item *
2544proto_tree_add_float_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2545 int length, float value, const char *format, ...) G_GNUC_PRINTF(7,8);
2546
2555WS_DLL_PUBLIC proto_item *
2556proto_tree_add_double(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2557 int length, double value);
2558
2571WS_DLL_PUBLIC proto_item *
2573 int start, int length, double value, const char *format, ...)
2574 G_GNUC_PRINTF(7,8);
2575
2587WS_DLL_PUBLIC proto_item *
2588proto_tree_add_double_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2589 int length, double value, const char *format, ...) G_GNUC_PRINTF(7,8);
2590
2599WS_DLL_PUBLIC proto_item *
2600proto_tree_add_uint(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2601 int length, uint32_t value);
2602
2615WS_DLL_PUBLIC proto_item *
2617 int start, int length, uint32_t value, const char *format, ...)
2618 G_GNUC_PRINTF(7,8);
2619
2632WS_DLL_PUBLIC proto_item *
2633proto_tree_add_uint_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2634 int length, uint32_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2635
2644WS_DLL_PUBLIC proto_item *
2645proto_tree_add_uint64(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2646 int length, uint64_t value);
2647
2660WS_DLL_PUBLIC proto_item *
2662 int start, int length, uint64_t value, const char *format, ...)
2663 G_GNUC_PRINTF(7,8);
2664
2676WS_DLL_PUBLIC proto_item *
2677proto_tree_add_uint64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2678 int length, uint64_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2679
2688WS_DLL_PUBLIC proto_item *
2689proto_tree_add_int(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2690 int length, int32_t value);
2691
2704WS_DLL_PUBLIC proto_item *
2705proto_tree_add_int_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2706 int start, int length, int32_t value, const char *format, ...)
2707 G_GNUC_PRINTF(7,8);
2708
2721WS_DLL_PUBLIC proto_item *
2722proto_tree_add_int_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2723 int length, int32_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2724
2733WS_DLL_PUBLIC proto_item *
2734proto_tree_add_int64(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2735 int length, int64_t value);
2736
2749WS_DLL_PUBLIC proto_item *
2751 int start, int length, int64_t value, const char *format, ...)
2752 G_GNUC_PRINTF(7,8);
2753
2765WS_DLL_PUBLIC proto_item *
2766proto_tree_add_int64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2767 int length, int64_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2768
2777WS_DLL_PUBLIC proto_item *
2778proto_tree_add_eui64(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2779 int length, const uint64_t value);
2780
2793WS_DLL_PUBLIC proto_item *
2795 int start, int length, const uint64_t value, const char *format, ...)
2796 G_GNUC_PRINTF(7,8);
2797
2809WS_DLL_PUBLIC proto_item *
2810proto_tree_add_eui64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start,
2811 int length, const uint64_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2812
2814typedef struct _mac_hf_list_t {
2815 int *hf_addr; // FT_ETHER, BASE_NONE
2816 int *hf_addr_resolved; // FT_STRING, BASE_NONE
2817 int *hf_oui; // FT_UINT24, BASE_OUI
2818 int *hf_oui_resolved; // FT_STRING, BASE_NONE
2819 int *hf_lg; // FT_BOOLEAN, 24 bits, mask 0x020000
2820 int *hf_ig; // FT_BOOLEAN, 24 bits, mask 0x010000
2822
2832WS_DLL_PUBLIC proto_item *
2833proto_tree_add_mac48_detail(const mac_hf_list_t *list_specific,
2834 const mac_hf_list_t *list_generic,
2835 int idx, tvbuff_t *tvb, proto_tree *tree, int offset);
2836
2843WS_DLL_PUBLIC proto_item *
2844proto_tree_add_debug_text(proto_tree *tree, const char *format,
2845 ...) G_GNUC_PRINTF(2,3);
2846
2852WS_DLL_PUBLIC void
2853proto_item_fill_label(const field_info *finfo, char *label_str, size_t *value_offset);
2854
2862WS_DLL_PUBLIC int
2863proto_item_fill_display_label(const field_info *fi, char *display_label_str, const int label_str_size);
2864
2870WS_DLL_PUBLIC int
2871proto_register_protocol(const char *name, const char *short_name, const char *filter_name);
2872
2887WS_DLL_PUBLIC int
2888proto_register_protocol_in_name_only(const char *name, const char *short_name, const char *filter_name,
2889 int parent_proto, enum ftenum field_type);
2890
2896bool
2897proto_deregister_protocol(const char *short_name);
2898
2903WS_DLL_PUBLIC void
2904proto_register_alias(const int proto_id, const char *alias_name);
2905
2910typedef void (*prefix_initializer_t)(const char* match);
2911
2919WS_DLL_PUBLIC void
2920proto_register_prefix(const char *prefix, prefix_initializer_t initializer);
2921
2923WS_DLL_PUBLIC void proto_initialize_all_prefixes(void);
2924
2929WS_DLL_PUBLIC void
2930proto_register_field_array(const int parent, hf_register_info *hf, const int num_records);
2931
2935WS_DLL_PUBLIC void
2936proto_deregister_field (const int parent, int hf_id);
2937
2940WS_DLL_PUBLIC void
2941proto_add_deregistered_data (void *data);
2942
2947WS_DLL_PUBLIC void
2948proto_deregister_all_fields_with_prefix(const int parent, const char *prefix);
2949
2953void
2954proto_add_deregistered_slice (size_t block_size, void *mem_block);
2955
2960WS_DLL_PUBLIC void
2961proto_free_field_strings (ftenum_t field_type, unsigned int field_display, const void *field_strings);
2962
2969WS_DLL_PUBLIC void
2971
2975WS_DLL_PUBLIC void
2976proto_register_subtree_array(int * const *indices, const int num_indices);
2977
2981WS_DLL_PUBLIC const char* proto_registrar_get_name(const int n);
2982
2986WS_DLL_PUBLIC const char* proto_registrar_get_abbrev(const int n);
2987
2991WS_DLL_PUBLIC header_field_info* proto_registrar_get_nth(unsigned hfindex);
2992
2996WS_DLL_PUBLIC header_field_info* proto_registrar_get_byname(const char *field_name);
2997
3001WS_DLL_PUBLIC header_field_info* proto_registrar_get_byalias(const char *alias_name);
3002
3006WS_DLL_PUBLIC int proto_registrar_get_id_byname(const char *field_name);
3007
3011WS_DLL_PUBLIC enum ftenum proto_registrar_get_ftype(const int n);
3012
3016WS_DLL_PUBLIC int proto_registrar_get_parent(const int n);
3017
3021WS_DLL_PUBLIC bool proto_registrar_is_protocol(const int n);
3022
3026WS_DLL_PUBLIC int proto_registrar_get_length(const int n);
3027
3036
3040WS_DLL_PUBLIC size_t proto_registrar_get_count(struct proto_registrar_stats *stats);
3041
3053WS_DLL_PUBLIC int proto_get_first_protocol(void **cookie);
3054
3062WS_DLL_PUBLIC int proto_get_data_protocol(void *cookie);
3063
3072WS_DLL_PUBLIC int proto_get_next_protocol(void **cookie);
3073
3085WS_DLL_PUBLIC header_field_info *proto_get_first_protocol_field(const int proto_id, void **cookie);
3086
3097WS_DLL_PUBLIC header_field_info *proto_get_next_protocol_field(const int proto_id, void **cookie);
3098
3102WS_DLL_PUBLIC bool proto_name_already_registered(const char *name);
3103
3107WS_DLL_PUBLIC int proto_get_id_by_filter_name(const char* filter_name);
3108
3112WS_DLL_PUBLIC int proto_get_id_by_short_name(const char* short_name);
3113
3117WS_DLL_PUBLIC bool proto_can_toggle_protocol(const int proto_id);
3118
3121WS_DLL_PUBLIC protocol_t *find_protocol_by_id(const int proto_id);
3122
3126WS_DLL_PUBLIC const char *proto_get_protocol_name(const int proto_id);
3127
3130WS_DLL_PUBLIC int proto_get_id(const protocol_t *protocol);
3131
3134WS_DLL_PUBLIC const char *proto_get_protocol_short_name(const protocol_t *protocol);
3135
3138WS_DLL_PUBLIC const char *proto_get_protocol_long_name(const protocol_t *protocol);
3139
3142WS_DLL_PUBLIC bool proto_is_protocol_enabled(const protocol_t *protocol);
3143
3146WS_DLL_PUBLIC bool proto_is_protocol_enabled_by_default(const protocol_t *protocol);
3147
3150WS_DLL_PUBLIC bool proto_is_pino(const protocol_t *protocol);
3151
3155WS_DLL_PUBLIC const char *proto_get_protocol_filter_name(const int proto_id);
3156
3162extern void proto_add_heuristic_dissector(protocol_t *protocol, const char *short_name);
3163
3169WS_DLL_PUBLIC void proto_heuristic_dissector_foreach(const protocol_t *protocol, GFunc func,
3170 void *user_data);
3171
3189WS_DLL_PUBLIC void proto_get_frame_protocols(const wmem_list_t *layers,
3190 bool *is_ip, bool *is_tcp, bool *is_udp, bool *is_sctp,
3191 bool *is_tls, bool *is_rtp, bool *is_lte_rlc);
3192
3198WS_DLL_PUBLIC bool proto_is_frame_protocol(const wmem_list_t *layers, const char* proto_name);
3199
3204WS_DLL_PUBLIC char * proto_list_layers(const packet_info *pinfo);
3205
3213WS_DLL_PUBLIC uint8_t proto_get_layer_num(const packet_info *pinfo, const int proto_id);
3214
3217WS_DLL_PUBLIC void proto_disable_by_default(const int proto_id);
3218
3222WS_DLL_PUBLIC void proto_set_decoding(const int proto_id, const bool enabled);
3223
3225WS_DLL_PUBLIC void proto_disable_all(void);
3226
3228WS_DLL_PUBLIC void proto_reenable_all(void);
3229
3232WS_DLL_PUBLIC void proto_set_cant_toggle(const int proto_id);
3233
3239extern bool proto_check_for_protocol_or_field(const proto_tree* tree, const int id);
3240
3249WS_DLL_PUBLIC GPtrArray* proto_get_finfo_ptr_array(const proto_tree *tree, const int hfindex);
3250
3255WS_DLL_PUBLIC bool proto_tracking_interesting_fields(const proto_tree *tree);
3256
3266WS_DLL_PUBLIC GPtrArray* proto_find_finfo(proto_tree *tree, const int hfindex);
3267
3277WS_DLL_PUBLIC GPtrArray* proto_find_first_finfo(proto_tree *tree, const int hfindex);
3278
3286WS_DLL_PUBLIC GPtrArray* proto_all_finfos(proto_tree *tree);
3287
3289WS_DLL_PUBLIC void proto_registrar_dump_protocols(void);
3290
3292WS_DLL_PUBLIC void proto_registrar_dump_values(void);
3293
3295WS_DLL_PUBLIC void proto_registrar_dump_elastic(const char* filter);
3296
3299WS_DLL_PUBLIC bool proto_registrar_dump_fieldcount(void);
3300
3302WS_DLL_PUBLIC void proto_registrar_dump_fields(void);
3303
3312WS_DLL_PUBLIC bool proto_registrar_dump_field_completions(const char *prefix);
3313
3318WS_DLL_PUBLIC void proto_registrar_dump_ftypes(void);
3319
3327WS_DLL_PUBLIC const char *proto_field_display_to_string(int field_display);
3328
3332WS_DLL_PUBLIC int num_tree_types;
3333
3339WS_DLL_PUBLIC bool tree_expanded(int tree_type);
3340
3347WS_DLL_PUBLIC void tree_expanded_set(int tree_type, bool value);
3348
3357WS_DLL_PUBLIC int
3358hfinfo_bitshift(const header_field_info *hfinfo);
3359
3360struct epan_dissect;
3361
3366WS_DLL_PUBLIC bool
3367proto_can_match_selected(const field_info *finfo, struct epan_dissect *edt);
3368
3373WS_DLL_PUBLIC char*
3375
3381WS_DLL_PUBLIC field_info*
3383
3388WS_DLL_PUBLIC char*
3389proto_find_undecoded_data(proto_tree *tree, unsigned length);
3390
3410WS_DLL_PUBLIC proto_item *
3411proto_tree_add_bitmask(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3412 const int hf_hdr, const int ett, int * const *fields, const unsigned encoding);
3413
3436WS_DLL_PUBLIC proto_item *
3438 const int hf_hdr, const int ett, int * const *fields,
3439 const unsigned encoding, uint64_t *retval);
3440
3464WS_DLL_PUBLIC proto_item *
3466 const int hf_hdr, const int ett, int * const *fields, const unsigned encoding, const int flags);
3467
3494WS_DLL_PUBLIC proto_item *
3496 const int hf_hdr, const int ett, int * const *fields,
3497 const unsigned encoding, const int flags, uint64_t *retval);
3498
3518WS_DLL_PUBLIC proto_item *
3519proto_tree_add_bitmask_value(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3520 const int hf_hdr, const int ett, int * const *fields, const uint64_t value);
3521
3545WS_DLL_PUBLIC proto_item *
3547 const int hf_hdr, const int ett, int * const *fields, const uint64_t value, const int flags);
3548
3563WS_DLL_PUBLIC void
3564proto_tree_add_bitmask_list(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3565 const int len, int * const *fields, const unsigned encoding);
3566
3582WS_DLL_PUBLIC void
3584 const int len, int * const *fields, const unsigned encoding, uint64_t *retval);
3585
3600WS_DLL_PUBLIC void
3602 const int len, int * const *fields, const uint64_t value);
3603
3604
3626WS_DLL_PUBLIC proto_item *
3627proto_tree_add_bitmask_len(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len,
3628 const int hf_hdr, const int ett, int * const *fields, struct expert_field* exp, const unsigned encoding);
3629
3642WS_DLL_PUBLIC proto_item *
3643proto_tree_add_bitmask_text(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len,
3644 const char *name, const char *fallback,
3645 const int ett, int * const *fields, const unsigned encoding, const int flags);
3646
3647#define BMT_NO_FLAGS 0x00
3648#define BMT_NO_APPEND 0x01
3649#define BMT_NO_INT 0x02
3650#define BMT_NO_FALSE 0x04
3651#define BMT_NO_TFS 0x08
3662WS_DLL_PUBLIC proto_item *
3663proto_tree_add_bits_item(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset,
3664 const int no_of_bits, const unsigned encoding);
3665
3681WS_DLL_PUBLIC proto_item *
3683 const unsigned bit_offset, const crumb_spec_t *crumb_spec, uint64_t *return_value);
3684
3698WS_DLL_PUBLIC void
3700 const unsigned bit_offset, const crumb_spec_t *crumb_spec, uint16_t crumb_index);
3701
3712WS_DLL_PUBLIC proto_item *
3714 const unsigned bit_offset, const int no_of_bits, uint64_t *return_value, const unsigned encoding);
3715
3728WS_DLL_PUBLIC proto_item *
3730 const unsigned bit_offset, const int no_of_bits, uint32_t value, const unsigned encoding,
3731 const char *format, ...)
3732 G_GNUC_PRINTF(8,9);
3733
3746WS_DLL_PUBLIC proto_item *
3748 const unsigned bit_offset, const int no_of_bits, uint64_t value, const unsigned encoding,
3749 const char *format, ...)
3750 G_GNUC_PRINTF(8,9);
3751
3765WS_DLL_PUBLIC proto_item *
3767 const unsigned bit_offset, const int no_of_bits, uint64_t value, const unsigned encoding,
3768 const char *format, ...)
3769 G_GNUC_PRINTF(8,9);
3770
3784WS_DLL_PUBLIC proto_item *
3786 const unsigned bit_offset, const int no_of_bits, int32_t value, const unsigned encoding,
3787 const char *format, ...)
3788 G_GNUC_PRINTF(8,9);
3789
3803WS_DLL_PUBLIC proto_item *
3805 const unsigned bit_offset, const int no_of_bits, int64_t value, const unsigned encoding,
3806 const char *format, ...)
3807 G_GNUC_PRINTF(8,9);
3808
3822WS_DLL_PUBLIC proto_item *
3824 const unsigned bit_offset, const int no_of_bits, float value, const unsigned encoding,
3825 const char *format, ...)
3826 G_GNUC_PRINTF(8,9);
3827
3828
3837WS_DLL_PUBLIC proto_item *
3839 const unsigned bit_offset, const int no_of_chars);
3840
3848WS_DLL_PUBLIC proto_item *
3850 const unsigned bit_offset, const int no_of_chars);
3851
3866WS_DLL_PUBLIC proto_item *
3867proto_tree_add_checksum(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3868 const int hf_checksum, const int hf_checksum_status, struct expert_field* bad_checksum_expert,
3869 packet_info *pinfo, uint32_t computed_checksum, const unsigned encoding, const unsigned flags);
3870
3885WS_DLL_PUBLIC proto_item*
3886proto_tree_add_checksum_bytes(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3887 const int hf_checksum, const int hf_checksum_status, struct expert_field* bad_checksum_expert,
3888 packet_info *pinfo, const uint8_t *computed_checksum, size_t checksum_len, const unsigned flags);
3889
3901
3902#define PROTO_CHECKSUM_NO_FLAGS 0x00
3903#define PROTO_CHECKSUM_VERIFY 0x01
3904#define PROTO_CHECKSUM_GENERATED 0x02
3905#define PROTO_CHECKSUM_IN_CKSUM 0x04
3906#define PROTO_CHECKSUM_ZERO 0x08
3907#define PROTO_CHECKSUM_NOT_PRESENT 0x10
3909WS_DLL_PUBLIC const value_string proto_checksum_vals[];
3910
3917WS_DLL_PUBLIC unsigned char
3918proto_check_field_name(const char *field_name);
3919
3924WS_DLL_PUBLIC unsigned char
3925proto_check_field_name_lower(const char *field_name);
3926
3927
3937const char *
3938proto_custom_set(proto_tree* tree, GSList *field_id,
3939 int occurrence,
3940 bool display_details,
3941 char *result,
3942 char *expr, const int size );
3943
3952char *
3953proto_custom_get_filter(struct epan_dissect *edt, GSList *field_id, int occurrence);
3954
3955#ifdef __cplusplus
3956}
3957#endif /* __cplusplus */
3958
3959/*
3960 * Editor modelines - https://www.wireshark.org/tools/modelines.html
3961 *
3962 * Local variables:
3963 * c-basic-offset: 4
3964 * tab-width: 8
3965 * indent-tabs-mode: nil
3966 * End:
3967 *
3968 * vi: set shiftwidth=4 tabstop=8 expandtab:
3969 * :indentSize=4:tabSize=8:noTabs=true:
3970 */
enum ftenum ftenum_t
Convenience typedef for ftenum.
Definition ftypes.h:190
ftenum
Fundamental field value types used throughout the Wireshark dissector framework.
Definition ftypes.h:26
WS_DLL_PUBLIC bool proto_registrar_dump_fieldcount(void)
Definition proto.c:12142
WS_DLL_PUBLIC unsigned char proto_check_field_name_lower(const char *field_name)
WS_DLL_PUBLIC proto_item * proto_tree_add_string_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const char *value, const char *format,...)
Definition proto.c:5489
WS_DLL_PUBLIC int hf_text_only
Definition proto.h:45
WS_DLL_PUBLIC void proto_tree_add_bitmask_list_ret_uint64(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int len, int *const *fields, const unsigned encoding, uint64_t *retval)
Definition proto.c:13290
WS_DLL_PUBLIC proto_item * proto_tree_add_int64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, int64_t value, const char *format,...)
Definition proto.c:6221
WS_DLL_PUBLIC proto_item * proto_tree_add_bitmask_value(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int hf_hdr, const int ett, int *const *fields, const uint64_t value)
Definition proto.c:13240
#define ITEM_LABEL_LENGTH
Definition proto.h:48
WS_DLL_PUBLIC const char * proto_get_protocol_name(const int proto_id)
Definition proto.c:8721
WS_DLL_PUBLIC void proto_get_frame_protocols(const wmem_list_t *layers, bool *is_ip, bool *is_tcp, bool *is_udp, bool *is_sctp, bool *is_tls, bool *is_rtp, bool *is_lte_rlc)
Definition proto.c:8782
WS_DLL_PUBLIC proto_item * proto_tree_add_bytes_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *start_ptr, const char *format,...)
Definition proto.c:4892
WS_DLL_PUBLIC bool proto_is_protocol_enabled(const protocol_t *protocol)
Definition proto.c:8890
struct _item_label_t item_label_t
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_uint32(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, uint32_t *retval)
Add an FT_UINT32 item to the protocol tree and return its value.
Definition proto.c:3435
WS_DLL_PUBLIC void proto_tree_add_split_bits_crumb(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const crumb_spec_t *crumb_spec, uint16_t crumb_index)
Definition proto.c:13758
WS_DLL_PUBLIC proto_item * proto_tree_add_time_item(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, const unsigned length, const unsigned encoding, nstime_t *retval, unsigned *endoff, int *err)
Definition proto.c:4672
WS_DLL_PUBLIC proto_item * proto_tree_add_uint_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint32_t value, const char *format,...)
Definition proto.c:5943
WS_DLL_PUBLIC proto_item * proto_tree_add_time_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, nstime_t *value_ptr, const char *format,...)
Definition proto.c:4980
#define FI_URL
Definition proto.h:863
size_t value_pos
Definition proto.h:812
WS_DLL_PUBLIC bool proto_field_is_referenced(proto_tree *tree, int proto_id)
Definition proto.c:978
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_boolean(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, bool *retval)
Add an FT_BOOLEAN item to the protocol tree and return its value.
Definition proto.c:3874
WS_DLL_PUBLIC void proto_register_subtree_array(int *const *indices, const int num_indices)
Definition proto.c:10063
WS_DLL_PUBLIC proto_item * proto_tree_add_bits_item(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, const unsigned encoding)
Definition proto.c:13403
WS_DLL_PUBLIC bool tree_expanded(int tree_type)
Return whether subtrees of a given type are currently expanded.
uint64_t bitmask
Definition proto.h:778
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_int(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, int32_t *retval)
Definition proto.c:3302
WS_DLL_PUBLIC proto_item * proto_tree_add_bits_ret_val(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, uint64_t *return_value, const unsigned encoding)
Definition proto.c:13788
WS_DLL_PUBLIC proto_item * proto_tree_add_item_new_ret_length(proto_tree *tree, header_field_info *hfinfo, tvbuff_t *tvb, const int start, int length, const unsigned encoding, int *lenretval)
Definition proto.c:4462
WS_DLL_PUBLIC proto_item * proto_tree_add_split_bits_item_ret_val(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const crumb_spec_t *crumb_spec, uint64_t *return_value)
Definition proto.c:13580
WS_DLL_PUBLIC char * proto_list_layers(const packet_info *pinfo)
Definition proto.c:8847
WS_DLL_PUBLIC proto_item * proto_tree_add_time(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const nstime_t *value_ptr)
Definition proto.c:4961
WS_DLL_PUBLIC void proto_deregister_field(const int parent, int hf_id)
Definition proto.c:9060
void proto_tree_prime_with_hfid(proto_tree *tree, const int hfid)
void proto_add_deregistered_slice(size_t block_size, void *mem_block)
Definition proto.c:9123
WS_DLL_PUBLIC int proto_item_get_len(const proto_item *pi)
Definition proto.c:8081
WS_DLL_PUBLIC header_field_info * proto_get_first_protocol_field(const int proto_id, void **cookie)
Begin iterating over all header fields registered to a protocol.
Definition proto.c:8635
int same_name_prev_id
Definition proto.h:785
WS_DLL_PUBLIC int proto_get_id_by_short_name(const char *short_name)
Definition proto.c:8707
WS_DLL_PUBLIC void proto_item_set_len(proto_item *pi, const int length)
Definition proto.c:8034
WS_DLL_PUBLIC proto_item * proto_tree_add_checksum(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int hf_checksum, const int hf_checksum_status, struct expert_field *bad_checksum_expert, packet_info *pinfo, uint32_t computed_checksum, const unsigned encoding, const unsigned flags)
Definition proto.c:14185
WS_DLL_PUBLIC proto_item * proto_tree_add_protocol_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const char *format,...)
Definition proto.c:4801
WS_DLL_PUBLIC void proto_tree_add_bitmask_list_value(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int len, int *const *fields, const uint64_t value)
Definition proto.c:13306
WS_DLL_PUBLIC int proto_get_next_protocol(void **cookie)
Advance the protocol iterator and return the next protocol ID.
Definition proto.c:8621
WS_DLL_PUBLIC proto_item * proto_tree_add_bytes_item(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, unsigned length, const unsigned encoding, GByteArray *retval, unsigned *endoff, int *err)
Definition proto.c:4530
WS_DLL_PUBLIC bool proto_is_pino(const protocol_t *protocol)
Definition proto.c:8883
WS_DLL_PUBLIC proto_item * proto_tree_add_int64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, int64_t value, const char *format,...)
Definition proto.c:6267
proto_item * proto_tree_add_text_valist_internal(proto_tree *tree, tvbuff_t *tvb, int start, int length, const char *format, va_list ap)
Definition proto.c:1508
WS_DLL_PUBLIC int proto_get_data_protocol(void *cookie)
Return the protocol ID stored in the current iterator position.
Definition proto.c:8612
WS_DLL_PUBLIC proto_item * proto_tree_add_int_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, int32_t value, const unsigned encoding, const char *format,...)
Definition proto.c:14029
tvbuff_t * ds_tvb
Definition proto.h:826
WS_DLL_PUBLIC proto_item * proto_tree_add_format_wsp_text(proto_tree *tree, tvbuff_t *tvb, int start, int length)
Definition proto.c:1606
WS_DLL_PUBLIC proto_item * proto_tree_add_bytes_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *start_ptr, const char *format,...)
Definition proto.c:4912
WS_DLL_PUBLIC proto_item * proto_tree_add_guid_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const e_guid_t *value_ptr, const char *format,...)
Definition proto.c:5289
WS_DLL_PUBLIC const char * proto_registrar_get_name(const int n)
Definition proto.c:11528
WS_DLL_PUBLIC void proto_registrar_dump_elastic(const char *filter)
Definition proto.c:12243
WS_DLL_PUBLIC void proto_set_decoding(const int proto_id, const bool enabled)
Definition proto.c:8940
WS_DLL_PUBLIC bool proto_name_already_registered(const char *name)
Definition proto.c:8683
WS_DLL_PUBLIC void proto_register_field_array(const int parent, hf_register_info *hf, const int num_records)
Definition proto.c:9018
WS_DLL_PUBLIC GPtrArray * proto_find_first_finfo(proto_tree *tree, const int hfindex)
Definition proto.c:11724
WS_DLL_PUBLIC proto_item * proto_tree_add_double_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, double value, const char *format,...)
Definition proto.c:5885
WS_DLL_PUBLIC proto_tree * proto_tree_add_subtree_format(proto_tree *tree, tvbuff_t *tvb, int start, int length, int idx, proto_item **tree_item, const char *format,...)
Definition proto.c:1544
WS_DLL_PUBLIC proto_item * proto_tree_add_double(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, double value)
Definition proto.c:5848
WS_DLL_PUBLIC int proto_registrar_get_length(const int n)
Definition proto.c:11577
WS_DLL_PUBLIC const char * proto_get_protocol_filter_name(const int proto_id)
Definition proto.c:8749
void(* proto_tree_foreach_func)(proto_node *node, void *data)
Callback type for proto_tree_children_foreach().
Definition proto.h:1097
hf_ref_type
Enum for specifying whether a field is referenced by a filter, and if so, how.
Definition proto.h:757
WS_DLL_PUBLIC const char * proto_get_protocol_long_name(const protocol_t *protocol)
Definition proto.c:8741
WS_DLL_PUBLIC void proto_tree_children_foreach(proto_tree *tree, proto_tree_foreach_func func, void *data)
Invoke a callback for each direct child of a proto_tree node.
Definition proto.c:844
WS_DLL_PUBLIC enum ftenum proto_registrar_get_ftype(const int n)
Definition proto.c:11546
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_ipv4(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, ws_in4_addr *retval)
Add an FT_IPv4 item to the protocol tree and return its value.
Definition proto.c:4004
#define FI_RESET_FLAG(fi, flag)
Definition proto.h:886
WS_DLL_PUBLIC void proto_initialize_all_prefixes(void)
Definition proto.c:1077
int proto_layer_num
Definition proto.h:829
WS_DLL_PUBLIC int hfinfo_bitshift(const header_field_info *hfinfo)
Return the number of bits to right-shift a field's bitmask to obtain its least-significant bit positi...
Definition proto.c:11088
WS_DLL_PUBLIC proto_item * proto_tree_add_guid_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const e_guid_t *value_ptr, const char *format,...)
Definition proto.c:5270
WS_DLL_PUBLIC proto_item * proto_item_get_parent(const proto_item *pi)
Definition proto.c:8247
WS_DLL_PUBLIC int proto_registrar_get_id_byname(const char *field_name)
Definition proto.c:1161
int display
Definition proto.h:773
WS_DLL_PUBLIC proto_item * proto_tree_add_ts_23_038_7bits_packed_item(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_chars)
Definition proto.c:14117
WS_DLL_PUBLIC proto_item * proto_tree_add_int_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, int32_t value, const char *format,...)
Definition proto.c:6144
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_display_string_and_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, wmem_allocator_t *scope, char **retval, int *lenretval)
Definition proto.c:4216
WS_DLL_PUBLIC proto_item * proto_tree_add_ipv6_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const ws_in6_addr *value_ptr, const char *format,...)
Definition proto.c:5179
WS_DLL_PUBLIC header_field_info * proto_registrar_get_byalias(const char *alias_name)
Definition proto.c:1130
struct _mac_hf_list_t mac_hf_list_t
proto_checksum_enum_e
Checksum verification result for a protocol field.
Definition proto.h:3894
WS_DLL_PUBLIC proto_item * proto_tree_add_boolean(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint64_t value)
Definition proto.c:5622
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_float(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, float *retval)
Parse a float from the buffer and add it to the tree, returning the item added and the parsed value v...
Definition proto.c:3926
WS_DLL_PUBLIC GPtrArray * proto_all_finfos(proto_tree *tree)
Definition proto.c:11754
WS_DLL_PUBLIC void proto_execute_in_directory(const char *dir, proto_execute_in_directory_func func, void *param)
Definition proto.c:805
WS_DLL_PUBLIC proto_item * proto_tree_add_int_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, int32_t value, const char *format,...)
Definition proto.c:6126
WS_DLL_PUBLIC proto_item * proto_tree_add_ipxnet(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint32_t value)
Definition proto.c:5028
WS_DLL_PUBLIC size_t proto_registrar_get_count(struct proto_registrar_stats *stats)
Definition proto.c:11586
WS_DLL_PUBLIC void proto_tree_set_appendix(proto_tree *tree, tvbuff_t *tvb, int start, const int length)
Definition proto.c:8344
WS_DLL_PUBLIC void proto_item_fill_label(const field_info *finfo, char *label_str, size_t *value_offset)
Definition proto.c:10229
WS_DLL_PUBLIC proto_item * proto_tree_add_uint64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint64_t value, const char *format,...)
Definition proto.c:6053
WS_DLL_PUBLIC void proto_heuristic_dissector_foreach(const protocol_t *protocol, GFunc func, void *user_data)
Definition proto.c:8773
WS_DLL_PUBLIC proto_tree * proto_tree_add_subtree(proto_tree *tree, tvbuff_t *tvb, int start, int length, int idx, proto_item **tree_item, const char *text)
Definition proto.c:1536
int total_layer_num
Definition proto.h:828
WS_DLL_PUBLIC proto_tree * proto_tree_get_parent_tree(proto_tree *tree)
Definition proto.c:8274
WS_DLL_PUBLIC int proto_register_protocol_in_name_only(const char *name, const char *short_name, const char *filter_name, int parent_proto, enum ftenum field_type)
Definition proto.c:8481
struct _proto_node proto_node
WS_DLL_PUBLIC proto_item * proto_tree_add_ipxnet_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint32_t value, const char *format,...)
Definition proto.c:5047
WS_DLL_PUBLIC char * proto_construct_match_selected_string(const field_info *finfo, struct epan_dissect *edt)
Definition proto.c:12753
WS_DLL_PUBLIC const char * proto_get_protocol_short_name(const protocol_t *protocol)
Definition proto.c:8733
WS_DLL_PUBLIC char * proto_find_undecoded_data(proto_tree *tree, unsigned length)
Definition proto.c:11840
void proto_pre_init(void)
Pre-initialise the proto subsystem memory structures.
Definition proto.c:564
WS_DLL_PUBLIC int proto_item_fill_display_label(const field_info *fi, char *display_label_str, const int label_str_size)
Definition proto.c:7190
WS_DLL_PUBLIC bool proto_is_protocol_enabled_by_default(const protocol_t *protocol)
Definition proto.c:8904
WS_DLL_PUBLIC field_info * proto_find_field_from_offset(proto_tree *tree, unsigned offset, tvbuff_t *tvb)
Definition proto.c:11801
WS_DLL_PUBLIC void proto_registrar_dump_values(void)
Definition proto.c:11927
WS_DLL_PUBLIC proto_item * proto_tree_add_bitmask_len(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len, const int hf_hdr, const int ett, int *const *fields, struct expert_field *exp, const unsigned encoding)
Definition proto.c:13328
WS_DLL_PUBLIC void tree_expanded_set(int tree_type, bool value)
Set the expansion state for subtrees of a given type.
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_double(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, double *retval)
Parse a double from the buffer and add it to the tree, returning the item added and the parsed value ...
Definition proto.c:3965
unsigned crumb_bit_offset
Definition proto.h:844
WS_DLL_PUBLIC void proto_item_set_bits_offset_len(proto_item *ti, int bits_offset, int bits_len)
Definition proto.c:8095
#define FI_GET_FLAG(fi, flag)
Definition proto.h:878
WS_DLL_PUBLIC uint8_t proto_get_layer_num(const packet_info *pinfo, const int proto_id)
Definition proto.c:8870
proto_node proto_item
Definition proto.h:922
const void * strings
Definition proto.h:774
WS_DLL_PUBLIC proto_item * proto_tree_add_uint64_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, uint64_t value, const unsigned encoding, const char *format,...)
Definition proto.c:13974
int appendix_start
Definition proto.h:821
WS_DLL_PUBLIC proto_item * proto_tree_add_ipv6_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const ws_in6_addr *value_ptr, const char *format,...)
Definition proto.c:5198
WS_DLL_PUBLIC proto_item * proto_tree_add_ether_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *value, const char *format,...)
Definition proto.c:5570
WS_DLL_PUBLIC proto_item * proto_tree_add_ipv4_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, ws_in4_addr value, const char *format,...)
Definition proto.c:5130
WS_DLL_PUBLIC int proto_registrar_get_parent(const int n)
Definition proto.c:11555
WS_DLL_PUBLIC header_field_info * proto_get_next_protocol_field(const int proto_id, void **cookie)
Advance the field iterator and return the next header field.
Definition proto.c:8647
WS_DLL_PUBLIC proto_tree * proto_item_add_subtree(proto_item *pi, const int idx) G_GNUC_WARN_UNUSED_RESULT
Definition proto.c:8217
WS_DLL_PUBLIC proto_item * proto_tree_add_float(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, float value)
Definition proto.c:5783
WS_DLL_PUBLIC proto_item * proto_tree_add_item(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding)
Append a decoded field to a protocol tree using a registered header-field index.
Definition proto.c:4448
WS_DLL_PUBLIC proto_item * proto_tree_add_mac48_detail(const mac_hf_list_t *list_specific, const mac_hf_list_t *list_generic, int idx, tvbuff_t *tvb, proto_tree *tree, int offset)
Definition proto.c:6365
WS_DLL_PUBLIC header_field_info * proto_registrar_get_nth(unsigned hfindex)
Definition proto.c:1002
void(* proto_execute_in_directory_func)(void *param)
Callback type for a function executed within a specific directory context.
Definition proto.h:1185
#define FI_HIDDEN
Definition proto.h:858
WS_DLL_PUBLIC proto_item * proto_tree_add_format_text(proto_tree *tree, tvbuff_t *tvb, int start, int length)
Definition proto.c:1587
WS_DLL_PUBLIC proto_item * proto_tree_add_eui64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint64_t value, const char *format,...)
Definition proto.c:6325
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_ether(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, uint8_t *retval)
Parse an ethernet address from the buffer and add it to the tree, writing the value to the pointer sp...
Definition proto.c:4096
WS_DLL_PUBLIC proto_item * proto_tree_add_int64_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, int64_t value, const unsigned encoding, const char *format,...)
Definition proto.c:14062
WS_DLL_PUBLIC proto_item * proto_item_get_parent_nth(proto_item *pi, int gen)
Definition proto.c:8254
uint32_t flags
Definition proto.h:824
WS_DLL_PUBLIC unsigned char proto_check_field_name(const char *field_name)
Check if a given string is a valid protocol field name.
WS_DLL_PUBLIC proto_item * proto_tree_add_debug_text(proto_tree *tree, const char *format,...)
Definition proto.c:1566
WS_DLL_PUBLIC void proto_item_prepend_text(proto_item *pi, const char *format,...)
Definition proto.c:7956
WS_DLL_PUBLIC proto_item * proto_tree_add_uint_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint32_t value, const char *format,...)
Definition proto.c:5961
proto_item * proto_tree_add_text_internal(proto_tree *tree, tvbuff_t *tvb, int start, int length, const char *format,...)
Definition proto.c:1478
WS_DLL_PUBLIC proto_item * proto_tree_add_oid(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *value_ptr)
Definition proto.c:5328
WS_DLL_PUBLIC proto_item * proto_tree_add_ipxnet_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint32_t value, const char *format,...)
Definition proto.c:5065
const header_field_info * hfinfo
Definition proto.h:818
WS_DLL_PUBLIC GPtrArray * proto_get_finfo_ptr_array(const proto_tree *tree, const int hfindex)
Definition proto.c:11634
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, int *lenretval)
Add an item to a protocol tree and return the length of the parsed field.
Definition proto.c:4504
WS_DLL_PUBLIC proto_item * proto_tree_add_oid_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *value_ptr, const char *format,...)
Definition proto.c:5347
WS_DLL_PUBLIC proto_item * proto_tree_add_int(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, int32_t value)
Definition proto.c:6098
WS_DLL_PUBLIC proto_item * proto_tree_add_time_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, nstime_t *value_ptr, const char *format,...)
Definition proto.c:4998
WS_DLL_PUBLIC proto_item * proto_tree_add_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const char *value)
Definition proto.c:5431
unsigned start
Definition proto.h:819
void proto_tree_set_fake_protocols(proto_tree *tree, bool fake_protocols)
Definition proto.c:964
void proto_tree_prime_with_hfid_print(proto_tree *tree, const int hfid)
WS_DLL_PUBLIC proto_item * proto_tree_add_bitmask_with_flags_ret_uint64(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int hf_hdr, const int ett, int *const *fields, const unsigned encoding, const int flags, uint64_t *retval)
Definition proto.c:13180
bool proto_deregister_protocol(const char *short_name)
Definition proto.c:8540
WS_DLL_PUBLIC proto_item * proto_tree_add_eui64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint64_t value, const char *format,...)
Definition proto.c:6307
WS_DLL_PUBLIC bool proto_is_frame_protocol(const wmem_list_t *layers, const char *proto_name)
Definition proto.c:8822
size_t protocol_count
Definition proto.h:3032
const char * name
Definition proto.h:770
WS_DLL_PUBLIC void proto_add_deregistered_data(void *data)
Definition proto.c:9117
field_display_e
Enum for specifying the display format of a field.
Definition proto.h:681
WS_DLL_PUBLIC void proto_item_set_end(proto_item *pi, tvbuff_t *tvb, unsigned end)
Definition proto.c:8056
WS_DLL_PUBLIC const char * proto_registrar_get_abbrev(const int n)
Definition proto.c:11537
void(* prefix_initializer_t)(const char *match)
Definition proto.h:2910
WS_DLL_PUBLIC proto_item * proto_tree_add_boolean_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint64_t value, const char *format,...)
Definition proto.c:5659
WS_DLL_PUBLIC proto_item * proto_tree_add_ether_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *value, const char *format,...)
Definition proto.c:5588
item_label_t * rep
Definition proto.h:825
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_varint(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, uint64_t *retval, int *lenretval)
Add a variable-length integer item to the protocol tree and return its value and consumed byte count.
Definition proto.c:3816
WS_DLL_PUBLIC proto_item * proto_tree_add_uint_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, uint32_t value, const unsigned encoding, const char *format,...)
Definition proto.c:13941
WS_DLL_PUBLIC bool proto_tree_set_visible(proto_tree *tree, bool visible)
Definition proto.c:954
int * p_id
Definition proto.h:805
size_t value_len
Definition proto.h:813
WS_DLL_PUBLIC proto_item * proto_tree_add_none_format(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const int start, int length, const char *format,...)
Definition proto.c:4742
void proto_cleanup(void)
Release all memory allocated by the proto subsystem.
Definition proto.c:760
WS_DLL_PUBLIC proto_item * proto_tree_add_int64(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, int64_t value)
Definition proto.c:6193
WS_DLL_PUBLIC int proto_get_id_by_filter_name(const char *filter_name)
Definition proto.c:8693
WS_DLL_PUBLIC WS_NORETURN void proto_report_dissector_bug(const char *format,...)
Definition proto.c:1627
bool(* proto_tree_traverse_func)(proto_node *node, void *data)
Callback type for depth-first proto_tree traversal functions.
Definition proto.h:1105
void proto_add_heuristic_dissector(protocol_t *protocol, const char *short_name)
Definition proto.c:8759
WS_DLL_PUBLIC proto_tree * proto_item_get_subtree(proto_item *pi)
Definition proto.c:8235
WS_DLL_PUBLIC void proto_tree_free(proto_tree *tree)
Free a protocol tree and all of its nodes.
Definition proto.c:928
hf_ref_type ref_type
Definition proto.h:784
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_uint8(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, uint8_t *retval)
Add an FT_UINT8 item to the protocol tree and return its value.
Definition proto.c:3443
WS_DLL_PUBLIC void proto_registrar_dump_fields(void)
Definition proto.c:12403
WS_DLL_PUBLIC int proto_get_first_protocol(void **cookie)
Begin iterating over all registered protocols.
Definition proto.c:8600
WS_DLL_PUBLIC proto_item * proto_tree_add_bitmask(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int hf_hdr, const int ett, int *const *fields, const unsigned encoding)
Definition proto.c:13168
WS_DLL_PUBLIC proto_item * proto_tree_add_bitmask_value_with_flags(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int hf_hdr, const int ett, int *const *fields, const uint64_t value, const int flags)
Definition proto.c:13249
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_time_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, wmem_allocator_t *scope, char **retval)
Definition proto.c:4344
WS_DLL_PUBLIC void proto_tree_move_item(proto_tree *tree, proto_item *fixed_item, proto_item *item_to_move)
Definition proto.c:8297
WS_DLL_PUBLIC proto_item * proto_tree_add_ascii_7bits_item(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_chars)
Definition proto.c:14145
proto_node proto_tree
Definition proto.h:920
WS_DLL_PUBLIC proto_item * proto_tree_add_string_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const char *value, const char *format,...)
Definition proto.c:5470
WS_DLL_PUBLIC char * proto_item_get_display_repr(wmem_allocator_t *scope, proto_item *pi)
Definition proto.c:8104
WS_DLL_PUBLIC proto_item * proto_tree_add_ether(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *value)
Definition proto.c:5551
WS_DLL_PUBLIC proto_item * proto_tree_add_ipv4(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, ws_in4_addr value)
Definition proto.c:5093
WS_DLL_PUBLIC bool proto_can_match_selected(const field_info *finfo, struct epan_dissect *edt)
Definition proto.c:12741
WS_DLL_PUBLIC GPtrArray * proto_find_finfo(proto_tree *tree, const int hfindex)
Definition proto.c:11705
int parent
Definition proto.h:783
WS_DLL_PUBLIC proto_item * proto_tree_add_eui64(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint64_t value)
Definition proto.c:6288
WS_DLL_PUBLIC proto_item * proto_tree_add_float_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, float value, const char *format,...)
Definition proto.c:5820
WS_DLL_PUBLIC void proto_disable_by_default(const int proto_id)
Definition proto.c:8928
void proto_init(GSList *register_all_plugin_protocols_list, GSList *register_all_plugin_handoffs_list, register_entity_func register_func, register_entity_func handoff_func, register_cb cb, void *client_data)
Initialise the proto subsystem and run all registration callbacks.
Definition proto.c:591
WS_DLL_PUBLIC proto_item * proto_tree_add_bytes_with_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *start_ptr, int ptr_length)
Definition proto.c:4868
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_int64(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, int64_t *retval)
Add an FT_INT64 item to the protocol tree and return its value.
Definition proto.c:3756
WS_DLL_PUBLIC void proto_item_set_text(proto_item *pi, const char *format,...)
Definition proto.c:7875
WS_DLL_PUBLIC proto_item * proto_tree_add_float_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, float value, const char *format,...)
Definition proto.c:5802
WS_DLL_PUBLIC proto_item * proto_tree_add_item_new(proto_tree *tree, header_field_info *hfinfo, tvbuff_t *tvb, const int start, int length, const unsigned encoding)
Definition proto.c:4427
WS_DLL_PUBLIC void proto_deregister_all_fields_with_prefix(const int parent, const char *prefix)
Definition proto.c:9091
WS_DLL_PUBLIC void proto_tree_add_bitmask_list(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int len, int *const *fields, const unsigned encoding)
Definition proto.c:13277
WS_DLL_PUBLIC proto_item * proto_tree_get_parent(proto_tree *tree)
Definition proto.c:8267
WS_DLL_PUBLIC void proto_register_plugin(const proto_plugin *plugin)
Register a dissector plugin with the plugin system.
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_string_and_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, wmem_allocator_t *scope, const uint8_t **retval, int *lenretval)
Definition proto.c:4135
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_display_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, wmem_allocator_t *scope, char **retval)
Definition proto.c:4332
WS_DLL_PUBLIC void proto_set_cant_toggle(const int proto_id)
Definition proto.c:8999
WS_DLL_PUBLIC bool proto_tracking_interesting_fields(const proto_tree *tree)
Definition proto.c:11647
WS_DLL_PUBLIC void proto_register_prefix(const char *prefix, prefix_initializer_t initializer)
Definition proto.c:1060
enum ftenum type
Definition proto.h:772
WS_DLL_PUBLIC int proto_register_protocol(const char *name, const char *short_name, const char *filter_name)
Definition proto.c:8418
WS_DLL_PUBLIC void proto_registrar_dump_protocols(void)
Definition proto.c:11864
WS_DLL_PUBLIC proto_item * proto_tree_add_uint64(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint64_t value)
Definition proto.c:6006
size_t deregistered_count
Definition proto.h:3033
WS_DLL_PUBLIC proto_item * proto_tree_add_checksum_bytes(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int hf_checksum, const int hf_checksum_status, struct expert_field *bad_checksum_expert, packet_info *pinfo, const uint8_t *computed_checksum, size_t checksum_len, const unsigned flags)
Definition proto.c:14295
const char * proto_custom_set(proto_tree *tree, GSList *field_id, int occurrence, bool display_details, char *result, char *expr, const int size)
Set the column text for a custom column.
Definition proto.c:7483
bool proto_check_for_protocol_or_field(const proto_tree *tree, const int id)
Definition proto.c:11616
const char * abbrev
Definition proto.h:771
char * proto_custom_get_filter(struct epan_dissect *edt, GSList *field_id, int occurrence)
Construct a display filter string for a custom column.
Definition proto.c:7719
const char * blurb
Definition proto.h:779
WS_DLL_PUBLIC proto_tree * proto_tree_create_root(packet_info *pinfo)
Allocate and initialise a new protocol tree root node.
Definition proto.c:8118
size_t same_name_count
Definition proto.h:3034
WS_DLL_PUBLIC proto_item * proto_tree_add_bitmask_with_flags(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int hf_hdr, const int ett, int *const *fields, const unsigned encoding, const int flags)
Definition proto.c:13215
WS_DLL_PUBLIC proto_item * proto_tree_add_uint(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint32_t value)
Definition proto.c:5913
WS_DLL_PUBLIC proto_item * proto_tree_add_guid(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const e_guid_t *value_ptr)
Definition proto.c:5251
WS_DLL_PUBLIC proto_tree * proto_tree_get_root(proto_tree *tree)
Definition proto.c:8287
int appendix_length
Definition proto.h:822
WS_DLL_PUBLIC bool proto_registrar_dump_field_completions(const char *prefix)
Dump all protocol and field abbreviations that start with a given prefix to standard output.
Definition proto.c:12514
WS_DLL_PUBLIC bool proto_can_toggle_protocol(const int proto_id)
Definition proto.c:8915
WS_DLL_PUBLIC void proto_registrar_dump_ftypes(void)
Dump all registered field types and their descriptive names to standard output.
Definition proto.c:12579
WS_DLL_PUBLIC proto_item * proto_tree_add_float_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, float value, const unsigned encoding, const char *format,...)
Definition proto.c:14007
WS_DLL_PUBLIC proto_item * proto_tree_add_ipv6(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const ws_in6_addr *value_ptr)
Definition proto.c:5160
WS_DLL_PUBLIC proto_item * proto_tree_add_double_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, double value, const char *format,...)
Definition proto.c:5867
WS_DLL_PUBLIC protocol_t * find_protocol_by_id(const int proto_id)
Definition proto.c:8662
WS_DLL_PUBLIC void proto_reenable_all(void)
Definition proto.c:8981
WS_DLL_PUBLIC bool proto_registrar_is_protocol(const int n)
Definition proto.c:11564
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_uint64(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, uint64_t *retval)
Add an FT_UINT64 item to the protocol tree and return its value.
Definition proto.c:3691
WS_DLL_PUBLIC void proto_disable_all(void)
Definition proto.c:8951
uint8_t crumb_bit_length
Definition proto.h:845
WS_DLL_PUBLIC header_field_info * proto_registrar_get_byname(const char *field_name)
Definition proto.c:1088
WS_DLL_PUBLIC int num_tree_types
Total number of registered subtree types.
Definition proto.h:3332
void proto_tree_reset(proto_tree *tree)
Reset a protocol tree to its initial empty state, retaining the root node and its associated tree dat...
Definition proto.c:899
#define PITEM_FINFO(proto_item)
Definition proto.h:990
WS_DLL_PUBLIC const char * proto_field_display_to_string(int field_display)
Convert a field display value to its string representation.
Definition proto.c:9328
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_uint(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, uint32_t *retval)
Add an FT_UINT32 (or compatible uint) item to the protocol tree and return its value as a uint32_t.
Definition proto.c:3367
WS_DLL_PUBLIC proto_item * proto_tree_add_ipv4_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, ws_in4_addr value, const char *format,...)
Definition proto.c:5112
WS_DLL_PUBLIC proto_item * proto_tree_add_boolean_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint64_t value, const char *format,...)
Definition proto.c:5641
WS_DLL_PUBLIC proto_item * proto_tree_add_oid_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *value_ptr, const char *format,...)
Definition proto.c:5366
WS_DLL_PUBLIC void proto_free_deregistered_fields(void)
Definition proto.c:9279
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_uint16(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, uint16_t *retval)
Add an FT_UINT16 item to the protocol tree and return its value.
Definition proto.c:3455
int id
Definition proto.h:782
#define FI_GENERATED
Definition proto.h:861
unsigned length
Definition proto.h:820
#define FI_SET_FLAG(fi, flag)
Definition proto.h:880
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_ipv6(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, ws_in6_addr *retval)
Parse an ipv6 address from the buffer and add it to the tree, writing the value to the pointer specif...
Definition proto.c:4057
WS_DLL_PUBLIC proto_item * proto_tree_add_uint64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, uint64_t value, const char *format,...)
Definition proto.c:6035
int tree_type
Definition proto.h:823
WS_DLL_PUBLIC proto_item * proto_tree_add_bytes(proto_tree *tree, int hfindex, tvbuff_t *tvb, int start, int length, const uint8_t *start_ptr)
Definition proto.c:4840
WS_DLL_PUBLIC proto_item * proto_tree_add_item_ret_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, const int start, int length, const unsigned encoding, wmem_allocator_t *scope, const uint8_t **retval)
Definition proto.c:4206
WS_DLL_PUBLIC int proto_get_id(const protocol_t *protocol)
Definition proto.c:8677
header_field_info hfinfo
Definition proto.h:806
WS_DLL_PUBLIC void proto_register_alias(const int proto_id, const char *alias_name)
Definition proto.c:8582
WS_DLL_PUBLIC void proto_free_field_strings(ftenum_t field_type, unsigned int field_display, const void *field_strings)
Definition proto.c:9133
WS_DLL_PUBLIC proto_item * proto_tree_add_boolean_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, uint64_t value, const unsigned encoding, const char *format,...)
Definition proto.c:14095
WS_DLL_PUBLIC proto_item * proto_tree_add_bitmask_text(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len, const char *name, const char *fallback, const int ett, int *const *fields, const unsigned encoding, const int flags)
Definition proto.c:13380
WS_DLL_PUBLIC proto_item * proto_tree_add_bitmask_ret_uint64(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const int hf_hdr, const int ett, int *const *fields, const unsigned encoding, uint64_t *retval)
Definition proto.c:13142
WS_DLL_PUBLIC void proto_item_append_text(proto_item *pi, const char *format,...)
Definition proto.c:7898
header_field_info * same_name_next
Definition proto.h:786
@ HF_REF_TYPE_INDIRECT
Definition proto.h:759
@ HF_REF_TYPE_NONE
Definition proto.h:758
@ HF_REF_TYPE_DIRECT
Definition proto.h:760
@ HF_REF_TYPE_PRINT
Definition proto.h:761
@ PROTO_CHECKSUM_E_GOOD
Definition proto.h:3896
@ PROTO_CHECKSUM_E_ILLEGAL
Definition proto.h:3899
@ PROTO_CHECKSUM_E_BAD
Definition proto.h:3895
@ PROTO_CHECKSUM_E_NOT_PRESENT
Definition proto.h:3898
@ PROTO_CHECKSUM_E_UNVERIFIED
Definition proto.h:3897
@ ABSOLUTE_TIME_DOY_UTC
Definition proto.h:714
@ BASE_PT_UDP
Definition proto.h:703
@ BASE_HEX_DEC
Definition proto.h:689
@ BASE_HEX
Definition proto.h:686
@ ABSOLUTE_TIME_NTP_UTC
Definition proto.h:715
@ BASE_EXP
Definition proto.h:691
@ ABSOLUTE_TIME_UTC
Definition proto.h:713
@ BASE_DEC
Definition proto.h:685
@ ABSOLUTE_TIME_UNIX
Definition proto.h:716
@ BASE_PT_TCP
Definition proto.h:704
@ BASE_DEC_HEX
Definition proto.h:688
@ BASE_OUI
Definition proto.h:709
@ SEP_COLON
Definition proto.h:696
@ BASE_PT_SCTP
Definition proto.h:706
@ BASE_NETMASK
Definition proto.h:700
@ ABSOLUTE_TIME_LOCAL
Definition proto.h:712
@ BASE_PT_DCCP
Definition proto.h:705
@ BASE_STR_WSP
Definition proto.h:719
@ BASE_NONE
Definition proto.h:682
@ SEP_DOT
Definition proto.h:694
@ SEP_DASH
Definition proto.h:695
@ SEP_SPACE
Definition proto.h:697
@ BASE_OCT
Definition proto.h:687
@ BASE_CUSTOM
Definition proto.h:690
uint32_t ws_in4_addr
Represents a 32-bit IPv4 address in network byte order.
Definition inet_addr.h:22
Represents a GUID/UUID value; may be larger than GUID_LEN so must not be used to directly overlay pac...
Definition guid-utils.h:21
Represents a typed field value used in protocol dissection.
Definition ftypes-int.h:22
Definition proto.h:768
Definition proto.h:810
Definition proto.h:2814
Represents the metadata and indexing information for a single captured frame.
Definition packet_info.h:43
Definition plugins.c:33
Definition proto.h:909
Definition proto.c:385
Mapping between a 32-bit integer value and its string representation.
Definition value_string.h:33
Internal memory allocator interface used by the wmem subsystem.
Definition wmem_allocator.h:34
Definition wmem_list.c:23
Definition packet-bt-dht.c:97
This structure describes one segment of a split-bits item.
Definition proto.h:843
Represents a 128-bit IPv6 address.
Definition inet_addr.h:27
Holds all state for the dissection of a single byte array, including session, buffer,...
Definition epan_dissect.h:28
tvbuff_t * tvb
Definition epan_dissect.h:30
proto_tree * tree
Definition epan_dissect.h:31
Pairs an expert info index with its associated header field index for registration and display.
Definition expert.h:41
Definition proto.h:817
Definition proto.h:804
Definition nstime.h:26
Descriptor for a dissector plugin's registration entry points.
Definition proto.h:1120
Holds aggregate statistics about the state of the protocol registrar.
Definition proto.h:3031
Definition proto.h:897
Core tvbuff (testy virtual buffer) structure representing a region of packet data,...
Definition tvbuff-int.h:95