Wireshark 4.7.0
The Wireshark network protocol analyzer
Loading...
Searching...
No Matches
pcapng_module.h
Go to the documentation of this file.
1
9#ifndef __PCAP_MODULE_H__
10#define __PCAP_MODULE_H__
11
12#include <wiretap/wtap_module.h>
13
14#include "ws_symbol_export.h"
15
16#ifdef __cplusplus
17extern "C" {
18#endif /* __cplusplus */
19
20/*
21 * These are the officially registered block types, from the pcapng
22 * specification.
23 *
24 * XXX - Dear Sysdig People: please add your blocks to the spec!
25 */
26#define BLOCK_TYPE_SHB 0x0A0D0D0A /* Section Header Block */
27#define BLOCK_TYPE_IDB 0x00000001 /* Interface Description Block */
28#define BLOCK_TYPE_PB 0x00000002 /* Packet Block (obsolete) */
29#define BLOCK_TYPE_SPB 0x00000003 /* Simple Packet Block */
30#define BLOCK_TYPE_NRB 0x00000004 /* Name Resolution Block */
31#define BLOCK_TYPE_ISB 0x00000005 /* Interface Statistics Block */
32#define BLOCK_TYPE_EPB 0x00000006 /* Enhanced Packet Block */
33#define BLOCK_TYPE_IRIG_TS 0x00000007 /* IRIG Timestamp Block */
34#define BLOCK_TYPE_ARINC_429 0x00000008 /* ARINC 429 in AFDX Encapsulation Information Block */
35#define BLOCK_TYPE_SYSTEMD_JOURNAL_EXPORT 0x00000009 /* systemd journal entry */
36#define BLOCK_TYPE_DSB 0x0000000A /* Decryption Secrets Block */
37#define BLOCK_TYPE_HP_MIB 0x00000101 /* Hone Project Machine Info Block */
38#define BLOCK_TYPE_HP_CEB 0x00000102 /* Hone Project Connection Event Block */
39#define BLOCK_TYPE_SYSDIG_MI 0x00000201 /* Sysdig Machine Info Block */
40#define BLOCK_TYPE_SYSDIG_PL_V1 0x00000202 /* Sysdig Process List Block */
41#define BLOCK_TYPE_SYSDIG_FDL_V1 0x00000203 /* Sysdig File Descriptor List Block */
42#define BLOCK_TYPE_SYSDIG_EVENT 0x00000204 /* Sysdig Event Block */
43#define BLOCK_TYPE_SYSDIG_IL_V1 0x00000205 /* Sysdig Interface List Block */
44#define BLOCK_TYPE_SYSDIG_UL_V1 0x00000206 /* Sysdig User List Block */
45#define BLOCK_TYPE_SYSDIG_PL_V2 0x00000207 /* Sysdig Process List Block version 2 */
46#define BLOCK_TYPE_SYSDIG_EVF 0x00000208 /* Sysdig Event Block with flags */
47#define BLOCK_TYPE_SYSDIG_PL_V3 0x00000209 /* Sysdig Process List Block version 3 */
48#define BLOCK_TYPE_SYSDIG_PL_V4 0x00000210 /* Sysdig Process List Block version 4 */
49#define BLOCK_TYPE_SYSDIG_PL_V5 0x00000211 /* Sysdig Process List Block version 5 */
50#define BLOCK_TYPE_SYSDIG_PL_V6 0x00000212 /* Sysdig Process List Block version 6 */
51#define BLOCK_TYPE_SYSDIG_PL_V7 0x00000213 /* Sysdig Process List Block version 7 */
52#define BLOCK_TYPE_SYSDIG_PL_V8 0x00000214 /* Sysdig Process List Block version 8 */
53#define BLOCK_TYPE_SYSDIG_PL_V9 0x00000215 /* Sysdig Process List Block version 9 */
54#define BLOCK_TYPE_SYSDIG_EVENT_V2 0x00000216 /* Sysdig Event Block version 2 */
55#define BLOCK_TYPE_SYSDIG_EVF_V2 0x00000217 /* Sysdig Event Block with flags version 2 */
56#define BLOCK_TYPE_SYSDIG_FDL_V2 0x00000218 /* Sysdig File Descriptor List Block */
57#define BLOCK_TYPE_SYSDIG_IL_V2 0x00000219 /* Sysdig Interface List Block version 2 */
58#define BLOCK_TYPE_SYSDIG_UL_V2 0x00000220 /* Sysdig User List Block version 2 */
59#define BLOCK_TYPE_SYSDIG_EVENT_V2_LARGE 0x00000221 /* Sysdig Event Block version 2 with large payload */
60#define BLOCK_TYPE_SYSDIG_EVF_V2_LARGE 0x00000222 /* Sysdig Event Block with flags version 2 with large payload */
61#define BLOCK_TYPE_CB_COPY 0x00000BAD /* Custom Block which can be copied */
62#define BLOCK_TYPE_CB_NO_COPY 0x40000BAD /* Custom Block which should not be copied */
63#define BLOCK_TYPE_LEGACY_DPIB 0x80000001 /* Historically, Apple used this code for Darwin Process Info Block. */
64
65/* TODO: the following are not yet well defined in the draft spec,
66 * and do not yet have block type values assigned to them:
67 * Alternative Packet Blocks
68 * Compression Block
69 * Encryption Block
70 * Fixed Length Block
71 * Directory Block
72 * Traffic Statistics and Monitoring Blocks
73 * Event/Security Block
74 */
75
76/* Block data to be passed between functions during reading */
77typedef struct wtapng_block_s {
78 uint32_t type; /* block_type as defined by pcapng */
79 bool internal; /* true if this block type shouldn't be returned from pcapng_read() */
80 wtap_block_t block;
81 wtap_rec *rec;
83
84/* Section data in private struct */
85/*
86 * XXX - there needs to be a more general way to implement the Netflix
87 * BBLog blocks and options.
88 */
89typedef struct section_info_t {
91 uint16_t version_major;
92 uint16_t version_minor;
93 GArray *interfaces;
94 int64_t shb_off;
95 GHashTable *custom_block_data;
96 GHashTable *local_block_data;
98
99/*
100 * Reader and writer routines for pcapng block types.
101 */
102typedef bool (*block_reader)(wtap* wth, FILE_T fh, uint32_t block_type,
103 uint32_t block_content_length,
104 section_info_t* section_info,
105 wtapng_block_t *wblock,
106 int *err, char **err_info);
107typedef bool (*block_writer)(wtap_dumper *wdh, const wtap_rec *rec,
108 int *err, char **err_info);
109typedef bool (*block_processor)(wtap* wth, section_info_t* section_info _U_,
110 wtapng_block_t* wblock);
111
112
114 unsigned type; /* block_type as defined by pcapng */
115 block_reader reader;
116 block_processor processor;
117 block_writer writer;
118 bool internal; /* true if this block type shouldn't be returned from pcapng_read() */
119 GHashTable *option_handlers; /* Hash table of option handlers */
121
127WS_DLL_PUBLIC
129
130/*
131 * Handler routines for pcapng option type.
132 */
133typedef bool (*option_parser)(wtap_block_t block, bool byte_swapped,
134 unsigned option_length,
135 const uint8_t *option_content,
136 int *err, char **err_info);
137typedef uint32_t (*option_sizer)(unsigned option_id, wtap_optval_t *optval);
138typedef bool (*option_writer)(wtap_dumper *wdh, unsigned option_id,
139 wtap_optval_t *optval, int *err);
140
145WS_DLL_PUBLIC
146GHashTable *pcapng_create_option_handler_table(void);
147
158WS_DLL_PUBLIC
159void register_pcapng_option_handler(unsigned block_type, unsigned option_code,
160 option_parser parser,
161 option_sizer sizer,
162 option_writer writer);
163
164/*
165 * Byte order of the options within a block.
166 *
167 * This is usually the byte order of the section, but, for options
168 * within a Custom Block, it needs to be a specified byte order,
169 * or a byte order indicated by data in the Custom Data (stored in
170 * a fashion that doesn't require knowing the byte order of the
171 * Custom Data, as it's also the byte order of the Custom Data
172 * itself), so that programs ignorant of the format of a given
173 * type of Custom Block can still read a block from one file and
174 * write it to another, even if the host doing the writing has
175 * a byte order different from the host that previously wrote
176 * the file.
177 */
178typedef enum {
179 OPT_SECTION_BYTE_ORDER, /* byte order of this section */
180 OPT_BIG_ENDIAN, /* as it says */
181 OPT_LITTLE_ENDIAN /* ditto */
182} pcapng_opt_byte_order_e;
183
197WS_DLL_PUBLIC
199 section_info_t *section_info,
200 unsigned opt_cont_buf_len,
201 bool (*process_option)(wtapng_block_t *,
203 uint16_t, uint16_t,
204 const uint8_t *,
205 int *, char **),
206 pcapng_opt_byte_order_e byte_order,
207 int *err, char **err_info);
208
218WS_DLL_PUBLIC
220 uint16_t option_code, uint16_t option_length,
221 const uint8_t *option_content);
222
233WS_DLL_PUBLIC
235 section_info_t *section_info,
236 pcapng_opt_byte_order_e byte_order,
237 uint16_t option_code, uint16_t option_length,
238 const uint8_t *option_content);
239
250WS_DLL_PUBLIC
252 section_info_t *section_info,
253 pcapng_opt_byte_order_e byte_order,
254 uint16_t option_code, uint16_t option_length,
255 const uint8_t *option_content);
256
267WS_DLL_PUBLIC
269 section_info_t *section_info,
270 pcapng_opt_byte_order_e byte_order,
271 uint16_t option_code, uint16_t option_length,
272 const uint8_t *option_content);
273
284WS_DLL_PUBLIC
286 section_info_t *section_info,
287 pcapng_opt_byte_order_e byte_order,
288 uint16_t option_code, uint16_t option_length,
289 const uint8_t *option_content);
290
299WS_DLL_PUBLIC
300void pcapng_process_string_option(wtapng_block_t *wblock, uint16_t option_code,
301 uint16_t option_length, const uint8_t *option_content);
302
311WS_DLL_PUBLIC
312void pcapng_process_bytes_option(wtapng_block_t *wblock, uint16_t option_code,
313 uint16_t option_length, const uint8_t *option_content);
314
315typedef uint32_t (*compute_option_size_func)(wtap_block_t, unsigned, wtap_opttype_e, wtap_optval_t*);
316
318{
319 uint32_t size;
320 compute_option_size_func compute_option_size;
322
330WS_DLL_PUBLIC
331uint32_t pcapng_compute_options_size(wtap_block_t block, compute_option_size_func compute_option_size);
332
333typedef bool (*write_option_func)(wtap_dumper *wdh, wtap_block_t block,
334 unsigned option_id,
335 wtap_opttype_e option_type,
336 wtap_optval_t *optval,
337 int *err, char **err_info);
338
350WS_DLL_PUBLIC
351bool pcapng_write_options(wtap_dumper *wdh, pcapng_opt_byte_order_e byte_order,
352 wtap_block_t block, write_option_func write_option,
353 int *err, char **err_info);
354
355/*
356 * Handler routines for pcapng custom blocks with an enterprise number.
357 */
358typedef bool (*custom_option_parser)(FILE_T fh, section_info_t* section_info,
359 wtapng_block_t* wblock,
360 int* err, char** err_info);
361typedef bool (*custom_option_processor)(wtapng_block_t* wblock,
362 section_info_t* section_info, uint16_t option_code,
363 const uint8_t* value, uint16_t length);
364
366{
367 custom_option_parser parser;
368 custom_option_processor processor;
369 block_writer writer;
371
372/*
373 * Register a handler for a pcapng custom block with an enterprise number.
374 */
381WS_DLL_PUBLIC
383
384/*
385 * Helper routines for modules.
386 */
387
388/*
389 * Write block header.
390 */
400WS_DLL_PUBLIC
401bool pcapng_write_block_header(wtap_dumper *wdh, uint32_t block_type,
402 uint32_t block_content_length, int *err);
403
404/*
405 * Write padding after a chunk of data.
406 */
415static inline bool
416pcapng_write_padding(wtap_dumper *wdh, size_t pad, int *err)
417{
418 if (pad != 0) {
419 const uint32_t zero_pad = 0;
420 if (!wtap_dump_file_write(wdh, &zero_pad, pad, err))
421 return false;
422 }
423
424 return true;
425}
426
427/*
428 * Write block footer.
429 */
438WS_DLL_PUBLIC
439bool pcapng_write_block_footer(wtap_dumper *wdh, uint32_t block_content_length,
440 int *err);
441
442/*
443 * Structure holding allocation-and-initialization and free functions
444 * for section_info_t-associated custom or local block information.
445 */
446typedef struct {
447 void *(*provision)(void);
448 GDestroyNotify free;
450
451/*
452 * Find custom block information from a section_info_t; add a
453 * newly-created one and return it if none is found.
454 */
463WS_DLL_PUBLIC
465 uint32_t pen,
466 const section_info_funcs_t *funcs);
467
477WS_DLL_PUBLIC
479 uint32_t block_type,
480 const section_info_funcs_t *funcs);
481
482#ifdef __cplusplus
483}
484#endif /* __cplusplus */
485
486#endif /* __PCAP_MODULE_H__ */
WS_DLL_PUBLIC void pcapng_process_uint64_option(wtapng_block_t *wblock, section_info_t *section_info, pcapng_opt_byte_order_e byte_order, uint16_t option_code, uint16_t option_length, const uint8_t *option_content)
Process a 64-bit unsigned integer option in a PCAP-NG block.
Definition pcapng.c:656
WS_DLL_PUBLIC void * pcapng_get_lb_section_info_data(section_info_t *section_info, uint32_t block_type, const section_info_funcs_t *funcs)
Find local block information from a section_info_t; add a newly-created one and return it if none is ...
Definition pcapng.c:482
WS_DLL_PUBLIC bool pcapng_write_block_footer(wtap_dumper *wdh, uint32_t block_content_length, int *err)
Writes a block footer for a PCAPNG file.
Definition pcapng.c:6283
WS_DLL_PUBLIC void pcapng_process_timestamp_option(wtapng_block_t *wblock, section_info_t *section_info, pcapng_opt_byte_order_e byte_order, uint16_t option_code, uint16_t option_length, const uint8_t *option_content)
Process a timestamp option in a PCAPng block.
Definition pcapng.c:597
WS_DLL_PUBLIC uint32_t pcapng_compute_options_size(wtap_block_t block, compute_option_size_func compute_option_size)
Computes the total size of all options in a PCAPNG block.
Definition pcapng.c:4144
WS_DLL_PUBLIC void pcapng_process_uint32_option(wtapng_block_t *wblock, section_info_t *section_info, pcapng_opt_byte_order_e byte_order, uint16_t option_code, uint16_t option_length, const uint8_t *option_content)
Process a 32-bit unsigned integer option in a PCAPNG block.
Definition pcapng.c:540
WS_DLL_PUBLIC void * pcapng_get_cb_section_info_data(section_info_t *section_info, uint32_t pen, const section_info_funcs_t *funcs)
Find local block information from a section_info_t; add a newly-created one and return it if none is ...
Definition pcapng.c:429
WS_DLL_PUBLIC void pcapng_process_uint8_option(wtapng_block_t *wblock, uint16_t option_code, uint16_t option_length, const uint8_t *option_content)
Helper routines to process options with types used in more than one block type.
Definition pcapng.c:525
WS_DLL_PUBLIC void pcapng_process_int64_option(wtapng_block_t *wblock, section_info_t *section_info, pcapng_opt_byte_order_e byte_order, uint16_t option_code, uint16_t option_length, const uint8_t *option_content)
Process a 64-bit integer option in a PCAPNG block.
Definition pcapng.c:708
WS_DLL_PUBLIC void register_pcapng_option_handler(unsigned block_type, unsigned option_code, option_parser parser, option_sizer sizer, option_writer writer)
Register a handler for a pcapng option code for a particular block type.
Definition pcapng.c:365
WS_DLL_PUBLIC void register_pcapng_block_type_information(pcapng_block_type_information_t *handler)
Register a handler for a pcapng block type.
Definition pcapng.c:238
WS_DLL_PUBLIC void pcapng_process_string_option(wtapng_block_t *wblock, uint16_t option_code, uint16_t option_length, const uint8_t *option_content)
Process a string option in a PCAPNG block.
Definition pcapng.c:760
WS_DLL_PUBLIC void pcapng_process_bytes_option(wtapng_block_t *wblock, uint16_t option_code, uint16_t option_length, const uint8_t *option_content)
Processes a bytes option in a PCAPng block.
Definition pcapng.c:781
WS_DLL_PUBLIC bool pcapng_write_block_header(wtap_dumper *wdh, uint32_t block_type, uint32_t block_content_length, int *err)
Write a pcapng block header.
Definition pcapng.c:6263
WS_DLL_PUBLIC GHashTable * pcapng_create_option_handler_table(void)
Create a table of handlers for pcapng option codes.
Definition pcapng.c:337
WS_DLL_PUBLIC bool pcapng_process_options(FILE_T fh, wtapng_block_t *wblock, section_info_t *section_info, unsigned opt_cont_buf_len, bool(*process_option)(wtapng_block_t *, section_info_t *, uint16_t, uint16_t, const uint8_t *, int *, char **), pcapng_opt_byte_order_e byte_order, int *err, char **err_info)
Process the options section of a block.
Definition pcapng.c:933
WS_DLL_PUBLIC void register_pcapng_custom_block_enterprise_handler(unsigned enterprise_number, pcapng_custom_block_enterprise_handler_t const *handler)
Register a handler for a pcapng custom block with an enterprise number.
Definition pcapng.c:2948
WS_DLL_PUBLIC bool pcapng_write_options(wtap_dumper *wdh, pcapng_opt_byte_order_e byte_order, wtap_block_t block, write_option_func write_option, int *err, char **err_info)
Writes options to a pcapng file.
Definition pcapng.c:4810
Definition pcapng_module.h:318
Definition pcapng_module.h:113
Definition pcapng_module.h:366
Definition pcapng_module.h:446
Definition pcapng_module.h:89
uint16_t version_major
Definition pcapng_module.h:91
int64_t shb_off
Definition pcapng_module.h:94
uint16_t version_minor
Definition pcapng_module.h:92
GHashTable * local_block_data
Definition pcapng_module.h:96
GHashTable * custom_block_data
Definition pcapng_module.h:95
GArray * interfaces
Definition pcapng_module.h:93
bool byte_swapped
Definition pcapng_module.h:90
Definition wtap_opttypes.h:272
Wiretap dumper handle and associated state.
Definition wtap_module.h:163
Definition file_wrappers.c:96
Definition wtap.h:1512
Definition wtap_module.h:58
Definition pcapng_module.h:77
Definition wtap_opttypes.h:525