Wireshark 4.7.0
The Wireshark network protocol analyzer
Loading...
Searching...
No Matches
addr_resolv.h
Go to the documentation of this file.
1
12/* The buffers returned by these functions are all allocated with a
13 * packet lifetime and does not have to be freed.
14 * However, take into account that when the packet dissection
15 * completes, these buffers will be automatically reclaimed/freed.
16 * If you need the buffer to remain for a longer scope than packet lifetime
17 * you must copy the content to an wmem_file_scope() buffer.
18 */
19
20#ifndef __RESOLV_H__
21#define __RESOLV_H__
22
23#include <epan/address.h>
24#include <epan/tvbuff.h>
25#include <wsutil/inet_cidr.h>
26#include <epan/to_str.h>
27#include <wiretap/wtap.h>
28#include "ws_symbol_export.h"
29
30#ifdef __cplusplus
31extern "C" {
32#endif /* __cplusplus */
33
34#ifndef MAXNAMELEN
35#define MAXNAMELEN 64 /* max name length (most names: DNS labels, services, eth) */
36#endif
37
38#ifndef MAXVLANNAMELEN
39#define MAXVLANNAMELEN 128 /* max vlan name length */
40#endif
41
42#ifndef MAXDNSNAMELEN
43#define MAXDNSNAMELEN 256 /* max total length of a domain name in the DNS */
44#endif
45
46#define BASE_ENTERPRISES BASE_CUSTOM
47#define STRINGS_ENTERPRISES CF_FUNC(enterprises_base_custom)
48
64
65#define ADDR_RESOLV_MACADDR(at) \
66 (((at)->type == AT_ETHER) || ((at)->type == AT_EUI64))
67
68#define ADDR_RESOLV_NETADDR(at) \
69 (((at)->type == AT_IPv4) || ((at)->type == AT_IPv6) || ((at)->type == AT_IPX))
70
71struct hashether;
72typedef struct hashether hashether_t;
73
74struct hasheui64;
75typedef struct hasheui64 hasheui64_t;
76
77struct hashwka;
78typedef struct hashwka hashwka_t;
79
80struct hashmanuf;
81typedef struct hashmanuf hashmanuf_t;
82
83typedef struct _serv_port_key {
84 uint16_t port;
85 port_type type;
87
88/* Used for manually edited DNS resolved names */
89typedef struct _resolved_name {
90 char name[MAXDNSNAMELEN];
92
93/*
94 * Flags for various resolved name hash table entries.
95 */
96#define TRIED_RESOLVE_ADDRESS (1U<<0) /* name resolution is being/has been tried */
97#define NAME_RESOLVED (1U<<1) /* the name field contains a host name, not a printable address */
98#define RESOLVED_ADDRESS_USED (1U<<2) /* a get_hostname* call returned the host name */
99#define STATIC_HOSTNAME (1U<<3) /* do not update entries from hosts file with DNS responses */
100#define NAME_RESOLVED_PREFIX (1U<<4) /* name was generated from a prefix (e.g., OUI) instead of the entire address */
101
102#define TRIED_OR_RESOLVED_MASK (TRIED_RESOLVE_ADDRESS | NAME_RESOLVED)
103#define USED_AND_RESOLVED_MASK (NAME_RESOLVED | RESOLVED_ADDRESS_USED)
104
105/*
106 * Flag controlling what names to resolve.
107 */
108WS_DLL_PUBLIC e_addr_resolve gbl_resolv_flags;
109
110/* global variables */
111
112extern char *g_ethers_path;
113extern char *g_ipxnets_path;
114extern char *g_pethers_path;
115extern char *g_pipxnets_path;
116
117/* Functions in addr_resolv.c */
118
129WS_DLL_PUBLIC hashipv4_t * new_ipv4(const unsigned addr);
130
143WS_DLL_PUBLIC bool fill_dummy_ip4(const unsigned addr, hashipv4_t* volatile tp);
144
156WS_DLL_PUBLIC char *udp_port_to_display(wmem_allocator_t *allocator, unsigned port);
157
158
170WS_DLL_PUBLIC char *tcp_port_to_display(wmem_allocator_t *allocator, unsigned port);
171
183WS_DLL_PUBLIC char *dccp_port_to_display(wmem_allocator_t *allocator, unsigned port);
184
196WS_DLL_PUBLIC char *sctp_port_to_display(wmem_allocator_t *allocator, unsigned port);
197
210WS_DLL_PUBLIC const char *serv_name_lookup(port_type proto, unsigned port);
211
226WS_DLL_PUBLIC const char *enterprises_lookup(uint32_t value, const char *unknown_str);
227
238WS_DLL_PUBLIC const char *try_enterprises_lookup(uint32_t value);
239
250WS_DLL_PUBLIC void enterprises_base_custom(char *buf, uint32_t value);
251
263WS_DLL_PUBLIC const char *try_serv_name_lookup(port_type proto, unsigned port);
264
278WS_DLL_PUBLIC char *port_with_resolution_to_str(wmem_allocator_t *scope,
279 port_type proto, unsigned port);
280
299WS_DLL_PUBLIC int port_with_resolution_to_str_buf(char *buf, unsigned long buf_size,
300 port_type proto, unsigned port);
301
302/*
303 * Asynchronous host name lookup initialization, processing, and cleanup
304 */
305
306/* Setup name resolution preferences */
307struct pref_module;
308
319extern void addr_resolve_pref_init(struct pref_module *nameres);
320
324extern void addr_resolve_pref_apply(void);
325
334WS_DLL_PUBLIC void disable_name_resolution(void);
335
347WS_DLL_PUBLIC bool host_name_lookup_process(void);
348
365WS_DLL_PUBLIC const char *get_hostname(const unsigned addr);
366
382WS_DLL_PUBLIC char *get_hostname_wmem(wmem_allocator_t *allocator, const unsigned addr);
383
398WS_DLL_PUBLIC const char *get_hostname6(const ws_in6_addr *ad);
399
410WS_DLL_PUBLIC char *get_hostname6_wmem(wmem_allocator_t *allocator, const ws_in6_addr *ad);
411
427WS_DLL_PUBLIC const char *get_ether_name(const uint8_t *addr);
428
439WS_DLL_PUBLIC const char *get_hostname_ss7pc(const uint8_t ni, const uint32_t pc);
440
450WS_DLL_PUBLIC void fill_unresolved_ss7pc(const char * pc_addr, const uint8_t ni, const uint32_t pc);
451
463WS_DLL_PUBLIC const char *tvb_get_ether_name(tvbuff_t *tvb, unsigned offset);
464
477WS_DLL_PUBLIC const char *get_ether_name_if_known(const uint8_t *addr);
478
495extern const char *get_manuf_name(const uint8_t *addr, size_t size);
496
513WS_DLL_PUBLIC const char *get_manuf_name_if_known(const uint8_t *addr, size_t size);
514
526WS_DLL_PUBLIC const char *uint_get_manuf_name_if_known(const uint32_t oid);
527
543WS_DLL_PUBLIC const char *tvb_get_manuf_name(tvbuff_t *tvb, unsigned offset);
544
558WS_DLL_PUBLIC const char *tvb_get_manuf_name_if_known(tvbuff_t *tvb, unsigned offset);
559
572extern const char *get_eui64_name(const uint8_t *addr);
573
589WS_DLL_PUBLIC char *eui64_to_display(wmem_allocator_t *allocator, const uint64_t addr);
590
603WS_DLL_PUBLIC char *get_ipxnet_name(wmem_allocator_t *allocator, const uint32_t addr);
604
617WS_DLL_PUBLIC char *get_vlan_name(wmem_allocator_t *allocator, const uint16_t id);
618
625WS_DLL_PUBLIC unsigned get_hash_ether_status(hashether_t* ether);
626
633WS_DLL_PUBLIC bool get_hash_ether_used(hashether_t* ether);
634
641WS_DLL_PUBLIC char* get_hash_ether_hexaddr(hashether_t* ether);
642
649WS_DLL_PUBLIC char* get_hash_ether_resolved_name(hashether_t* ether);
650
657WS_DLL_PUBLIC bool get_hash_manuf_used(hashmanuf_t* manuf);
658
665WS_DLL_PUBLIC char* get_hash_manuf_resolved_name(hashmanuf_t* manuf);
666
673WS_DLL_PUBLIC bool get_hash_wka_used(hashwka_t* wka);
674
681WS_DLL_PUBLIC char* get_hash_wka_resolved_name(hashwka_t* wka);
682
692WS_DLL_PUBLIC void add_ipv4_name(const unsigned addr, const char *name, const bool static_entry);
693
703WS_DLL_PUBLIC void add_ipv6_name(const ws_in6_addr *addr, const char *name, const bool static_entry);
704
715WS_DLL_PUBLIC bool add_hosts_file(const char *hosts_file);
716
727WS_DLL_PUBLIC bool add_ip_name_from_string(const char *addr, const char *name);
728
738WS_DLL_PUBLIC resolved_name_t* get_edited_resolved_name(const char* addr);
739
748WS_DLL_PUBLIC addrinfo_lists_t *get_addrinfo_list(void);
749
759WS_DLL_PUBLIC void add_ether_byip(const unsigned ip, const uint8_t *eth);
760
775WS_DLL_PUBLIC
776bool get_host_ipaddr(const char *host, uint32_t *addrp);
777
792WS_DLL_PUBLIC
793bool get_host_ipaddr6(const char *host, ws_in6_addr *addrp);
794
802WS_DLL_PUBLIC
804
812WS_DLL_PUBLIC
814
822WS_DLL_PUBLIC
824
832WS_DLL_PUBLIC
834
842WS_DLL_PUBLIC
844
852WS_DLL_PUBLIC
854
862WS_DLL_PUBLIC
864
872WS_DLL_PUBLIC
874
875
876/*
877 * XXX - if we ever have per-session host name etc. information, we
878 * should probably have the "resolve synchronously or asynchronously"
879 * flag be per-session, set with an epan API.
880 */
889WS_DLL_PUBLIC
890void set_resolution_synchrony(bool synchronous);
891
892/*
893 * private functions (should only be called by epan directly)
894 */
895
902WS_DLL_LOCAL
904
911WS_DLL_LOCAL
912void host_name_lookup_reset(const char* app_env_var_prefix);
913
920WS_DLL_LOCAL
921void addr_resolv_init(const char* app_env_var_prefix);
922
929WS_DLL_LOCAL
930void addr_resolv_cleanup(void);
931
941WS_DLL_PUBLIC
942bool str_to_ip(const char *str, void *dst);
943
953WS_DLL_PUBLIC
954bool str_to_ip6(const char *str, void *dst);
955
966WS_DLL_LOCAL
967bool str_to_eth(const char *str, uint8_t (*eth_bytes)[6]);
968
978WS_DLL_LOCAL
979unsigned ipv6_oat_hash(const void *key);
980
991WS_DLL_LOCAL
992gboolean ipv6_equal(const void *v1, const void *v2);
993
1010WS_DLL_PUBLIC const char *tac_name_lookup(const unsigned addr);
1011
1012#ifdef __cplusplus
1013}
1014#endif /* __cplusplus */
1015
1016#endif /* __RESOLV_H__ */
void addr_resolve_pref_apply(void)
Apply name resolution preferences.
Definition addr_resolv.c:3770
WS_DLL_PUBLIC bool host_name_lookup_process(void)
Process outstanding asynchronous host name lookups via c-ares.
Definition addr_resolv.c:3791
WS_DLL_PUBLIC wmem_map_t * get_ipv4_hash_table(void)
Retrieves the IPv4 address hashtable.
Definition addr_resolv.c:4571
WS_DLL_PUBLIC void fill_unresolved_ss7pc(const char *pc_addr, const uint8_t ni, const uint32_t pc)
Initializes unresolved SS7 Point Code entries in the hashtable.
Definition addr_resolv.c:3478
WS_DLL_PUBLIC char * get_vlan_name(wmem_allocator_t *allocator, const uint16_t id)
Resolves a VLAN ID to a name.
Definition addr_resolv.c:4278
WS_DLL_PUBLIC const char * get_hostname(const unsigned addr)
Resolve an IPv4 address to its host name.
Definition addr_resolv.c:3838
WS_DLL_PUBLIC const char * get_ether_name_if_known(const uint8_t *addr)
Resolves an Ethernet address only if an exact match is known.
Definition addr_resolv.c:4218
WS_DLL_PUBLIC char * eui64_to_display(wmem_allocator_t *allocator, const uint64_t addr)
Converts a uint64_t EUI-64 address to a display string.
Definition addr_resolv.c:4380
WS_DLL_PUBLIC char * tcp_port_to_display(wmem_allocator_t *allocator, unsigned port)
Resolve a TCP port number to its display name.
Definition addr_resolv.c:4145
WS_DLL_PUBLIC void enterprises_base_custom(char *buf, uint32_t value)
Format a private enterprise code as "name (decimal)" into a buffer.
Definition addr_resolv.c:1166
WS_DLL_PUBLIC bool get_hash_wka_used(hashwka_t *wka)
Checks if a WKA hash entry was used.
Definition addr_resolv.c:2017
WS_DLL_PUBLIC const char * get_manuf_name_if_known(const uint8_t *addr, size_t size)
Resolves an OUI to a full vendor name if known.
Definition addr_resolv.c:4313
WS_DLL_PUBLIC char * get_hash_wka_resolved_name(hashwka_t *wka)
Gets the resolved name for a WKA hash entry.
Definition addr_resolv.c:2022
WS_DLL_PUBLIC wmem_map_t * get_wka_hashtable(void)
Retrieves the well-known address (WKA) hashtable.
Definition addr_resolv.c:4541
WS_DLL_PUBLIC bool get_hash_ether_used(hashether_t *ether)
Checks if an Ethernet hash entry was used.
Definition addr_resolv.c:2002
WS_DLL_PUBLIC const char * tvb_get_ether_name(tvbuff_t *tvb, unsigned offset)
Resolves an Ethernet address from a tvbuff.
Definition addr_resolv.c:4209
WS_DLL_PUBLIC const char * try_enterprises_lookup(uint32_t value)
Attempt to resolve a private enterprise code to its registered name.
Definition addr_resolv.c:1142
WS_DLL_PUBLIC wmem_map_t * get_manuf_hashtable(void)
Retrieves the manufacturer hashtable.
Definition addr_resolv.c:4535
const char * get_manuf_name(const uint8_t *addr, size_t size)
Resolves a 3-octet OUI to a short vendor name.
Definition addr_resolv.c:4290
WS_DLL_PUBLIC const char * serv_name_lookup(port_type proto, unsigned port)
Resolve a port number to its well-known service name.
Definition addr_resolv.c:1009
WS_DLL_PUBLIC wmem_map_t * get_ipv6_hash_table(void)
Retrieves the IPv6 address hashtable.
Definition addr_resolv.c:4577
WS_DLL_PUBLIC bool get_host_ipaddr6(const char *host, ws_in6_addr *addrp)
Resolves a hostname or IPv6 string to a numeric IPv6 address.
Definition addr_resolv.c:4476
WS_DLL_PUBLIC void add_ether_byip(const unsigned ip, const uint8_t *eth)
Associates an Ethernet (MAC) address / name to an IPv4 address.
Definition addr_resolv.c:4242
const char * get_eui64_name(const uint8_t *addr)
Resolves an EUI-64 address to a logical name or vendor string.
Definition addr_resolv.c:4368
WS_DLL_LOCAL unsigned ipv6_oat_hash(const void *key)
Computes a hash value for an IPv6 address using OAT hashing.
Definition addr_resolv.c:291
WS_DLL_PUBLIC hashipv4_t * new_ipv4(const unsigned addr)
Construct a new IPv4 object from a 32-bit address.
Definition addr_resolv.c:1347
WS_DLL_PUBLIC char * udp_port_to_display(wmem_allocator_t *allocator, unsigned port)
Resolve a UDP port number to its display name.
Definition addr_resolv.c:4121
WS_DLL_PUBLIC wmem_map_t * get_serv_port_hashtable(void)
Retrieves the service port hashtable.
Definition addr_resolv.c:4553
WS_DLL_LOCAL void addr_resolv_cleanup(void)
Cleans up the address resolution subsystem.
Definition addr_resolv.c:4598
WS_DLL_PUBLIC void add_ipv4_name(const unsigned addr, const char *name, const bool static_entry)
Adds a static or dynamic IPv4 name mapping.
Definition addr_resolv.c:3908
WS_DLL_PUBLIC unsigned get_hash_ether_status(hashether_t *ether)
Gets the status code for a resolved Ethernet entry.
Definition addr_resolv.c:1997
WS_DLL_LOCAL bool str_to_eth(const char *str, uint8_t(*eth_bytes)[6])
Parses a string as an Ethernet (MAC) address.
Definition addr_resolv.c:4630
WS_DLL_PUBLIC bool get_hash_manuf_used(hashmanuf_t *manuf)
Checks if a manufacturer hash entry was used.
Definition addr_resolv.c:4357
WS_DLL_PUBLIC const char * try_serv_name_lookup(port_type proto, unsigned port)
Attempt to resolve a port number to its well-known service name.
Definition addr_resolv.c:1003
WS_DLL_PUBLIC bool str_to_ip6(const char *str, void *dst)
Parses a string as an IPv6 address.
Definition addr_resolv.c:4619
WS_DLL_PUBLIC wmem_map_t * get_ipxnet_hash_table(void)
Retrieves the IPX network hashtable.
Definition addr_resolv.c:4559
WS_DLL_PUBLIC bool add_ip_name_from_string(const char *addr, const char *name)
Adds a hostname mapping for a given IP address string.
Definition addr_resolv.c:2966
WS_DLL_PUBLIC char * get_hash_ether_resolved_name(hashether_t *ether)
Gets the resolved name for an Ethernet hash entry.
Definition addr_resolv.c:2012
WS_DLL_PUBLIC bool str_to_ip(const char *str, void *dst)
Parses a string as an IPv4 address.
Definition addr_resolv.c:4613
WS_DLL_PUBLIC const char * tac_name_lookup(const unsigned addr)
Resolve an TAC to its area name.
Definition addr_resolv.c:3651
WS_DLL_PUBLIC bool get_host_ipaddr(const char *host, uint32_t *addrp)
Resolves a hostname or IPv4 string to a numeric IPv4 address.
Definition addr_resolv.c:4411
WS_DLL_PUBLIC const char * tvb_get_manuf_name(tvbuff_t *tvb, unsigned offset)
Resolves a 3-octet OUI from a tvbuff to a short vendor name.
Definition addr_resolv.c:4305
WS_DLL_PUBLIC void add_ipv6_name(const ws_in6_addr *addr, const char *name, const bool static_entry)
Adds a Hostname/IPv4 in the hash table.
Definition addr_resolv.c:3936
WS_DLL_PUBLIC const char * tvb_get_manuf_name_if_known(tvbuff_t *tvb, unsigned offset)
Resolves a 3-octet OUI from a tvbuff to a full vendor name.
Definition addr_resolv.c:4350
WS_DLL_LOCAL void name_resolver_init(void)
Initializes the name resolution subsystem.
WS_DLL_PUBLIC const char * enterprises_lookup(uint32_t value, const char *unknown_str)
Resolve a private enterprise code to its registered name.
Definition addr_resolv.c:1153
WS_DLL_PUBLIC char * get_hash_ether_hexaddr(hashether_t *ether)
Gets the hex string representation of an Ethernet address.
Definition addr_resolv.c:2007
WS_DLL_PUBLIC addrinfo_lists_t * get_addrinfo_list(void)
Retrieves known host-to-address mappings.
Definition addr_resolv.c:3066
WS_DLL_PUBLIC char * sctp_port_to_display(wmem_allocator_t *allocator, unsigned port)
Resolve an SCTP port number to its display name.
Definition addr_resolv.c:4157
WS_DLL_PUBLIC bool fill_dummy_ip4(const unsigned addr, hashipv4_t *volatile tp)
Populate a dummy IPv4 object with the specified address.
Definition addr_resolv.c:1191
WS_DLL_PUBLIC resolved_name_t * get_edited_resolved_name(const char *addr)
Retrieves the user-defined name for a given address.
Definition addr_resolv.c:3021
WS_DLL_LOCAL void addr_resolv_init(const char *app_env_var_prefix)
Initializes the address resolution subsystem.
Definition addr_resolv.c:4583
WS_DLL_PUBLIC char * get_hostname_wmem(wmem_allocator_t *allocator, const unsigned addr)
Resolve an IPv4 address to its host name using scoped memory allocation.
Definition addr_resolv.c:3865
WS_DLL_LOCAL gboolean ipv6_equal(const void *v1, const void *v2)
Compares two IPv6 addresses for equality.
Definition addr_resolv.c:322
WS_DLL_PUBLIC char * dccp_port_to_display(wmem_allocator_t *allocator, unsigned port)
Resolve a DCCP port number to its display name.
Definition addr_resolv.c:4133
WS_DLL_PUBLIC const char * get_ether_name(const uint8_t *addr)
Resolves an Ethernet address to a logical name or vendor string.
Definition addr_resolv.c:4197
WS_DLL_PUBLIC wmem_map_t * get_vlan_hash_table(void)
Retrieves the VLAN ID hashtable.
Definition addr_resolv.c:4565
WS_DLL_PUBLIC const char * uint_get_manuf_name_if_known(const uint32_t oid)
Resolves a 24-bit OUI integer to a vendor name.
Definition addr_resolv.c:4339
WS_DLL_PUBLIC bool add_hosts_file(const char *hosts_file)
Adds an additional "hosts" file for IPv4 and IPv6 name resolution.
Definition addr_resolv.c:2942
WS_DLL_PUBLIC const char * get_hostname6(const ws_in6_addr *ad)
Resolves an IPv6 address to a hostname or numeric string.
Definition addr_resolv.c:3879
WS_DLL_PUBLIC char * get_hostname6_wmem(wmem_allocator_t *allocator, const ws_in6_addr *ad)
Resolves an IPv6 address to a hostname using a memory allocator.
Definition addr_resolv.c:3895
struct _e_addr_resolve e_addr_resolve
Flags to control name resolution.
WS_DLL_PUBLIC const char * get_hostname_ss7pc(const uint8_t ni, const uint32_t pc)
Resolves an SS7 Point Code to a hostname.
Definition addr_resolv.c:3486
WS_DLL_PUBLIC void disable_name_resolution(void)
Disable all forms of name resolution.
Definition addr_resolv.c:3777
void addr_resolve_pref_init(struct pref_module *nameres)
Disable all forms of name resolution.
Definition addr_resolv.c:3662
WS_DLL_PUBLIC char * get_ipxnet_name(wmem_allocator_t *allocator, const uint32_t addr)
Resolves an IPX network number to a name.
Definition addr_resolv.c:4266
WS_DLL_PUBLIC int port_with_resolution_to_str_buf(char *buf, unsigned long buf_size, port_type proto, unsigned port)
Format a port number with its resolved service name into a buffer.
Definition addr_resolv.c:4183
WS_DLL_LOCAL void host_name_lookup_reset(const char *app_env_var_prefix)
Reinitialize hostname resolution subsystem.
Definition addr_resolv.c:4114
WS_DLL_PUBLIC char * port_with_resolution_to_str(wmem_allocator_t *scope, port_type proto, unsigned port)
Format a port number with its resolved service name.
Definition addr_resolv.c:4169
WS_DLL_PUBLIC void set_resolution_synchrony(bool synchronous)
Sets the resolution mode to synchronous or asynchronous.
Definition addr_resolv.c:714
WS_DLL_PUBLIC char * get_hash_manuf_resolved_name(hashmanuf_t *manuf)
Gets the resolved name for a manufacturer hash entry.
Definition addr_resolv.c:4362
WS_DLL_PUBLIC wmem_map_t * get_eth_hashtable(void)
Retrieves the Ethernet address hashtable.
Definition addr_resolv.c:4547
Flags to control name resolution.
Definition addr_resolv.h:52
bool dns_pkt_addr_resolution
Definition addr_resolv.h:56
bool maxmind_geoip
Definition addr_resolv.h:61
bool ss7pc_name
Definition addr_resolv.h:60
bool tac_name
Definition addr_resolv.h:62
bool use_external_net_name_resolver
Definition addr_resolv.h:58
bool handshake_sni_addr_resolution
Definition addr_resolv.h:57
bool transport_name
Definition addr_resolv.h:55
bool mac_name
Definition addr_resolv.h:53
bool network_name
Definition addr_resolv.h:54
bool vlan_name
Definition addr_resolv.h:59
Definition addr_resolv.h:89
Definition addr_resolv.h:83
Internal memory allocator interface used by the wmem subsystem.
Definition wmem_allocator.h:34
Definition wmem_map.c:60
Definition wtap.h:1609
Represents a 128-bit IPv6 address.
Definition inet_addr.h:27
Definition addr_resolv.c:184
Definition addr_resolv.c:191
Definition wtap.h:1590
Definition addr_resolv.c:203
Definition addr_resolv.c:198
Definition prefs-int.h:27
const char * name
Definition prefs-int.h:28
Definition tvbuff-int.h:36