Wireshark 4.7.2
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 <[email protected]>
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
43
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
140
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
734
735#define BASE_UNIT_STRING 0x00001000
736
737#define BASE_NO_DISPLAY_VALUE 0x00002000
739
740#define BASE_PROTOCOL_INFO 0x00004000
741
742#define BASE_SPECIAL_VALS 0x00008000
743
744#define BASE_SHOW_ASCII_PRINTABLE 0x00010000
745
746#define BASE_SHOW_UTF_8_PRINTABLE 0x00020000
747
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;
780
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
817typedef struct field_info {
819 unsigned start;
820 unsigned length;
821 unsigned appendix_start;
824 uint32_t flags;
826 tvbuff_t *ds_tvb;
827 fvalue_t *value;
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)
885
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
920typedef proto_node proto_tree;
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 unsigned length);
1262
1284WS_DLL_PUBLIC void proto_item_set_end(proto_item *pi, tvbuff_t *tvb, unsigned end);
1285
1301WS_DLL_PUBLIC unsigned proto_item_get_len(const proto_item *pi);
1302
1308WS_DLL_PUBLIC void proto_item_set_bits_offset_len(proto_item *ti, int bits_offset, int bits_len);
1309
1322WS_DLL_PUBLIC char *proto_item_get_display_repr(wmem_allocator_t *scope, proto_item *pi);
1323
1330WS_DLL_PUBLIC proto_tree *proto_tree_create_root(packet_info *pinfo);
1331
1338void proto_tree_reset(proto_tree *tree);
1339
1345WS_DLL_PUBLIC void proto_tree_free(proto_tree *tree);
1346
1354WS_DLL_PUBLIC bool
1355proto_tree_set_visible(proto_tree *tree, bool visible);
1356
1360extern void
1361proto_tree_set_fake_protocols(proto_tree *tree, bool fake_protocols);
1362
1369extern void
1370proto_tree_prime_with_hfid(proto_tree *tree, const int hfid);
1371
1377extern void
1378proto_tree_prime_with_hfid_print(proto_tree *tree, const int hfid);
1379
1383WS_DLL_PUBLIC proto_item* proto_tree_get_parent(proto_tree *tree);
1384
1388WS_DLL_PUBLIC proto_tree *proto_tree_get_parent_tree(proto_tree *tree);
1389
1393WS_DLL_PUBLIC proto_tree* proto_tree_get_root(proto_tree *tree);
1394
1399WS_DLL_PUBLIC void proto_tree_move_item(proto_tree *tree, proto_item *fixed_item, proto_item *item_to_move);
1400
1401
1411WS_DLL_PUBLIC void proto_tree_set_appendix(proto_tree *tree, tvbuff_t *tvb, unsigned start, const unsigned length);
1412
1413
1423WS_DLL_PUBLIC proto_item *
1424proto_tree_add_item_new(proto_tree *tree, header_field_info *hfinfo, tvbuff_t *tvb,
1425 const unsigned start, int length, const unsigned encoding);
1426
1448WS_DLL_PUBLIC proto_item *
1449proto_tree_add_item(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1450 const unsigned start, int length, const unsigned encoding);
1451
1464WS_DLL_PUBLIC proto_item *
1465proto_tree_add_item_new_ret_length(proto_tree *tree, header_field_info *hfinfo, tvbuff_t *tvb,
1466 const unsigned start, int length, const unsigned encoding, int *lenretval);
1467
1480WS_DLL_PUBLIC proto_item *
1481proto_tree_add_item_ret_length(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1482 const unsigned start, int length, const unsigned encoding, int *lenretval);
1483
1515WS_DLL_PUBLIC proto_item *
1516proto_tree_add_item_ret_int(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1517 const unsigned start, int length, const unsigned encoding, int32_t *retval);
1518
1531WS_DLL_PUBLIC proto_item *
1532proto_tree_add_item_ret_int64(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1533 const unsigned start, int length, const unsigned encoding, int64_t *retval);
1534
1548WS_DLL_PUBLIC proto_item *
1549proto_tree_add_item_ret_uint(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1550 const unsigned start, int length, const unsigned encoding, uint32_t *retval);
1551
1567WS_DLL_PUBLIC proto_item *
1568proto_tree_add_item_ret_uint32(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1569 const unsigned start, int length, const unsigned encoding, uint32_t *retval);
1570
1583WS_DLL_PUBLIC proto_item *
1584proto_tree_add_item_ret_uint8(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1585 const unsigned start, int length, const unsigned encoding, uint8_t *retval);
1586
1599WS_DLL_PUBLIC proto_item *
1600proto_tree_add_item_ret_uint16(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1601 const unsigned start, int length, const unsigned encoding, uint16_t *retval);
1602
1615WS_DLL_PUBLIC proto_item *
1616proto_tree_add_item_ret_uint64(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1617 const unsigned start, int length, const unsigned encoding, uint64_t *retval);
1618
1641WS_DLL_PUBLIC proto_item *
1642proto_tree_add_item_ret_varint(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1643 const unsigned start, int length, const unsigned encoding, uint64_t *retval, int *lenretval);
1644
1657WS_DLL_PUBLIC proto_item *
1658proto_tree_add_item_ret_boolean(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1659 const unsigned start, int length, const unsigned encoding, bool *retval);
1660
1674WS_DLL_PUBLIC proto_item *
1675proto_tree_add_item_ret_ipv4(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1676 const unsigned start, int length, const unsigned encoding, ws_in4_addr *retval);
1677
1692WS_DLL_PUBLIC proto_item *
1693proto_tree_add_item_ret_ipv6(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1694 const unsigned start, int length, const unsigned encoding, ws_in6_addr *retval);
1695
1710WS_DLL_PUBLIC proto_item *
1711proto_tree_add_item_ret_ether(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1712 const unsigned start, int length, const unsigned encoding, uint8_t *retval);
1713
1727WS_DLL_PUBLIC proto_item *
1728proto_tree_add_item_ret_float(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1729 const unsigned start, int length,
1730 const unsigned encoding, float *retval);
1731
1745WS_DLL_PUBLIC proto_item *
1746proto_tree_add_item_ret_double(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1747 const unsigned start, int length,
1748 const unsigned encoding, double *retval);
1749
1779WS_DLL_PUBLIC proto_item *
1780proto_tree_add_item_ret_string_and_length(proto_tree *tree, int hfindex,
1781 tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding,
1782 wmem_allocator_t *scope, const uint8_t **retval, int *lenretval);
1783
1811WS_DLL_PUBLIC proto_item *
1812proto_tree_add_item_ret_string(proto_tree *tree, int hfindex, tvbuff_t *tvb,
1813 const unsigned start, int length, const unsigned encoding,
1814 wmem_allocator_t *scope, const uint8_t **retval);
1815
1836WS_DLL_PUBLIC proto_item *
1837proto_tree_add_item_ret_display_string_and_length(proto_tree *tree, int hfindex,
1838 tvbuff_t *tvb,
1839 const unsigned start, int length, const unsigned encoding,
1840 wmem_allocator_t *scope, char **retval, int *lenretval);
1841
1859WS_DLL_PUBLIC proto_item *
1860proto_tree_add_item_ret_display_string(proto_tree *tree, int hfindex,
1861 tvbuff_t *tvb,
1862 const unsigned start, int length, const unsigned encoding,
1863 wmem_allocator_t *scope, char **retval);
1864
1880WS_DLL_PUBLIC proto_item *
1881proto_tree_add_item_ret_time_string(proto_tree *tree, int hfindex,
1882 tvbuff_t *tvb,
1883 const unsigned start, int length, const unsigned encoding,
1884 wmem_allocator_t *scope, char **retval);
1885
1894proto_item *
1895proto_tree_add_text_internal(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length, const char *format,
1896 ...) G_GNUC_PRINTF(5,6);
1897
1906proto_item *
1907proto_tree_add_text_valist_internal(proto_tree *tree, tvbuff_t *tvb, unsigned start,
1908 int length, const char *format, va_list ap) G_GNUC_PRINTF(5, 0);
1909
1919WS_DLL_PUBLIC proto_tree *
1920proto_tree_add_subtree(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length, int idx,
1921 proto_item **tree_item, const char *text);
1922
1933WS_DLL_PUBLIC proto_tree *
1934proto_tree_add_subtree_format(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length, int idx,
1935 proto_item **tree_item, const char *format, ...) G_GNUC_PRINTF(7,8);
1936
1938WS_DLL_PUBLIC proto_item *
1939proto_tree_add_format_text(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length);
1940
1942WS_DLL_PUBLIC proto_item *
1943proto_tree_add_format_wsp_text(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length);
1944
1954WS_DLL_PUBLIC proto_item *
1955proto_tree_add_none_format(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned start,
1956 int length, const char *format, ...) G_GNUC_PRINTF(6,7);
1957
1967WS_DLL_PUBLIC proto_item *
1968proto_tree_add_protocol_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
1969 int length, const char *format, ...) G_GNUC_PRINTF(6,7);
1970
1979WS_DLL_PUBLIC proto_item *
1980proto_tree_add_bytes(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
1981 int length, const uint8_t* start_ptr);
1982
1993WS_DLL_PUBLIC proto_item *
1994proto_tree_add_bytes_with_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
1995 int length, const uint8_t *start_ptr, int ptr_length);
1996
2030WS_DLL_PUBLIC proto_item *
2031proto_tree_add_bytes_item(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2032 const unsigned start, unsigned length, const unsigned encoding,
2033 GByteArray *retval, unsigned *endoff, int *err);
2034
2048WS_DLL_PUBLIC proto_item *
2049proto_tree_add_bytes_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2050 unsigned start, int length, const uint8_t* start_ptr, const char *format,
2051 ...) G_GNUC_PRINTF(7,8);
2052
2065WS_DLL_PUBLIC proto_item *
2066proto_tree_add_bytes_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2067 int length, const uint8_t* start_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2068
2077WS_DLL_PUBLIC proto_item *
2078proto_tree_add_time(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2079 unsigned length, const nstime_t* value_ptr);
2080
2111WS_DLL_PUBLIC proto_item *
2112proto_tree_add_time_item(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2113 const unsigned start, const unsigned length, const unsigned encoding,
2114 nstime_t *retval, unsigned *endoff, int *err);
2115
2116
2129WS_DLL_PUBLIC proto_item *
2130proto_tree_add_time_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2131 unsigned start, unsigned length, nstime_t* value_ptr, const char *format, ...)
2132 G_GNUC_PRINTF(7,8);
2133
2146WS_DLL_PUBLIC proto_item *
2147proto_tree_add_time_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2148 unsigned length, nstime_t* value_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2149
2158WS_DLL_PUBLIC proto_item *
2159proto_tree_add_ipxnet(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2160 unsigned length, uint32_t value);
2161
2174WS_DLL_PUBLIC proto_item *
2175proto_tree_add_ipxnet_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2176 unsigned start, unsigned length, uint32_t value, const char *format, ...)
2177 G_GNUC_PRINTF(7,8);
2178
2190WS_DLL_PUBLIC proto_item *
2191proto_tree_add_ipxnet_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2192 unsigned length, uint32_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2193
2202WS_DLL_PUBLIC proto_item *
2203proto_tree_add_ipv4(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2204 unsigned length, ws_in4_addr value);
2205
2218WS_DLL_PUBLIC proto_item *
2219proto_tree_add_ipv4_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2220 unsigned start, unsigned length, ws_in4_addr value, const char *format, ...)
2221 G_GNUC_PRINTF(7,8);
2222
2234WS_DLL_PUBLIC proto_item *
2235proto_tree_add_ipv4_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2236 unsigned length, ws_in4_addr value, const char *format, ...) G_GNUC_PRINTF(7,8);
2237
2246WS_DLL_PUBLIC proto_item *
2247proto_tree_add_ipv6(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2248 unsigned length, const ws_in6_addr *value_ptr);
2249
2262WS_DLL_PUBLIC proto_item *
2263proto_tree_add_ipv6_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2264 unsigned start, unsigned length, const ws_in6_addr *value_ptr, const char *format,
2265 ...) G_GNUC_PRINTF(7,8);
2266
2278WS_DLL_PUBLIC proto_item *
2279proto_tree_add_ipv6_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2280 unsigned length, const ws_in6_addr *value_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2281
2290WS_DLL_PUBLIC proto_item *
2291proto_tree_add_ether(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2292 unsigned length, const uint8_t* value);
2293
2306WS_DLL_PUBLIC proto_item *
2307proto_tree_add_ether_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2308 unsigned start, unsigned length, const uint8_t* value, const char *format, ...)
2309 G_GNUC_PRINTF(7,8);
2310
2322WS_DLL_PUBLIC proto_item *
2323proto_tree_add_ether_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2324 unsigned length, const uint8_t* value, const char *format, ...) G_GNUC_PRINTF(7,8);
2325
2334WS_DLL_PUBLIC proto_item *
2335proto_tree_add_guid(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2336 unsigned length, const e_guid_t *value_ptr);
2337
2350WS_DLL_PUBLIC proto_item *
2351proto_tree_add_guid_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2352 unsigned start, unsigned length, const e_guid_t *value_ptr, const char *format,
2353 ...) G_GNUC_PRINTF(7,8);
2354
2366WS_DLL_PUBLIC proto_item *
2367proto_tree_add_guid_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2368 unsigned length, const e_guid_t *value_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2369
2378WS_DLL_PUBLIC proto_item *
2379proto_tree_add_oid(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2380 unsigned length, const uint8_t* value_ptr);
2381
2394WS_DLL_PUBLIC proto_item *
2395proto_tree_add_oid_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2396 unsigned start, unsigned length, const uint8_t* value_ptr, const char *format,
2397 ...) G_GNUC_PRINTF(7,8);
2398
2410WS_DLL_PUBLIC proto_item *
2411proto_tree_add_oid_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2412 unsigned length, const uint8_t* value_ptr, const char *format, ...) G_GNUC_PRINTF(7,8);
2413
2433WS_DLL_PUBLIC proto_item *
2434proto_tree_add_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2435 int length, const char* value);
2436
2449WS_DLL_PUBLIC proto_item *
2450proto_tree_add_string_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2451 unsigned start, int length, const char* value, const char *format, ...)
2452 G_GNUC_PRINTF(7,8);
2453
2466WS_DLL_PUBLIC proto_item *
2467proto_tree_add_string_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2468 int length, const char* value, const char *format, ...) G_GNUC_PRINTF(7,8);
2469
2478WS_DLL_PUBLIC proto_item *
2479proto_tree_add_boolean(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2480 unsigned length, uint64_t value);
2481
2494WS_DLL_PUBLIC proto_item *
2495proto_tree_add_boolean_format_value(proto_tree *tree, int hfindex,
2496 tvbuff_t *tvb, unsigned start, unsigned length, uint64_t value,
2497 const char *format, ...) G_GNUC_PRINTF(7,8);
2498
2510WS_DLL_PUBLIC proto_item *
2511proto_tree_add_boolean_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2512 unsigned length, uint64_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2513
2522WS_DLL_PUBLIC proto_item *
2523proto_tree_add_float(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2524 unsigned length, float value);
2525
2538WS_DLL_PUBLIC proto_item *
2539proto_tree_add_float_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2540 unsigned start, unsigned length, float value, const char *format, ...)
2541 G_GNUC_PRINTF(7,8);
2542
2554WS_DLL_PUBLIC proto_item *
2555proto_tree_add_float_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2556 unsigned length, float value, const char *format, ...) G_GNUC_PRINTF(7,8);
2557
2566WS_DLL_PUBLIC proto_item *
2567proto_tree_add_double(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2568 unsigned length, double value);
2569
2582WS_DLL_PUBLIC proto_item *
2583proto_tree_add_double_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2584 unsigned start, unsigned length, double value, const char *format, ...)
2585 G_GNUC_PRINTF(7,8);
2586
2598WS_DLL_PUBLIC proto_item *
2599proto_tree_add_double_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2600 unsigned length, double value, const char *format, ...) G_GNUC_PRINTF(7,8);
2601
2610WS_DLL_PUBLIC proto_item *
2611proto_tree_add_uint(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2612 unsigned length, uint32_t value);
2613
2626WS_DLL_PUBLIC proto_item *
2627proto_tree_add_uint_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2628 unsigned start, unsigned length, uint32_t value, const char *format, ...)
2629 G_GNUC_PRINTF(7,8);
2630
2643WS_DLL_PUBLIC proto_item *
2644proto_tree_add_uint_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2645 unsigned length, uint32_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2646
2655WS_DLL_PUBLIC proto_item *
2656proto_tree_add_uint64(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2657 unsigned length, uint64_t value);
2658
2671WS_DLL_PUBLIC proto_item *
2672proto_tree_add_uint64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2673 unsigned start, unsigned length, uint64_t value, const char *format, ...)
2674 G_GNUC_PRINTF(7,8);
2675
2687WS_DLL_PUBLIC proto_item *
2688proto_tree_add_uint64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2689 unsigned length, uint64_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2690
2699WS_DLL_PUBLIC proto_item *
2700proto_tree_add_int(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2701 unsigned length, int32_t value);
2702
2715WS_DLL_PUBLIC proto_item *
2716proto_tree_add_int_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2717 unsigned start, unsigned length, int32_t value, const char *format, ...)
2718 G_GNUC_PRINTF(7,8);
2719
2732WS_DLL_PUBLIC proto_item *
2733proto_tree_add_int_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2734 unsigned length, int32_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2735
2744WS_DLL_PUBLIC proto_item *
2745proto_tree_add_int64(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2746 unsigned length, int64_t value);
2747
2760WS_DLL_PUBLIC proto_item *
2761proto_tree_add_int64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2762 unsigned start, unsigned length, int64_t value, const char *format, ...)
2763 G_GNUC_PRINTF(7,8);
2764
2776WS_DLL_PUBLIC proto_item *
2777proto_tree_add_int64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2778 unsigned length, int64_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2779
2788WS_DLL_PUBLIC proto_item *
2789proto_tree_add_eui64(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2790 unsigned length, const uint64_t value);
2791
2804WS_DLL_PUBLIC proto_item *
2805proto_tree_add_eui64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb,
2806 unsigned start, unsigned length, const uint64_t value, const char *format, ...)
2807 G_GNUC_PRINTF(7,8);
2808
2820WS_DLL_PUBLIC proto_item *
2821proto_tree_add_eui64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start,
2822 unsigned length, const uint64_t value, const char *format, ...) G_GNUC_PRINTF(7,8);
2823
2825typedef struct _mac_hf_list_t {
2826 int *hf_addr; // FT_ETHER, BASE_NONE
2827 int *hf_addr_resolved; // FT_STRING, BASE_NONE
2828 int *hf_oui; // FT_UINT24, BASE_OUI
2829 int *hf_oui_resolved; // FT_STRING, BASE_NONE
2830 int *hf_lg; // FT_BOOLEAN, 24 bits, mask 0x020000
2831 int *hf_ig; // FT_BOOLEAN, 24 bits, mask 0x010000
2833
2843WS_DLL_PUBLIC proto_item *
2844proto_tree_add_mac48_detail(const mac_hf_list_t *list_specific,
2845 const mac_hf_list_t *list_generic,
2846 int idx, tvbuff_t *tvb, proto_tree *tree, unsigned offset);
2847
2854WS_DLL_PUBLIC proto_item *
2855proto_tree_add_debug_text(proto_tree *tree, const char *format,
2856 ...) G_GNUC_PRINTF(2,3);
2857
2863WS_DLL_PUBLIC void
2864proto_item_fill_label(const field_info *finfo, char *label_str, size_t *value_offset);
2865
2873WS_DLL_PUBLIC int
2874proto_item_fill_display_label(const field_info *fi, char *display_label_str, const int label_str_size);
2875
2881WS_DLL_PUBLIC int
2882proto_register_protocol(const char *name, const char *short_name, const char *filter_name);
2883
2898WS_DLL_PUBLIC int
2899proto_register_protocol_in_name_only(const char *name, const char *short_name, const char *filter_name,
2900 int parent_proto, enum ftenum field_type);
2901
2907bool
2908proto_deregister_protocol(const char *short_name);
2909
2914WS_DLL_PUBLIC void
2915proto_register_alias(const int proto_id, const char *alias_name);
2916
2921typedef void (*prefix_initializer_t)(const char* match);
2922
2930WS_DLL_PUBLIC void
2931proto_register_prefix(const char *prefix, prefix_initializer_t initializer);
2932
2934WS_DLL_PUBLIC void proto_initialize_all_prefixes(void);
2935
2940WS_DLL_PUBLIC void
2941proto_register_field_array(const int parent, hf_register_info *hf, const int num_records);
2942
2946WS_DLL_PUBLIC void
2947proto_deregister_field (const int parent, int hf_id);
2948
2951WS_DLL_PUBLIC void
2952proto_add_deregistered_data (void *data);
2953
2958WS_DLL_PUBLIC void
2959proto_deregister_all_fields_with_prefix(const int parent, const char *prefix);
2960
2964void
2965proto_add_deregistered_slice (size_t block_size, void *mem_block);
2966
2971WS_DLL_PUBLIC void
2972proto_free_field_strings (ftenum_t field_type, unsigned int field_display, const void *field_strings);
2973
2980WS_DLL_PUBLIC void
2982
2986WS_DLL_PUBLIC void
2987proto_register_subtree_array(int * const *indices, const int num_indices);
2988
2992WS_DLL_PUBLIC const char* proto_registrar_get_name(const int n);
2993
2997WS_DLL_PUBLIC const char* proto_registrar_get_abbrev(const int n);
2998
3002WS_DLL_PUBLIC header_field_info* proto_registrar_get_nth(unsigned hfindex);
3003
3007WS_DLL_PUBLIC header_field_info* proto_registrar_get_byname(const char *field_name);
3008
3012WS_DLL_PUBLIC header_field_info* proto_registrar_get_byalias(const char *alias_name);
3013
3017WS_DLL_PUBLIC int proto_registrar_get_id_byname(const char *field_name);
3018
3022WS_DLL_PUBLIC enum ftenum proto_registrar_get_ftype(const int n);
3023
3027WS_DLL_PUBLIC int proto_registrar_get_parent(const int n);
3028
3032WS_DLL_PUBLIC bool proto_registrar_is_protocol(const int n);
3033
3037WS_DLL_PUBLIC int proto_registrar_get_length(const int n);
3038
3047
3051WS_DLL_PUBLIC size_t proto_registrar_get_count(struct proto_registrar_stats *stats);
3052
3064WS_DLL_PUBLIC int proto_get_first_protocol(void **cookie);
3065
3073WS_DLL_PUBLIC int proto_get_data_protocol(void *cookie);
3074
3083WS_DLL_PUBLIC int proto_get_next_protocol(void **cookie);
3084
3096WS_DLL_PUBLIC header_field_info *proto_get_first_protocol_field(const int proto_id, void **cookie);
3097
3108WS_DLL_PUBLIC header_field_info *proto_get_next_protocol_field(const int proto_id, void **cookie);
3109
3113WS_DLL_PUBLIC bool proto_name_already_registered(const char *name);
3114
3118WS_DLL_PUBLIC int proto_get_id_by_filter_name(const char* filter_name);
3119
3123WS_DLL_PUBLIC int proto_get_id_by_short_name(const char* short_name);
3124
3128WS_DLL_PUBLIC bool proto_can_toggle_protocol(const int proto_id);
3129
3132WS_DLL_PUBLIC protocol_t *find_protocol_by_id(const int proto_id);
3133
3137WS_DLL_PUBLIC const char *proto_get_protocol_name(const int proto_id);
3138
3141WS_DLL_PUBLIC int proto_get_id(const protocol_t *protocol);
3142
3145WS_DLL_PUBLIC const char *proto_get_protocol_short_name(const protocol_t *protocol);
3146
3149WS_DLL_PUBLIC const char *proto_get_protocol_long_name(const protocol_t *protocol);
3150
3153WS_DLL_PUBLIC bool proto_is_protocol_enabled(const protocol_t *protocol);
3154
3157WS_DLL_PUBLIC bool proto_is_protocol_enabled_by_default(const protocol_t *protocol);
3158
3161WS_DLL_PUBLIC bool proto_is_pino(const protocol_t *protocol);
3162
3166WS_DLL_PUBLIC const char *proto_get_protocol_filter_name(const int proto_id);
3167
3173extern void proto_add_heuristic_dissector(protocol_t *protocol, const char *short_name);
3174
3180WS_DLL_PUBLIC void proto_heuristic_dissector_foreach(const protocol_t *protocol, GFunc func,
3181 void *user_data);
3182
3200WS_DLL_PUBLIC void proto_get_frame_protocols(const wmem_list_t *layers,
3201 bool *is_ip, bool *is_tcp, bool *is_udp, bool *is_sctp,
3202 bool *is_tls, bool *is_rtp, bool *is_lte_rlc);
3203
3209WS_DLL_PUBLIC bool proto_is_frame_protocol(const wmem_list_t *layers, const char* proto_name);
3210
3215WS_DLL_PUBLIC char * proto_list_layers(const packet_info *pinfo);
3216
3224WS_DLL_PUBLIC uint8_t proto_get_layer_num(const packet_info *pinfo, const int proto_id);
3225
3228WS_DLL_PUBLIC void proto_disable_by_default(const int proto_id);
3229
3233WS_DLL_PUBLIC void proto_set_decoding(const int proto_id, const bool enabled);
3234
3236WS_DLL_PUBLIC void proto_disable_all(void);
3237
3239WS_DLL_PUBLIC void proto_reenable_all(void);
3240
3243WS_DLL_PUBLIC void proto_set_cant_toggle(const int proto_id);
3244
3250extern bool proto_check_for_protocol_or_field(const proto_tree* tree, const int id);
3251
3260WS_DLL_PUBLIC GPtrArray* proto_get_finfo_ptr_array(const proto_tree *tree, const int hfindex);
3261
3266WS_DLL_PUBLIC bool proto_tracking_interesting_fields(const proto_tree *tree);
3267
3277WS_DLL_PUBLIC GPtrArray* proto_find_finfo(proto_tree *tree, const int hfindex);
3278
3288WS_DLL_PUBLIC GPtrArray* proto_find_first_finfo(proto_tree *tree, const int hfindex);
3289
3297WS_DLL_PUBLIC GPtrArray* proto_all_finfos(proto_tree *tree);
3298
3300WS_DLL_PUBLIC void proto_registrar_dump_protocols(void);
3301
3303WS_DLL_PUBLIC void proto_registrar_dump_values(void);
3304
3306WS_DLL_PUBLIC void proto_registrar_dump_elastic(const char* filter);
3307
3310WS_DLL_PUBLIC bool proto_registrar_dump_fieldcount(void);
3311
3313WS_DLL_PUBLIC void proto_registrar_dump_fields(void);
3314
3323WS_DLL_PUBLIC bool proto_registrar_dump_field_completions(const char *prefix);
3324
3329WS_DLL_PUBLIC void proto_registrar_dump_ftypes(void);
3330
3338WS_DLL_PUBLIC const char *proto_field_display_to_string(int field_display);
3339
3343WS_DLL_PUBLIC int num_tree_types;
3344
3350WS_DLL_PUBLIC bool tree_expanded(int tree_type);
3351
3358WS_DLL_PUBLIC void tree_expanded_set(int tree_type, bool value);
3359
3368WS_DLL_PUBLIC int
3369hfinfo_bitshift(const header_field_info *hfinfo);
3370
3371struct epan_dissect;
3372
3377WS_DLL_PUBLIC bool
3378proto_can_match_selected(const field_info *finfo, struct epan_dissect *edt);
3379
3384WS_DLL_PUBLIC char*
3386
3392WS_DLL_PUBLIC field_info*
3393proto_find_field_from_offset(proto_tree *tree, unsigned offset, tvbuff_t *tvb);
3394
3399WS_DLL_PUBLIC char*
3400proto_find_undecoded_data(proto_tree *tree, unsigned length);
3401
3421WS_DLL_PUBLIC proto_item *
3422proto_tree_add_bitmask(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3423 const int hf_hdr, const int ett, int * const *fields, const unsigned encoding);
3424
3447WS_DLL_PUBLIC proto_item *
3448proto_tree_add_bitmask_ret_uint64(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3449 const int hf_hdr, const int ett, int * const *fields,
3450 const unsigned encoding, uint64_t *retval);
3451
3475WS_DLL_PUBLIC proto_item *
3476proto_tree_add_bitmask_with_flags(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3477 const int hf_hdr, const int ett, int * const *fields, const unsigned encoding, const int flags);
3478
3505WS_DLL_PUBLIC proto_item *
3506proto_tree_add_bitmask_with_flags_ret_uint64(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3507 const int hf_hdr, const int ett, int * const *fields,
3508 const unsigned encoding, const int flags, uint64_t *retval);
3509
3529WS_DLL_PUBLIC proto_item *
3530proto_tree_add_bitmask_value(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3531 const int hf_hdr, const int ett, int * const *fields, const uint64_t value);
3532
3556WS_DLL_PUBLIC proto_item *
3557proto_tree_add_bitmask_value_with_flags(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3558 const int hf_hdr, const int ett, int * const *fields, const uint64_t value, const int flags);
3559
3574WS_DLL_PUBLIC void
3575proto_tree_add_bitmask_list(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3576 const unsigned len, int * const *fields, const unsigned encoding);
3577
3593WS_DLL_PUBLIC void
3594proto_tree_add_bitmask_list_ret_uint64(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3595 const unsigned len, int * const *fields, const unsigned encoding, uint64_t *retval);
3596
3611WS_DLL_PUBLIC void
3612proto_tree_add_bitmask_list_value(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3613 const unsigned len, int * const *fields, const uint64_t value);
3614
3615
3637WS_DLL_PUBLIC proto_item *
3638proto_tree_add_bitmask_len(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len,
3639 const int hf_hdr, const int ett, int * const *fields, struct expert_field* exp, const unsigned encoding);
3640
3653WS_DLL_PUBLIC proto_item *
3654proto_tree_add_bitmask_text(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len,
3655 const char *name, const char *fallback,
3656 const int ett, int * const *fields, const unsigned encoding, const int flags);
3657
3658#define BMT_NO_FLAGS 0x00
3659#define BMT_NO_APPEND 0x01
3660#define BMT_NO_INT 0x02
3661#define BMT_NO_FALSE 0x04
3662#define BMT_NO_TFS 0x08
3663
3673WS_DLL_PUBLIC proto_item *
3674proto_tree_add_bits_item(proto_tree *tree, const int hf_index, tvbuff_t *tvb, const unsigned bit_offset,
3675 const int no_of_bits, const unsigned encoding);
3676
3692WS_DLL_PUBLIC proto_item *
3693proto_tree_add_split_bits_item_ret_val(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3694 const unsigned bit_offset, const crumb_spec_t *crumb_spec, uint64_t *return_value);
3695
3709WS_DLL_PUBLIC void
3710proto_tree_add_split_bits_crumb(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3711 const unsigned bit_offset, const crumb_spec_t *crumb_spec, uint16_t crumb_index);
3712
3723WS_DLL_PUBLIC proto_item *
3724proto_tree_add_bits_ret_val(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3725 const unsigned bit_offset, const int no_of_bits, uint64_t *return_value, const unsigned encoding);
3726
3739WS_DLL_PUBLIC proto_item *
3740proto_tree_add_uint_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3741 const unsigned bit_offset, const int no_of_bits, uint32_t value, const unsigned encoding,
3742 const char *format, ...)
3743 G_GNUC_PRINTF(8,9);
3744
3757WS_DLL_PUBLIC proto_item *
3758proto_tree_add_uint64_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3759 const unsigned bit_offset, const int no_of_bits, uint64_t value, const unsigned encoding,
3760 const char *format, ...)
3761 G_GNUC_PRINTF(8,9);
3762
3776WS_DLL_PUBLIC proto_item *
3777proto_tree_add_boolean_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3778 const unsigned bit_offset, const int no_of_bits, uint64_t value, const unsigned encoding,
3779 const char *format, ...)
3780 G_GNUC_PRINTF(8,9);
3781
3795WS_DLL_PUBLIC proto_item *
3796proto_tree_add_int_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3797 const unsigned bit_offset, const int no_of_bits, int32_t value, const unsigned encoding,
3798 const char *format, ...)
3799 G_GNUC_PRINTF(8,9);
3800
3814WS_DLL_PUBLIC proto_item *
3815proto_tree_add_int64_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3816 const unsigned bit_offset, const int no_of_bits, int64_t value, const unsigned encoding,
3817 const char *format, ...)
3818 G_GNUC_PRINTF(8,9);
3819
3833WS_DLL_PUBLIC proto_item *
3834proto_tree_add_float_bits_format_value(proto_tree *tree, const int hf_index, tvbuff_t *tvb,
3835 const unsigned bit_offset, const int no_of_bits, float value, const unsigned encoding,
3836 const char *format, ...)
3837 G_GNUC_PRINTF(8,9);
3838
3839
3848WS_DLL_PUBLIC proto_item *
3849proto_tree_add_ts_23_038_7bits_packed_item(proto_tree *tree, const int hfindex, tvbuff_t *tvb,
3850 const unsigned bit_offset, const int no_of_chars);
3851
3859WS_DLL_PUBLIC proto_item *
3860proto_tree_add_ascii_7bits_item(proto_tree *tree, const int hfindex, tvbuff_t *tvb,
3861 const unsigned bit_offset, const int no_of_chars);
3862
3877WS_DLL_PUBLIC proto_item *
3878proto_tree_add_checksum(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3879 const int hf_checksum, const int hf_checksum_status, struct expert_field* bad_checksum_expert,
3880 packet_info *pinfo, uint32_t computed_checksum, const unsigned encoding, const unsigned flags);
3881
3896WS_DLL_PUBLIC proto_item*
3897proto_tree_add_checksum_bytes(proto_tree *tree, tvbuff_t *tvb, const unsigned offset,
3898 const int hf_checksum, const int hf_checksum_status, struct expert_field* bad_checksum_expert,
3899 packet_info *pinfo, const uint8_t *computed_checksum, size_t checksum_len, const unsigned flags);
3900
3912
3913#define PROTO_CHECKSUM_NO_FLAGS 0x00
3914#define PROTO_CHECKSUM_VERIFY 0x01
3915#define PROTO_CHECKSUM_GENERATED 0x02
3916#define PROTO_CHECKSUM_IN_CKSUM 0x04
3917#define PROTO_CHECKSUM_ZERO 0x08
3918#define PROTO_CHECKSUM_NOT_PRESENT 0x10
3919
3920WS_DLL_PUBLIC const value_string proto_checksum_vals[];
3921
3928WS_DLL_PUBLIC unsigned char
3929proto_check_field_name(const char *field_name);
3930
3935WS_DLL_PUBLIC unsigned char
3936proto_check_field_name_lower(const char *field_name);
3937
3938
3948const char *
3949proto_custom_set(proto_tree* tree, GSList *field_id,
3950 int occurrence,
3951 bool display_details,
3952 char *result,
3953 char *expr, const int size );
3954
3963char *
3964proto_custom_get_filter(struct epan_dissect *edt, GSList *field_id, int occurrence);
3965
3966#ifdef __cplusplus
3967}
3968#endif /* __cplusplus */
3969
3970/*
3971 * Editor modelines - https://www.wireshark.org/tools/modelines.html
3972 *
3973 * Local variables:
3974 * c-basic-offset: 4
3975 * tab-width: 8
3976 * indent-tabs-mode: nil
3977 * End:
3978 *
3979 * vi: set shiftwidth=4 tabstop=8 expandtab:
3980 * :indentSize=4:tabSize=8:noTabs=true:
3981 */
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
struct _packet_info packet_info
Represents the metadata and indexing information for a single captured frame.
WS_DLL_PUBLIC bool proto_registrar_dump_fieldcount(void)
Definition proto.c:12208
WS_DLL_PUBLIC unsigned char proto_check_field_name_lower(const char *field_name)
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:13306
#define ITEM_LABEL_LENGTH
Definition proto.h:48
WS_DLL_PUBLIC const char * proto_get_protocol_name(const int proto_id)
Definition proto.c:8781
proto_item * proto_tree_add_time_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, nstime_t *value_ptr, const char *format,...)
Definition proto.c:4997
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:8842
proto_item * proto_tree_add_item_ret_uint16(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3462
WS_DLL_PUBLIC bool proto_is_protocol_enabled(const protocol_t *protocol)
Definition proto.c:8950
struct _item_label_t item_label_t
void proto_tree_set_appendix(proto_tree *tree, tvbuff_t *tvb, unsigned start, const unsigned length)
Definition proto.c:8403
proto_item * proto_tree_add_guid_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const e_guid_t *value_ptr, const char *format,...)
Definition proto.c:5306
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:13824
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:4682
proto_item * proto_tree_add_item_ret_boolean(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, bool *retval)
Add an FT_BOOLEAN item to the protocol tree and return its value.
Definition proto.c:3881
#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:982
proto_item * proto_tree_add_item_ret_time_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, wmem_allocator_t *scope, char **retval)
Definition proto.c:4351
void proto_register_subtree_array(int *const *indices, const int num_indices)
Definition proto.c:10125
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:13469
WS_DLL_PUBLIC bool tree_expanded(int tree_type)
Return whether subtrees of a given type are currently expanded.
proto_item * proto_tree_add_format_wsp_text(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length)
Definition proto.c:1610
uint64_t bitmask
Definition proto.h:778
proto_tree * proto_tree_add_subtree_format(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length, int idx, proto_item **tree_item, const char *format,...)
Definition proto.c:1548
struct _protocol protocol_t
Definition proto.h:100
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:13854
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:13646
WS_DLL_PUBLIC char * proto_list_layers(const packet_info *pinfo)
Definition proto.c:8907
void proto_deregister_field(const int parent, int hf_id)
Definition proto.c:9120
proto_item * proto_tree_add_uint64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint64_t value, const char *format,...)
Definition proto.c:6070
WS_DLL_PUBLIC void proto_tree_add_bitmask_list_ret_uint64(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len, int *const *fields, const unsigned encoding, uint64_t *retval)
Definition proto.c:13356
void proto_add_deregistered_slice(size_t block_size, void *mem_block)
Definition proto.c:9183
proto_item * proto_tree_add_double(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, double value)
Definition proto.c:5865
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:8695
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:8767
proto_item * proto_tree_add_ipv4_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, ws_in4_addr value, const char *format,...)
Definition proto.c:5129
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:14251
WS_DLL_PUBLIC int proto_get_next_protocol(void **cookie)
Advance the protocol iterator and return the next protocol ID.
Definition proto.c:8681
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:4540
WS_DLL_PUBLIC bool proto_is_pino(const protocol_t *protocol)
Definition proto.c:8943
proto_item * proto_tree_add_ether(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint8_t *value)
Definition proto.c:5568
proto_item * proto_tree_add_guid(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const e_guid_t *value_ptr)
Definition proto.c:5268
WS_DLL_PUBLIC int proto_get_data_protocol(void *cookie)
Return the protocol ID stored in the current iterator position.
Definition proto.c:8672
proto_item * proto_tree_add_int_bits_format_value(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, int32_t value, const unsigned encoding, const char *format,...)
Definition proto.c:14095
proto_item * proto_tree_add_none_format(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned start, int length, const char *format,...)
Definition proto.c:4752
tvbuff_t * ds_tvb
Definition proto.h:826
proto_item * proto_tree_add_uint_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint32_t value, const char *format,...)
Definition proto.c:5978
proto_item * proto_tree_add_item_ret_double(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3972
proto_item * proto_tree_add_string_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, int length, const char *value, const char *format,...)
Definition proto.c:5506
const char * proto_registrar_get_name(const int n)
Definition proto.c:11594
proto_item * proto_tree_add_format_text(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length)
Definition proto.c:1591
proto_item * proto_tree_add_boolean_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint64_t value, const char *format,...)
Definition proto.c:5658
void(* register_handoff)(void)
Routine to call to register dissector handoff.
Definition proto.h:1129
WS_DLL_PUBLIC void proto_registrar_dump_elastic(const char *filter)
Definition proto.c:12309
WS_DLL_PUBLIC void proto_set_decoding(const int proto_id, const bool enabled)
Definition proto.c:9000
WS_DLL_PUBLIC bool proto_name_already_registered(const char *name)
Definition proto.c:8743
void proto_register_field_array(const int parent, hf_register_info *hf, const int num_records)
Definition proto.c:9078
WS_DLL_PUBLIC GPtrArray * proto_find_first_finfo(proto_tree *tree, const int hfindex)
Definition proto.c:11790
proto_item * proto_tree_add_item_ret_uint32(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3442
int proto_registrar_get_length(const int n)
Definition proto.c:11643
WS_DLL_PUBLIC const char * proto_get_protocol_filter_name(const int proto_id)
Definition proto.c:8809
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:8801
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:848
enum ftenum proto_registrar_get_ftype(const int n)
Definition proto.c:11612
proto_item * proto_tree_add_int_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, int32_t value, const char *format,...)
Definition proto.c:6161
#define FI_RESET_FLAG(fi, flag)
Definition proto.h:886
WS_DLL_PUBLIC void proto_tree_add_bitmask_list_value(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len, int *const *fields, const uint64_t value)
Definition proto.c:13372
void proto_initialize_all_prefixes(void)
Definition proto.c:1081
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:11154
proto_item * proto_tree_add_double_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, double value, const char *format,...)
Definition proto.c:5884
proto_item * proto_tree_add_int64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, int64_t value, const char *format,...)
Definition proto.c:6284
proto_item * proto_tree_add_uint_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint32_t value, const char *format,...)
Definition proto.c:5960
WS_DLL_PUBLIC proto_item * proto_item_get_parent(const proto_item *pi)
Definition proto.c:8306
int proto_registrar_get_id_byname(const char *field_name)
Definition proto.c:1165
proto_item * proto_tree_add_float_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, float value, const char *format,...)
Definition proto.c:5837
int display
Definition proto.h:773
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:14183
header_field_info * proto_registrar_get_byalias(const char *alias_name)
Definition proto.c:1134
struct _mac_hf_list_t mac_hf_list_t
proto_checksum_enum_e
Checksum verification result for a protocol field.
Definition proto.h:3905
WS_DLL_PUBLIC GPtrArray * proto_all_finfos(proto_tree *tree)
Definition proto.c:11820
proto_item * proto_tree_add_oid_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint8_t *value_ptr, const char *format,...)
Definition proto.c:5383
WS_DLL_PUBLIC void proto_execute_in_directory(const char *dir, proto_execute_in_directory_func func, void *param)
Definition proto.c:809
proto_item * proto_tree_add_time(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const nstime_t *value_ptr)
Definition proto.c:4978
proto_item * proto_tree_add_text_internal(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length, const char *format,...)
Definition proto.c:1482
WS_DLL_PUBLIC size_t proto_registrar_get_count(struct proto_registrar_stats *stats)
Definition proto.c:11652
void proto_item_fill_label(const field_info *fi, char *label_str, size_t *value_pos)
Definition proto.c:10291
proto_item * proto_tree_add_item_ret_int(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, int32_t *retval)
Definition proto.c:3309
WS_DLL_PUBLIC void proto_heuristic_dissector_foreach(const protocol_t *protocol, GFunc func, void *user_data)
Definition proto.c:8833
int total_layer_num
Definition proto.h:828
proto_tree * proto_tree_get_parent_tree(proto_tree *tree)
Definition proto.c:8333
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:8541
struct _proto_node proto_node
proto_item * proto_tree_add_ipv6_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const ws_in6_addr *value_ptr, const char *format,...)
Definition proto.c:5215
WS_DLL_PUBLIC char * proto_construct_match_selected_string(const field_info *finfo, struct epan_dissect *edt)
Definition proto.c:12819
WS_DLL_PUBLIC const char * proto_get_protocol_short_name(const protocol_t *protocol)
Definition proto.c:8793
WS_DLL_PUBLIC char * proto_find_undecoded_data(proto_tree *tree, unsigned length)
Definition proto.c:11906
void proto_pre_init(void)
Pre-initialise the proto subsystem memory structures.
Definition proto.c:568
int proto_item_fill_display_label(const field_info *finfo, char *display_label_str, const int label_str_size)
Definition proto.c:7241
WS_DLL_PUBLIC bool proto_is_protocol_enabled_by_default(const protocol_t *protocol)
Definition proto.c:8964
WS_DLL_PUBLIC field_info * proto_find_field_from_offset(proto_tree *tree, unsigned offset, tvbuff_t *tvb)
Definition proto.c:11867
proto_item * proto_tree_add_item_ret_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, wmem_allocator_t *scope, const uint8_t **retval)
Definition proto.c:4213
void(* register_protoinfo)(void)
Routine to call to register protocol information.
Definition proto.h:1124
WS_DLL_PUBLIC void proto_registrar_dump_values(void)
Definition proto.c:11993
void proto_item_set_len(proto_item *pi, const unsigned length)
Definition proto.c:8084
proto_item * proto_tree_add_int64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, int64_t value, const char *format,...)
Definition proto.c:6238
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:13394
WS_DLL_PUBLIC void tree_expanded_set(int tree_type, bool value)
Set the expansion state for subtrees of a given type.
proto_item * proto_tree_add_boolean(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint64_t value)
Definition proto.c:5639
unsigned crumb_bit_offset
Definition proto.h:844
void proto_item_set_bits_offset_len(proto_item *ti, int bits_offset, int bits_len)
Definition proto.c:8154
#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:8930
proto_node proto_item
Definition proto.h:922
proto_item * proto_tree_add_item_ret_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:4514
proto_item * proto_tree_add_bytes_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, int length, const uint8_t *start_ptr, const char *format,...)
Definition proto.c:4909
const void * strings
Definition proto.h:774
proto_item * proto_tree_add_uint64_bits_format_value(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, uint64_t value, const unsigned encoding, const char *format,...)
Definition proto.c:14040
int proto_registrar_get_parent(const int n)
Definition proto.c:11621
proto_item * proto_tree_add_ipxnet(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint32_t value)
Definition proto.c:5045
proto_item * proto_tree_add_uint64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint64_t value, const char *format,...)
Definition proto.c:6052
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:8707
WS_DLL_PUBLIC proto_tree * proto_item_add_subtree(proto_item *pi, const int idx) G_GNUC_WARN_UNUSED_RESULT
Definition proto.c:8276
unsigned appendix_length
Definition proto.h:822
proto_item * proto_tree_add_item_new(proto_tree *tree, header_field_info *hfinfo, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding)
Definition proto.c:4434
proto_item * proto_tree_add_item_ret_uint8(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3450
proto_item * proto_tree_add_time_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, nstime_t *value_ptr, const char *format,...)
Definition proto.c:5015
header_field_info * proto_registrar_get_nth(unsigned hfindex)
Definition proto.c:1006
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
proto_item * proto_tree_add_int64_bits_format_value(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, int64_t value, const unsigned encoding, const char *format,...)
Definition proto.c:14128
WS_DLL_PUBLIC proto_item * proto_item_get_parent_nth(proto_item *pi, int gen)
Definition proto.c:8313
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:1570
proto_item * proto_tree_add_uint(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint32_t value)
Definition proto.c:5930
void proto_item_prepend_text(proto_item *pi, const char *format,...)
Definition proto.c:8007
proto_tree * proto_tree_add_subtree(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length, int idx, proto_item **tree_item, const char *text)
Definition proto.c:1540
proto_item * proto_tree_add_guid_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const e_guid_t *value_ptr, const char *format,...)
Definition proto.c:5287
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:11700
proto_item * proto_tree_add_item_ret_float(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3933
proto_item * proto_tree_add_ipv4_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, ws_in4_addr value, const char *format,...)
Definition proto.c:5147
unsigned start
Definition proto.h:819
proto_item * proto_tree_add_item_ret_string_and_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, wmem_allocator_t *scope, const uint8_t **retval, int *lenretval)
Definition proto.c:4142
proto_item * proto_tree_add_item_ret_uint64(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3698
proto_item * proto_tree_add_boolean_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint64_t value, const char *format,...)
Definition proto.c:5676
void proto_tree_set_fake_protocols(proto_tree *tree, bool fake_protocols)
Definition proto.c:968
proto_item * proto_tree_add_oid_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint8_t *value_ptr, const char *format,...)
Definition proto.c:5364
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:13246
bool proto_deregister_protocol(const char *short_name)
Definition proto.c:8600
WS_DLL_PUBLIC bool proto_is_frame_protocol(const wmem_list_t *layers, const char *proto_name)
Definition proto.c:8882
size_t protocol_count
Definition proto.h:3043
const char * name
Definition proto.h:770
void proto_add_deregistered_data(void *data)
Definition proto.c:9177
field_display_e
Enum for specifying the display format of a field.
Definition proto.h:681
void proto_item_set_end(proto_item *pi, tvbuff_t *tvb, unsigned end)
Definition proto.c:8106
proto_item * proto_tree_add_item_ret_display_string_and_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, wmem_allocator_t *scope, char **retval, int *lenretval)
Definition proto.c:4223
proto_item * proto_tree_add_ipxnet_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint32_t value, const char *format,...)
Definition proto.c:5082
const char * proto_registrar_get_abbrev(const int n)
Definition proto.c:11603
void(* prefix_initializer_t)(const char *match)
Definition proto.h:2921
proto_item * proto_tree_add_bytes_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, int length, const uint8_t *start_ptr, const char *format,...)
Definition proto.c:4929
proto_item * proto_tree_add_int(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, int32_t value)
Definition proto.c:6115
item_label_t * rep
Definition proto.h:825
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:14007
bool proto_tree_set_visible(proto_tree *tree, bool visible)
Definition proto.c:958
proto_item * proto_tree_add_ipv6(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const ws_in6_addr *value)
Definition proto.c:5177
proto_item * proto_tree_add_float_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, float value, const char *format,...)
Definition proto.c:5819
int * p_id
Definition proto.h:805
size_t value_len
Definition proto.h:813
void proto_cleanup(void)
Release all memory allocated by the proto subsystem.
Definition proto.c:764
proto_item * proto_tree_add_protocol_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, int length, const char *format,...)
Definition proto.c:4812
proto_item * proto_tree_add_item_ret_display_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, wmem_allocator_t *scope, char **retval)
Definition proto.c:4339
WS_DLL_PUBLIC int proto_get_id_by_filter_name(const char *filter_name)
Definition proto.c:8753
WS_DLL_PUBLIC WS_NORETURN void proto_report_dissector_bug(const char *format,...)
Definition proto.c:1631
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:8819
WS_DLL_PUBLIC proto_tree * proto_item_get_subtree(proto_item *pi)
Definition proto.c:8294
void proto_tree_free(proto_tree *tree)
Free a protocol tree and all of its nodes.
Definition proto.c:932
hf_ref_type ref_type
Definition proto.h:784
WS_DLL_PUBLIC void proto_registrar_dump_fields(void)
Definition proto.c:12469
WS_DLL_PUBLIC int proto_get_first_protocol(void **cookie)
Begin iterating over all registered protocols.
Definition proto.c:8660
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:13234
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:13315
void proto_tree_move_item(proto_tree *tree, proto_item *fixed_item, proto_item *item_to_move)
Definition proto.c:8356
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:14211
char * proto_item_get_display_repr(wmem_allocator_t *scope, proto_item *pi)
Definition proto.c:8163
WS_DLL_PUBLIC bool proto_can_match_selected(const field_info *finfo, struct epan_dissect *edt)
Definition proto.c:12807
proto_item * proto_tree_add_item_ret_varint(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3823
WS_DLL_PUBLIC GPtrArray * proto_find_finfo(proto_tree *tree, const int hfindex)
Definition proto.c:11771
int parent
Definition proto.h:783
proto_item * proto_tree_add_item_ret_int64(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3763
WS_DLL_PUBLIC void proto_disable_by_default(const int proto_id)
Definition proto.c:8988
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:595
proto_item * proto_tree_add_text_valist_internal(proto_tree *tree, tvbuff_t *tvb, unsigned start, int length, const char *format, va_list ap)
Definition proto.c:1512
WS_DLL_PUBLIC void proto_item_set_text(proto_item *pi, const char *format,...)
Definition proto.c:7926
struct _header_field_info header_field_info
Definition proto.h:765
unsigned proto_item_get_len(const proto_item *pi)
Definition proto.c:8131
proto_item * proto_tree_add_ether_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint8_t *value, const char *format,...)
Definition proto.c:5605
void proto_deregister_all_fields_with_prefix(const int parent, const char *prefix)
Definition proto.c:9151
proto_item * proto_tree_get_parent(proto_tree *tree)
Definition proto.c:8326
proto_item * proto_tree_add_ether_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint8_t *value, const char *format,...)
Definition proto.c:5587
proto_item * proto_tree_add_item_ret_ether(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:4103
WS_DLL_PUBLIC void proto_register_plugin(const proto_plugin *plugin)
Register a dissector plugin with the plugin system.
proto_item * proto_tree_add_item_ret_uint(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:3374
proto_item * proto_tree_add_item_ret_ipv4(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned 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:4011
WS_DLL_PUBLIC void proto_set_cant_toggle(const int proto_id)
Definition proto.c:9059
WS_DLL_PUBLIC bool proto_tracking_interesting_fields(const proto_tree *tree)
Definition proto.c:11713
void proto_register_prefix(const char *prefix, prefix_initializer_t pi)
Definition proto.c:1064
enum ftenum type
Definition proto.h:772
int proto_register_protocol(const char *name, const char *short_name, const char *filter_name)
Definition proto.c:8478
WS_DLL_PUBLIC void proto_registrar_dump_protocols(void)
Definition proto.c:11930
size_t deregistered_count
Definition proto.h:3044
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:14361
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:7534
bool proto_check_for_protocol_or_field(const proto_tree *tree, const int id)
Definition proto.c:11682
proto_item * proto_tree_add_ipv4(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, ws_in4_addr value)
Definition proto.c:5110
proto_item * proto_tree_add_uint64(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint64_t value)
Definition proto.c:6023
proto_item * proto_tree_add_string_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, int length, const char *value, const char *format,...)
Definition proto.c:5487
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:7770
const char * blurb
Definition proto.h:779
proto_tree * proto_tree_create_root(packet_info *pinfo)
Allocate and initialise a new protocol tree root node.
Definition proto.c:8177
size_t same_name_count
Definition proto.h:3045
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:13281
proto_item * proto_tree_add_string(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, int length, const char *value)
Definition proto.c:5448
proto_tree * proto_tree_get_root(proto_tree *tree)
Definition proto.c:8346
proto_item * proto_tree_add_bytes(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, int length, const uint8_t *start_ptr)
Definition proto.c:4857
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:12580
WS_DLL_PUBLIC bool proto_can_toggle_protocol(const int proto_id)
Definition proto.c:8975
WS_DLL_PUBLIC void proto_registrar_dump_ftypes(void)
Dump all registered field types and their descriptive names to standard output.
Definition proto.c:12645
proto_item * proto_tree_add_float_bits_format_value(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, float value, const unsigned encoding, const char *format,...)
Definition proto.c:14073
proto_item * proto_tree_add_eui64(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint64_t value)
Definition proto.c:6305
proto_item * proto_tree_add_eui64_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint64_t value, const char *format,...)
Definition proto.c:6342
WS_DLL_PUBLIC protocol_t * find_protocol_by_id(const int proto_id)
Definition proto.c:8722
WS_DLL_PUBLIC void proto_reenable_all(void)
Definition proto.c:9041
bool proto_registrar_is_protocol(const int n)
Definition proto.c:11630
WS_DLL_PUBLIC void proto_disable_all(void)
Definition proto.c:9011
uint8_t crumb_bit_length
Definition proto.h:845
proto_item * proto_tree_add_double_format(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, double value, const char *format,...)
Definition proto.c:5902
proto_item * proto_tree_add_int_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, int32_t value, const char *format,...)
Definition proto.c:6143
proto_item * proto_tree_add_item(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding)
Append a decoded field to a protocol tree using a registered header-field index.
Definition proto.c:4455
header_field_info * proto_registrar_get_byname(const char *field_name)
Definition proto.c:1092
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:903
#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:9388
void proto_free_deregistered_fields(void)
Definition proto.c:9339
WS_DLL_PUBLIC void proto_tree_add_bitmask_list(proto_tree *tree, tvbuff_t *tvb, const unsigned offset, const unsigned len, int *const *fields, const unsigned encoding)
Definition proto.c:13343
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_mac48_detail(const mac_hf_list_t *list_specific, const mac_hf_list_t *list_generic, int idx, tvbuff_t *tvb, proto_tree *tree, unsigned offset)
Definition proto.c:6382
proto_item * proto_tree_add_float(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, float value)
Definition proto.c:5800
proto_item * proto_tree_add_oid(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint8_t *value_ptr)
Definition proto.c:5345
proto_item * proto_tree_add_int64(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, int64_t value)
Definition proto.c:6210
int tree_type
Definition proto.h:823
WS_DLL_PUBLIC int proto_get_id(const protocol_t *protocol)
Definition proto.c:8737
header_field_info hfinfo
Definition proto.h:806
void proto_register_alias(const int proto_id, const char *alias_name)
Definition proto.c:8642
proto_item * proto_tree_add_eui64_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const uint64_t value, const char *format,...)
Definition proto.c:6324
proto_item * proto_tree_add_item_new_ret_length(proto_tree *tree, header_field_info *hfinfo, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, int *lenretval)
Definition proto.c:4469
proto_item * proto_tree_add_bytes_with_length(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, int tvbuff_length, const uint8_t *start_ptr, int ptr_length)
Definition proto.c:4885
proto_item * proto_tree_add_ipxnet_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, uint32_t value, const char *format,...)
Definition proto.c:5064
proto_item * proto_tree_add_ipv6_format_value(proto_tree *tree, int hfindex, tvbuff_t *tvb, unsigned start, unsigned length, const ws_in6_addr *value_ptr, const char *format,...)
Definition proto.c:5196
void proto_free_field_strings(ftenum_t field_type, unsigned int field_display, const void *field_strings)
Definition proto.c:9193
proto_item * proto_tree_add_boolean_bits_format_value(proto_tree *tree, const int hfindex, tvbuff_t *tvb, const unsigned bit_offset, const int no_of_bits, uint64_t value, const unsigned encoding, const char *format,...)
Definition proto.c:14161
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:13446
unsigned appendix_start
Definition proto.h:821
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:13208
void proto_item_append_text(proto_item *pi, const char *format,...)
Definition proto.c:7949
header_field_info * same_name_next
Definition proto.h:786
proto_item * proto_tree_add_item_ret_ipv6(proto_tree *tree, int hfindex, tvbuff_t *tvb, const unsigned start, int length, const unsigned encoding, ws_in6_addr *addr)
Parse an ipv6 address from the buffer and add it to the tree, writing the value to the pointer specif...
Definition proto.c:4064
@ 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:3907
@ PROTO_CHECKSUM_E_ILLEGAL
Definition proto.h:3910
@ PROTO_CHECKSUM_E_BAD
Definition proto.h:3906
@ PROTO_CHECKSUM_E_NOT_PRESENT
Definition proto.h:3909
@ PROTO_CHECKSUM_E_UNVERIFIED
Definition proto.h:3908
@ 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
struct _wmem_list_t wmem_list_t
Opaque type representing a scoped, doubly-linked list in the wmem system.
Definition wmem_list.h:42
struct _wmem_allocator_t wmem_allocator_t
Definition wmem_core.h:44
struct _e_guid_t e_guid_t
Represents a GUID/UUID value; may be larger than GUID_LEN so must not be used to directly overlay pac...
struct e_in6_addr ws_in6_addr
Represents a 128-bit IPv6 address.
uint32_t ws_in4_addr
Represents a 32-bit IPv4 address in network byte order.
Definition inet_addr.h:22
Definition proto.h:768
Definition proto.h:810
Definition proto.h:2825
Represents the metadata and indexing information for a single captured frame.
Definition packet_info.h:43
Definition proto.h:909
Definition proto.c:389
Definition packet-bt-dht.c:97
This structure describes one segment of a split-bits item.
Definition proto.h:843
Holds all state for the dissection of a single byte array, including session, buffer,...
Definition epan_dissect.h:28
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:3042
Definition proto.h:897
struct _value_string value_string
Mapping between a 32-bit integer value and its string representation.