summaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-wbxml.c
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-09-19 04:14:53 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-09-19 04:14:53 +0000
commita86c5f7cae7ec9a3398300555a0b644689d946a1 (patch)
tree39fe4b107c71174fd1e8a8ceb9a4d2aa14116248 /epan/dissectors/packet-wbxml.c
parentReleasing progress-linux version 4.2.6-1~progress7.99u1. (diff)
downloadwireshark-a86c5f7cae7ec9a3398300555a0b644689d946a1.tar.xz
wireshark-a86c5f7cae7ec9a3398300555a0b644689d946a1.zip
Merging upstream version 4.4.0.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--epan/dissectors/packet-wbxml.c477
1 files changed, 240 insertions, 237 deletions
diff --git a/epan/dissectors/packet-wbxml.c b/epan/dissectors/packet-wbxml.c
index 5836cddb..c5754c0a 100644
--- a/epan/dissectors/packet-wbxml.c
+++ b/epan/dissectors/packet-wbxml.c
@@ -38,7 +38,7 @@
#include <epan/proto_data.h>
#include <epan/strutil.h>
#include <epan/iana_charsets.h>
-/* We need the function tvb_get_guintvar() */
+/* We need the function tvb_get_uintvar() */
#include "packet-wap.h"
void proto_register_wbxml(void);
@@ -125,76 +125,76 @@ void proto_reg_handoff_wbxml(void);
/* Initialize the protocol and registered fields */
-static int proto_wbxml = -1;
-static int hf_wbxml_version = -1;
-static int hf_wbxml_public_id_known = -1;
-static int hf_wbxml_public_id_literal = -1;
-static int hf_wbxml_charset = -1;
-static int hf_wbxml_string_table_item_offset = -1;
-static int hf_wbxml_string_table_item_string = -1;
-static int hf_wbxml_switch_page = -1;
-static int hf_wbxml_known_tag = -1;
-static int hf_wbxml_end_known_tag = -1;
-static int hf_wbxml_end_known_tag_uint = -1;
-static int hf_wbxml_str_i = -1;
-static int hf_wbxml_str_t = -1;
-static int hf_wbxml_opaque_data = -1;
-static int hf_wbxml_entity = -1;
-static int hf_wbxml_literal = -1;
-static int hf_wbxml_ext_i = -1;
-static int hf_wbxml_ext_t = -1;
-static int hf_wbxml_extension_token = -1;
-static int hf_wbxml_reserved_2 = -1;
-static int hf_wbxml_invalid_token = -1;
-static int hf_wbxml_known_attrvalue = -1;
-static int hf_wbxml_known_attrstart = -1;
-static int hf_wbxml_end_literal_tag = -1;
-static int hf_wbxml_literal_a = -1;
-static int hf_wbxml_literal_c = -1;
-static int hf_wbxml_literal_ac = -1;
-static int hf_wbxml_end_pi = -1;
-static int hf_wbxml_end_attribute_list = -1;
-static int hf_wbxml_pi_xml = -1;
+static int proto_wbxml;
+static int hf_wbxml_version;
+static int hf_wbxml_public_id_known;
+static int hf_wbxml_public_id_literal;
+static int hf_wbxml_charset;
+static int hf_wbxml_string_table_item_offset;
+static int hf_wbxml_string_table_item_string;
+static int hf_wbxml_switch_page;
+static int hf_wbxml_known_tag;
+static int hf_wbxml_end_known_tag;
+static int hf_wbxml_end_known_tag_uint;
+static int hf_wbxml_str_i;
+static int hf_wbxml_str_t;
+static int hf_wbxml_opaque_data;
+static int hf_wbxml_entity;
+static int hf_wbxml_literal;
+static int hf_wbxml_ext_i;
+static int hf_wbxml_ext_t;
+static int hf_wbxml_extension_token;
+static int hf_wbxml_reserved_2;
+static int hf_wbxml_invalid_token;
+static int hf_wbxml_known_attrvalue;
+static int hf_wbxml_known_attrstart;
+static int hf_wbxml_end_literal_tag;
+static int hf_wbxml_literal_a;
+static int hf_wbxml_literal_c;
+static int hf_wbxml_literal_ac;
+static int hf_wbxml_end_pi;
+static int hf_wbxml_end_attribute_list;
+static int hf_wbxml_pi_xml;
/* Initialize the subtree pointers */
-static gint ett_wbxml = -1;
-static gint ett_wbxml_str_tbl = -1;
-static gint ett_wbxml_content = -1;
-static gint ett_wbxml_tags = -1;
-static gint ett_wbxml_string_table_item = -1;
-
-static expert_field ei_wbxml_data_not_shown = EI_INIT;
-static expert_field ei_wbxml_content_type_not_supported = EI_INIT;
-static expert_field ei_wbxml_content_type_disabled = EI_INIT;
-static expert_field ei_wbxml_oversized_uintvar = EI_INIT;
-static expert_field ei_wbxml_too_much_recursion = EI_INIT;
+static int ett_wbxml;
+static int ett_wbxml_str_tbl;
+static int ett_wbxml_content;
+static int ett_wbxml_tags;
+static int ett_wbxml_string_table_item;
+
+static expert_field ei_wbxml_data_not_shown;
+static expert_field ei_wbxml_content_type_not_supported;
+static expert_field ei_wbxml_content_type_disabled;
+static expert_field ei_wbxml_oversized_uintvar;
+static expert_field ei_wbxml_too_much_recursion;
static dissector_handle_t wbxml_handle;
/* WBXML Preferences */
-static gboolean skip_wbxml_token_mapping = FALSE;
-static gboolean disable_wbxml_token_parsing = FALSE;
+static bool skip_wbxml_token_mapping;
+static bool disable_wbxml_token_parsing;
typedef struct _value_valuestring {
- guint32 value;
+ uint32_t value;
const value_string *valstrptr;
} value_valuestring;
/* Tries to match val against each element in the value_value_string array vvs.
* Returns the associated value_string ptr on a match, or NULL on failure. */
static const value_string *
-val_to_valstr(guint32 val, const value_valuestring *vvs)
+val_to_valstr(uint32_t val, const value_valuestring *vvs)
{
- gint i = 0;
+ int i = 0;
while (vvs[i].valstrptr) {
if (vvs[i].value == val)
- return(vvs[i].valstrptr);
+ return vvs[i].valstrptr;
i++;
}
- return(NULL);
+ return NULL;
}
/* Note on Token mapping
@@ -222,9 +222,9 @@ val_to_valstr(guint32 val, const value_valuestring *vvs)
/* ext_t_func_ptr is a pointer to a function handling the EXT_T_i tokens:
*
- * char * ext_t_function(tvbuff_t *tvb, guint32 value, guint32 strtbl);
+ * char * ext_t_function(tvbuff_t *tvb, uint32_t value, uint32_t strtbl);
*/
-typedef char * (* ext_t_func_ptr)(tvbuff_t *, guint32, guint32);
+typedef char * (* ext_t_func_ptr)(tvbuff_t *, uint32_t, uint32_t);
/* Note on parsing of OPAQUE data
* ------------------------------
@@ -254,49 +254,49 @@ typedef char * (* ext_t_func_ptr)(tvbuff_t *, guint32, guint32);
*
* The length of the processed OPAQUE value is returned by reference.
*
- * char * opaque_token_function(tvbuff_t *tvb, guint32 offset,
- * guint8 token, guint8 codepage, guint32 *length);
- * char * opaque_literal_function(tvbuff_t *tvb, guint32 offset,
- * const char *token, guint8 codepage, guint32 *length);
+ * char * opaque_token_function(tvbuff_t *tvb, uint32_t offset,
+ * uint8_t token, uint8_t codepage, uint32_t *length);
+ * char * opaque_literal_function(tvbuff_t *tvb, uint32_t offset,
+ * const char *token, uint8_t codepage, uint32_t *length);
*/
-typedef char * (* opaque_token_func_ptr)(tvbuff_t *, guint32, guint8, guint8, guint32 *, packet_info *);
-typedef char * (* opaque_literal_func_ptr)(tvbuff_t *, guint32, const char *, guint8, guint32 *, packet_info *);
+typedef char * (* opaque_token_func_ptr)(tvbuff_t *, uint32_t, uint8_t, uint8_t, uint32_t *, packet_info *);
+typedef char * (* opaque_literal_func_ptr)(tvbuff_t *, uint32_t, const char *, uint8_t, uint32_t *, packet_info *);
static char *
-default_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
- guint8 token _U_, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+default_opaque_binary_tag(tvbuff_t *tvb, uint32_t offset,
+ uint8_t token _U_, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = wmem_strdup_printf(pinfo->pool, "(%u bytes of opaque data)", data_len);
*length += data_len;
return str;
}
static char *
-default_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
- const char *token _U_, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+default_opaque_literal_tag(tvbuff_t *tvb, uint32_t offset,
+ const char *token _U_, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = wmem_strdup_printf(pinfo->pool, "(%u bytes of opaque data)", data_len);
*length += data_len;
return str;
}
static char *
-default_opaque_binary_attr(tvbuff_t *tvb, guint32 offset,
- guint8 token _U_, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+default_opaque_binary_attr(tvbuff_t *tvb, uint32_t offset,
+ uint8_t token _U_, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = wmem_strdup_printf(pinfo->pool, "(%u bytes of opaque data)", data_len);
*length += data_len;
return str;
}
static char *
-default_opaque_literal_attr(tvbuff_t *tvb, guint32 offset,
- const char *token _U_, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+default_opaque_literal_attr(tvbuff_t *tvb, uint32_t offset,
+ const char *token _U_, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = wmem_strdup_printf(pinfo->pool, "(%u bytes of opaque data)", data_len);
*length += data_len;
return str;
@@ -305,7 +305,7 @@ default_opaque_literal_attr(tvbuff_t *tvb, guint32 offset,
/* Render a hex %dateTime encoded timestamp as a string.
* 0x20011231123456 becomes "2001-12-31T12:34:56Z" */
static char *
-date_time_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, guint32 offset, guint32 data_len)
+date_time_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, uint32_t offset, uint32_t data_len)
{
char *str;
@@ -313,40 +313,40 @@ date_time_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, guint32 offset, gui
case 4: /* YYYY-MM-DD[T00:00:00Z] */
str = wmem_strdup_printf(pool, "%%DateTime: "
"%02x%02x-%02x-%02xT00:00:00Z",
- tvb_get_guint8(tvb, offset),
- tvb_get_guint8(tvb, offset + 1),
- tvb_get_guint8(tvb, offset + 2),
- tvb_get_guint8(tvb, offset + 3));
+ tvb_get_uint8(tvb, offset),
+ tvb_get_uint8(tvb, offset + 1),
+ tvb_get_uint8(tvb, offset + 2),
+ tvb_get_uint8(tvb, offset + 3));
break;
case 5: /* YYYY-MM-DDThh[:00:00Z] */
str = wmem_strdup_printf(pool, "%%DateTime: "
"%02x%02x-%02x-%02xT%02x:00:00Z",
- tvb_get_guint8(tvb, offset),
- tvb_get_guint8(tvb, offset + 1),
- tvb_get_guint8(tvb, offset + 2),
- tvb_get_guint8(tvb, offset + 3),
- tvb_get_guint8(tvb, offset + 4));
+ tvb_get_uint8(tvb, offset),
+ tvb_get_uint8(tvb, offset + 1),
+ tvb_get_uint8(tvb, offset + 2),
+ tvb_get_uint8(tvb, offset + 3),
+ tvb_get_uint8(tvb, offset + 4));
break;
case 6: /* YYYY-MM-DDThh:mm[:00Z] */
str = wmem_strdup_printf(pool, "%%DateTime: "
"%02x%02x-%02x-%02xT%02x:%02x:00Z",
- tvb_get_guint8(tvb, offset),
- tvb_get_guint8(tvb, offset + 1),
- tvb_get_guint8(tvb, offset + 2),
- tvb_get_guint8(tvb, offset + 3),
- tvb_get_guint8(tvb, offset + 4),
- tvb_get_guint8(tvb, offset + 5));
+ tvb_get_uint8(tvb, offset),
+ tvb_get_uint8(tvb, offset + 1),
+ tvb_get_uint8(tvb, offset + 2),
+ tvb_get_uint8(tvb, offset + 3),
+ tvb_get_uint8(tvb, offset + 4),
+ tvb_get_uint8(tvb, offset + 5));
break;
case 7: /* YYYY-MM-DDThh:mm[:00Z] */
str = wmem_strdup_printf(pool, "%%DateTime: "
"%02x%02x-%02x-%02xT%02x:%02x:%02xZ",
- tvb_get_guint8(tvb, offset),
- tvb_get_guint8(tvb, offset + 1),
- tvb_get_guint8(tvb, offset + 2),
- tvb_get_guint8(tvb, offset + 3),
- tvb_get_guint8(tvb, offset + 4),
- tvb_get_guint8(tvb, offset + 5),
- tvb_get_guint8(tvb, offset + 6));
+ tvb_get_uint8(tvb, offset),
+ tvb_get_uint8(tvb, offset + 1),
+ tvb_get_uint8(tvb, offset + 2),
+ tvb_get_uint8(tvb, offset + 3),
+ tvb_get_uint8(tvb, offset + 4),
+ tvb_get_uint8(tvb, offset + 5),
+ tvb_get_uint8(tvb, offset + 6));
break;
default:
str = wmem_strdup_printf(pool, "<Error: invalid binary %%DateTime "
@@ -360,37 +360,37 @@ date_time_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, guint32 offset, gui
/* Is ALWAYS 6 bytes long:
* 00YY YYYY YYYY YYMM MMDD DDDh hhhh mmmm mmss ssss ZZZZ ZZZZ */
static char *
-wv_datetime_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, guint32 offset, guint32 data_len)
+wv_datetime_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, uint32_t offset, uint32_t data_len)
{
char *str;
- guint16 year;
- guint8 month, day, hour, minute, second, time_zone;
- guint8 peek;
+ uint16_t year;
+ uint8_t month, day, hour, minute, second, time_zone;
+ uint8_t peek;
if (data_len == 6) { /* Valid */
/* Octet 1: 00YY YYYY */
- year = tvb_get_guint8(tvb, offset) & 0x3F; /* ..11 1111 */
+ year = tvb_get_uint8(tvb, offset) & 0x3F; /* ..11 1111 */
year <<=6;
/* Octet 2: YYYY YYMM */
- peek = tvb_get_guint8(tvb, offset + 1);
+ peek = tvb_get_uint8(tvb, offset + 1);
year += (peek >> 2); /* 1111 11.. */
month = (peek & 0x03) << 2; /* .... ..11 */
/* Octet 3: MMDD DDDh */
- peek = tvb_get_guint8(tvb, offset + 2);
+ peek = tvb_get_uint8(tvb, offset + 2);
month += (peek >> 6); /* 11.. .... */
day = (peek & 0x3E) >> 1; /* ..11 111. */
hour = (peek & 0x01) << 4; /* .... ...1 */
/* Octet 4: hhhh mmmm */
- peek = tvb_get_guint8(tvb, offset + 3);
+ peek = tvb_get_uint8(tvb, offset + 3);
hour += (peek >> 4);
minute = (peek & 0x0F) << 2; /* .... 1111 */
/* Octet 5: mmss ssss */
- peek = tvb_get_guint8(tvb, offset + 4);
+ peek = tvb_get_uint8(tvb, offset + 4);
minute += (peek >> 6); /* 11.. .... */
second = peek & 0x3F; /* ..11 1111 */
/* octet 6: ZZZZZZZZ */
- time_zone = tvb_get_guint8(tvb, offset + 5);
+ time_zone = tvb_get_uint8(tvb, offset + 5);
/* Now construct the string */
str = wmem_strdup_printf(pool, "WV-CSP DateTime: "
"%04d-%02d-%02dT%02d:%02d:%02d%s",
@@ -405,14 +405,14 @@ wv_datetime_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, guint32 offset, g
/* WV-CSP integer values for tag content is encoded in a fashion similar
* to a Long-Integer in WSP */
static char *
-wv_integer_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, guint32 offset, guint32 data_len)
+wv_integer_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, uint32_t offset, uint32_t data_len)
{
char *str;
switch (data_len) {
case 1:
str = wmem_strdup_printf(pool, "WV-CSP Integer: %d",
- tvb_get_guint8(tvb, offset));
+ tvb_get_uint8(tvb, offset));
break;
case 2:
str = wmem_strdup_printf(pool, "WV-CSP Integer: %d",
@@ -436,10 +436,10 @@ wv_integer_from_opaque(wmem_allocator_t *pool, tvbuff_t *tvb, guint32 offset, gu
}
static char *
-wv_csp10_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
- guint8 token, guint8 codepage, guint32 *length, packet_info *pinfo)
+wv_csp10_opaque_binary_tag(tvbuff_t *tvb, uint32_t offset,
+ uint8_t token, uint8_t codepage, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
switch (codepage) {
@@ -499,10 +499,10 @@ wv_csp10_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
}
static char *
-wv_csp10_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
- const char *token, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+wv_csp10_opaque_literal_tag(tvbuff_t *tvb, uint32_t offset,
+ const char *token, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
if ( token && ( (strcmp(token, "Code") == 0)
@@ -534,10 +534,10 @@ wv_csp10_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
}
static char *
-wv_csp11_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
- guint8 token, guint8 codepage, guint32 *length, packet_info *pinfo)
+wv_csp11_opaque_binary_tag(tvbuff_t *tvb, uint32_t offset,
+ uint8_t token, uint8_t codepage, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
switch (codepage) {
@@ -606,10 +606,10 @@ wv_csp11_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
}
static char *
-wv_csp11_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
- const char *token, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+wv_csp11_opaque_literal_tag(tvbuff_t *tvb, uint32_t offset,
+ const char *token, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
if ( token && ( (strcmp(token, "Code") == 0)
@@ -643,10 +643,10 @@ wv_csp11_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
static char *
-wv_csp12_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
- guint8 token, guint8 codepage, guint32 *length, packet_info *pinfo)
+wv_csp12_opaque_binary_tag(tvbuff_t *tvb, uint32_t offset,
+ uint8_t token, uint8_t codepage, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
switch (codepage) {
@@ -726,10 +726,10 @@ wv_csp12_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
}
static char *
-wv_csp12_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
- const char *token, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+wv_csp12_opaque_literal_tag(tvbuff_t *tvb, uint32_t offset,
+ const char *token, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
if ( token && ( (strcmp(token, "Code") == 0)
@@ -764,10 +764,10 @@ wv_csp12_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
}
static char *
-wv_csp13_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
- guint8 token, guint8 codepage, guint32 *length, packet_info *pinfo)
+wv_csp13_opaque_binary_tag(tvbuff_t *tvb, uint32_t offset,
+ uint8_t token, uint8_t codepage, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
switch (codepage)
@@ -903,10 +903,10 @@ wv_csp13_opaque_binary_tag(tvbuff_t *tvb, guint32 offset,
static char *
-wv_csp13_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
- const char *token, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+wv_csp13_opaque_literal_tag(tvbuff_t *tvb, uint32_t offset,
+ const char *token, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
if ( token && ( (strcmp(token, "Code") == 0)
@@ -961,10 +961,10 @@ wv_csp13_opaque_literal_tag(tvbuff_t *tvb, guint32 offset,
}
static char *
-sic10_opaque_literal_attr(tvbuff_t *tvb, guint32 offset,
- const char *token, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+sic10_opaque_literal_attr(tvbuff_t *tvb, uint32_t offset,
+ const char *token, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
if ( token && ( (strcmp(token, "created") == 0)
@@ -981,10 +981,10 @@ sic10_opaque_literal_attr(tvbuff_t *tvb, guint32 offset,
}
static char *
-sic10_opaque_binary_attr(tvbuff_t *tvb, guint32 offset,
- guint8 token, guint8 codepage, guint32 *length, packet_info *pinfo)
+sic10_opaque_binary_attr(tvbuff_t *tvb, uint32_t offset,
+ uint8_t token, uint8_t codepage, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
switch (codepage) {
@@ -1011,10 +1011,10 @@ sic10_opaque_binary_attr(tvbuff_t *tvb, guint32 offset,
}
static char *
-emnc10_opaque_literal_attr(tvbuff_t *tvb, guint32 offset,
- const char *token, guint8 codepage _U_, guint32 *length, packet_info *pinfo)
+emnc10_opaque_literal_attr(tvbuff_t *tvb, uint32_t offset,
+ const char *token, uint8_t codepage _U_, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
if ( token && (strcmp(token, "timestamp") == 0) )
@@ -1030,10 +1030,10 @@ emnc10_opaque_literal_attr(tvbuff_t *tvb, guint32 offset,
}
static char *
-emnc10_opaque_binary_attr(tvbuff_t *tvb, guint32 offset,
- guint8 token, guint8 codepage, guint32 *length, packet_info *pinfo)
+emnc10_opaque_binary_attr(tvbuff_t *tvb, uint32_t offset,
+ uint8_t token, uint8_t codepage, uint32_t *length, packet_info *pinfo)
{
- guint32 data_len = tvb_get_guintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
+ uint32_t data_len = tvb_get_uintvar(tvb, offset, length, pinfo, &ei_wbxml_oversized_uintvar);
char *str = NULL;
switch (codepage) {
@@ -1075,11 +1075,11 @@ typedef struct _wbxml_decoding {
/* Define a pointer to a discriminator function taking a tvb and the start
* offset of the WBXML tokens in the body as arguments.
*/
-typedef const wbxml_decoding * (* discriminator_func_ptr)(tvbuff_t *, guint32);
+typedef const wbxml_decoding * (* discriminator_func_ptr)(tvbuff_t *, uint32_t);
/* For the decoding lists based on the known WBXML public ID */
typedef struct _wbxml_integer_list {
- guint32 public_id;
+ uint32_t public_id;
const wbxml_decoding *map;
} wbxml_integer_list;
@@ -1215,7 +1215,7 @@ static value_string_ext vals_wbxml1x_global_tokens_ext = VALUE_STRING_EXT_INIT(v
* Wireless Markup Language
***************************************/
static char *
-ext_t_0_wml_10(tvbuff_t *tvb, guint32 value, guint32 str_tbl)
+ext_t_0_wml_10(tvbuff_t *tvb, uint32_t value, uint32_t str_tbl)
{
char *str = wmem_strdup_printf(wmem_packet_scope(), "Variable substitution - escaped: '%s'",
tvb_get_stringz_enc(wmem_packet_scope(), tvb, str_tbl + value, NULL, ENC_ASCII));
@@ -1223,7 +1223,7 @@ ext_t_0_wml_10(tvbuff_t *tvb, guint32 value, guint32 str_tbl)
}
static char *
-ext_t_1_wml_10(tvbuff_t *tvb, guint32 value, guint32 str_tbl)
+ext_t_1_wml_10(tvbuff_t *tvb, uint32_t value, uint32_t str_tbl)
{
char *str = wmem_strdup_printf(wmem_packet_scope(), "Variable substitution - unescaped: '%s'",
tvb_get_stringz_enc(wmem_packet_scope(), tvb, str_tbl + value, NULL, ENC_ASCII));
@@ -1231,7 +1231,7 @@ ext_t_1_wml_10(tvbuff_t *tvb, guint32 value, guint32 str_tbl)
}
static char *
-ext_t_2_wml_10(tvbuff_t *tvb, guint32 value, guint32 str_tbl)
+ext_t_2_wml_10(tvbuff_t *tvb, uint32_t value, uint32_t str_tbl)
{
char *str = wmem_strdup_printf(wmem_packet_scope(), "Variable substitution - no transformation: '%s'",
tvb_get_stringz_enc(wmem_packet_scope(), tvb, str_tbl + value, NULL, ENC_ASCII));
@@ -5224,7 +5224,7 @@ static value_string_ext vals_wv_csp_11_element_value_tokens_ext = VALUE_STRING_E
/***** Token code page aggregation *****/
static char *
-ext_t_0_wv_cspc_11(tvbuff_t *tvb _U_, guint32 value, guint32 str_tbl _U_)
+ext_t_0_wv_cspc_11(tvbuff_t *tvb _U_, uint32_t value, uint32_t str_tbl _U_)
{
char *str = wmem_strdup_printf(wmem_packet_scope(), "Common Value: '%s'",
val_to_str_ext(value, &vals_wv_csp_11_element_value_tokens_ext,
@@ -5835,7 +5835,7 @@ static const value_string vals_wv_csp_12_element_value_tokens[] = {
/***** Token code page aggregation *****/
static char *
-ext_t_0_wv_cspc_12(tvbuff_t *tvb _U_, guint32 value, guint32 str_tbl _U_)
+ext_t_0_wv_cspc_12(tvbuff_t *tvb _U_, uint32_t value, uint32_t str_tbl _U_)
{
char *str = wmem_strdup_printf(wmem_packet_scope(), "Common Value: '%s'",
val_to_str(value, vals_wv_csp_12_element_value_tokens,
@@ -6675,7 +6675,7 @@ static const value_string vals_wv_csp_13_element_value_tokens[] = {
/***** Token code page aggregation *****/
static char *
-ext_t_0_wv_cspc_13(tvbuff_t *tvb _U_, guint32 value, guint32 str_tbl _U_)
+ext_t_0_wv_cspc_13(tvbuff_t *tvb _U_, uint32_t value, uint32_t str_tbl _U_)
{
char *str = wmem_strdup_printf(wmem_packet_scope(), "Common Value: '%s'",
val_to_str(value, vals_wv_csp_13_element_value_tokens,
@@ -6729,10 +6729,10 @@ static const wbxml_decoding decode_wv_cspc_13 = {
* of the start of the WBXML body.
*/
static const wbxml_decoding *
-wv_csp_discriminator(tvbuff_t *tvb, guint32 offset)
+wv_csp_discriminator(tvbuff_t *tvb, uint32_t offset)
{
- guint32 magic_1 = tvb_get_ntohl(tvb, offset + 0);
- guint16 magic_2 = tvb_get_ntohs(tvb, offset + 4);
+ uint32_t magic_1 = tvb_get_ntohl(tvb, offset + 0);
+ uint16_t magic_2 = tvb_get_ntohs(tvb, offset + 4);
if (magic_1 == 0xFE050331 && magic_2 == 0x2e30)
{
@@ -6762,14 +6762,14 @@ wv_csp_discriminator(tvbuff_t *tvb, guint32 offset)
/********************** WBXML token mapping aggregation **********************/
-static const wbxml_decoding *get_wbxml_decoding_from_public_id (guint32 publicid);
+static const wbxml_decoding *get_wbxml_decoding_from_public_id (uint32_t publicid);
static const wbxml_decoding *get_wbxml_decoding_from_content_type (
- const char *content_type, tvbuff_t *tvb, guint32 offset);
+ const char *content_type, tvbuff_t *tvb, uint32_t offset);
/**
** Aggregation of content type and aggregated code pages
- ** Content type map lookup will stop at the 1st entry with 3rd member = FALSE
+ ** Content type map lookup will stop at the 1st entry with 3rd member = false
**/
/*
@@ -6839,7 +6839,7 @@ static const wbxml_literal_list content_type_list[] = {
/* Returns a pointer to the WBXML token map for the given WBXML public
* identifier value (see WINA for a table with defined identifiers). */
-static const wbxml_decoding *get_wbxml_decoding_from_public_id (guint32 public_id)
+static const wbxml_decoding *get_wbxml_decoding_from_public_id (uint32_t public_id)
{
const wbxml_decoding *map = NULL;
@@ -6860,7 +6860,7 @@ static const wbxml_decoding *get_wbxml_decoding_from_public_id (guint32 public_i
}
static const wbxml_decoding *get_wbxml_decoding_from_content_type (
- const char *content_type, tvbuff_t *tvb, guint32 offset)
+ const char *content_type, tvbuff_t *tvb, uint32_t offset)
{
const wbxml_decoding *map = NULL;
@@ -6888,7 +6888,7 @@ static const wbxml_decoding *get_wbxml_decoding_from_content_type (
/* WBXML content token mapping depends on the following parameters:
- * - Content type (guint32)
+ * - Content type (uint32_t)
* - Token type (global, tags, attrStart, attrValue)
* - Code page for tag and attribute
*
@@ -6907,7 +6907,7 @@ static const wbxml_decoding *get_wbxml_decoding_from_content_type (
"(Requested token map not defined for this content type)"
/* Return token mapping for a given content mapping entry. */
static const char *
-map_token (const value_valuestring *token_map, guint8 codepage, guint8 token) {
+map_token (const value_valuestring *token_map, uint8_t codepage, uint8_t token) {
const value_string *vs;
const char *s;
@@ -6939,16 +6939,16 @@ map_token (const value_valuestring *token_map, guint8 codepage, guint8 token) {
/* Parse and display the WBXML string table. */
static void
-show_wbxml_string_table (proto_tree *tree, tvbuff_t *tvb, guint32 str_tbl,
- guint32 str_tbl_len, guint charset)
+show_wbxml_string_table (proto_tree *tree, tvbuff_t *tvb, uint32_t str_tbl,
+ uint32_t str_tbl_len, unsigned charset)
{
- guint encoding = mibenum_charset_to_encoding(charset);
- guint32 off = str_tbl;
- guint32 end = str_tbl + str_tbl_len;
+ unsigned encoding = mibenum_charset_to_encoding(charset);
+ uint32_t off = str_tbl;
+ uint32_t end = str_tbl + str_tbl_len;
proto_tree *item_tree;
proto_item *ti;
- const guint8 *str;
- gint len;
+ const uint8_t *str;
+ int len;
while (off < end) {
/*
@@ -6985,7 +6985,7 @@ static const char indent_buffer[514] = " "
" "
; /* Generate XML indentation (length = 1 + 2 * 256 + 1 for '\0') */
-static const char * Indent (guint8 level) {
+static const char * Indent (uint8_t level) {
return indent_buffer + (512 - 2 * (level));
}
@@ -7041,34 +7041,34 @@ static const char * Indent (guint8 level) {
*
* NOTE: See above for known token mappings.
*/
-static guint32
+static uint32_t
parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo,
- guint32 offset, guint32 str_tbl, guint8 *codepage_attr,
+ uint32_t offset, uint32_t str_tbl, uint8_t *codepage_attr,
const wbxml_decoding *map)
{
- guint32 tvb_len = tvb_reported_length (tvb);
- guint32 off = offset;
- guint32 len;
- guint str_len;
- guint32 ent;
- guint32 idx;
- guint8 peek;
- guint8 attr_save_known = 0; /* Will contain peek & 0x3F (attr identity) */
+ uint32_t tvb_len = tvb_reported_length (tvb);
+ uint32_t off = offset;
+ uint32_t len;
+ unsigned str_len;
+ uint32_t ent;
+ uint32_t idx;
+ uint8_t peek;
+ uint8_t attr_save_known = 0; /* Will contain peek & 0x3F (attr identity) */
const char *attr_save_literal = NULL; /* Will contain the LITERAL attr identity */
- const gchar *str;
+ const char *str;
unsigned recursion_level = p_get_proto_depth(pinfo, proto_wbxml);
unsigned encoding = GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_wbxml, 0));
DebugLog(("parse_wbxml_attr_defined (level = %u, offset = %u)\n", recursion_level, offset));
/* Parse attributes */
while (off < tvb_len) {
- peek = tvb_get_guint8 (tvb, off);
+ peek = tvb_get_uint8 (tvb, off);
DebugLog(("ATTR: (top of while) level = %3u, peek = 0x%02X, "
"off = %u, tvb_len = %u\n", recursion_level, peek, off, tvb_len));
if ((peek & 0x3F) < 5) switch (peek) { /* Global tokens
in state = ATTR */
case 0x00: /* SWITCH_PAGE */
- *codepage_attr = tvb_get_guint8 (tvb, off+1);
+ *codepage_attr = tvb_get_uint8 (tvb, off+1);
proto_tree_add_uint_format(tree, hf_wbxml_switch_page, tvb, off, 2, *codepage_attr,
" | Attr | A -->%3d | SWITCH_PAGE (Attr code page) |",
*codepage_attr);
@@ -7085,7 +7085,7 @@ parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info
recursion_level, off - offset));
return (off - offset);
case 0x02: /* ENTITY */
- ent = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ ent = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
if (len <= tvb_len) {
proto_tree_add_uint_format(tree, hf_wbxml_entity, tvb, off, 1+len, ent,
" %3d | Attr | A %3d | ENTITY | %s'&#%u;'",
@@ -7107,7 +7107,7 @@ parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info
/* ALWAYS means the start of a new attribute,
* and may only contain the NAME of the attribute.
*/
- idx = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ idx = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
if (len <= tvb_len) {
attr_save_known = 0;
attr_save_literal = tvb_get_stringz_enc(pinfo->pool, tvb, str_tbl+idx, &str_len, encoding);
@@ -7137,7 +7137,7 @@ parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info
case 0x81: /* EXT_T_1 */
case 0x82: /* EXT_T_2 */
/* Extension tokens */
- idx = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ idx = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
{
char *s;
if (map != NULL) {
@@ -7163,7 +7163,7 @@ parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info
}
break;
case 0x83: /* STR_T */
- idx = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ idx = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
if (len <= tvb_len) {
str = tvb_get_stringz_enc(pinfo->pool, tvb, str_tbl+idx, &str_len, encoding);
proto_tree_add_string_format(tree, hf_wbxml_str_t, tvb, off, 1+len, str,
@@ -7187,7 +7187,7 @@ parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info
off++;
break;
case 0xC3: /* OPAQUE - WBXML 1.1 and newer */
- if (tvb_get_guint8 (tvb, 0)) { /* WBXML 1.x (x > 0) */
+ if (tvb_get_uint8 (tvb, 0)) { /* WBXML 1.x (x > 0) */
if (map != NULL) {
char *tmp_str;
if (attr_save_known) { /* Knwon attribute */
@@ -7218,7 +7218,7 @@ parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info
off = tvb_len;
}
} else {
- idx = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ idx = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
if ((len <= tvb_len) && (idx < tvb_len)) {
proto_tree_add_bytes_format(tree, hf_wbxml_opaque_data, tvb, off, 1 + len + idx, NULL,
" %3d | Attr | A %3d | OPAQUE (Opaque data) | %s(%u bytes of opaque data)",
@@ -7248,7 +7248,7 @@ parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info
/* Move to end of buffer */
off = tvb_len;
break;
- } else { /* Known atribute token */
+ } else { /* Known attribute token */
const char* s;
if (peek & 0x80) { /* attrValue */
if (map != NULL) {
@@ -7306,44 +7306,45 @@ parse_wbxml_attribute_list_defined (proto_tree *tree, tvbuff_t *tvb, packet_info
* the used code page.
*/
#define WBXML_MAX_RECURSION_LEVEL 255
-static guint32
-parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, guint32 offset,
- guint32 str_tbl, guint8 *codepage_stag, guint8 *codepage_attr,
+static uint32_t
+// NOLINTNEXTLINE(misc-no-recursion)
+parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, uint32_t offset,
+ uint32_t str_tbl, uint8_t *codepage_stag, uint8_t *codepage_attr,
const wbxml_decoding *map)
{
- guint32 tvb_len = tvb_reported_length (tvb);
- guint32 off = offset;
- guint32 len;
- guint str_len;
- guint32 ent;
- guint32 idx;
- guint8 peek;
- guint32 tag_len; /* Length of the index (uintvar) from a LITERAL tag */
- guint8 tag_save_known = 0; /* Will contain peek & 0x3F (tag identity) */
- guint8 tag_new_known = 0; /* Will contain peek & 0x3F (tag identity) */
+ uint32_t tvb_len = tvb_reported_length (tvb);
+ uint32_t off = offset;
+ uint32_t len;
+ unsigned str_len;
+ uint32_t ent;
+ uint32_t idx;
+ uint8_t peek;
+ uint32_t tag_len; /* Length of the index (uintvar) from a LITERAL tag */
+ uint8_t tag_save_known = 0; /* Will contain peek & 0x3F (tag identity) */
+ uint8_t tag_new_known = 0; /* Will contain peek & 0x3F (tag identity) */
const char *tag_save_literal = NULL; /* Will contain the LITERAL tag identity */
const char *tag_new_literal; /* Will contain the LITERAL tag identity */
- const gchar *str;
- guint8 parsing_tag_content = FALSE; /* Are we parsing content from a
+ const char *str;
+ uint8_t parsing_tag_content = false; /* Are we parsing content from a
tag with content: <x>Content</x>
- The initial state is FALSE.
+ The initial state is false.
This state will trigger recursion. */
unsigned recursion_level = p_get_proto_depth(pinfo, proto_wbxml);
unsigned encoding = GPOINTER_TO_UINT(p_get_proto_data(pinfo->pool, pinfo, proto_wbxml, 0));
- if (++recursion_level >= WBXML_MAX_RECURSION_LEVEL) {
+ if (recursion_level >= WBXML_MAX_RECURSION_LEVEL) {
proto_tree_add_expert(tree, pinfo, &ei_wbxml_too_much_recursion, tvb, offset, tvb_captured_length_remaining(tvb, offset));
return tvb_len;
}
DebugLog(("parse_wbxml_tag_defined (level = %u, offset = %u)\n", recursion_level, offset));
while (off < tvb_len) {
- peek = tvb_get_guint8 (tvb, off);
+ peek = tvb_get_uint8 (tvb, off);
DebugLog(("STAG: (top of while) level = %3u, peek = 0x%02X, off = %u, tvb_len = %u\n", recursion_level, peek, off, tvb_len));
if ((peek & 0x3F) < 4) switch (peek) { /* Global tokens in state = STAG
but not the LITERAL tokens */
case 0x00: /* SWITCH_PAGE */
- *codepage_stag = tvb_get_guint8 (tvb, off+1);
+ *codepage_stag = tvb_get_uint8 (tvb, off+1);
proto_tree_add_uint_format(tree, hf_wbxml_switch_page, tvb, off, 2, *codepage_stag,
" | Tag | T -->%3d | SWITCH_PAGE (Tag code page) |",
*codepage_stag);
@@ -7368,7 +7369,7 @@ parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, gu
DebugLog(("STAG: level = %u, Return: len = %u\n", recursion_level, off - offset));
return (off - offset);
case 0x02: /* ENTITY */
- ent = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ ent = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
proto_tree_add_uint_format(tree, hf_wbxml_entity, tvb, off, 1+len, ent,
" %3d | Tag | T %3d | ENTITY | %s'&#%u;'",
recursion_level, *codepage_stag, Indent (recursion_level), ent);
@@ -7416,7 +7417,7 @@ parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, gu
case 0x81: /* EXT_T_1 */
case 0x82: /* EXT_T_2 */
/* Extension tokens */
- idx = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ idx = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
{
char *s;
if (map)
@@ -7438,7 +7439,7 @@ parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, gu
off += 1+len;
break;
case 0x83: /* STR_T */
- idx = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ idx = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
str = tvb_get_stringz_enc(pinfo->pool, tvb, str_tbl+idx, &str_len, encoding);
proto_tree_add_string_format(tree, hf_wbxml_str_t, tvb, off, 1+len, str,
" %3d | Tag | T %3d | STR_T (Tableref string) | %s\'%s\'",
@@ -7456,11 +7457,11 @@ parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, gu
off++;
break;
case 0xC3: /* OPAQUE - WBXML 1.1 and newer */
- if (tvb_get_guint8 (tvb, 0)) { /* WBXML 1.x (x > 0) */
+ if (tvb_get_uint8 (tvb, 0)) { /* WBXML 1.x (x > 0) */
if (map != NULL)
{
char *tmp_str;
- if (tag_save_known) { /* Knwon tag */
+ if (tag_save_known) { /* Known tag */
if (map->opaque_binary_tag) {
tmp_str = map->opaque_binary_tag(tvb, off + 1,
tag_save_known, *codepage_stag, &len, pinfo);
@@ -7482,7 +7483,7 @@ parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, gu
recursion_level, *codepage_stag, Indent (recursion_level), tmp_str);
off += 1 + len;
} else {
- idx = tvb_get_guintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ idx = tvb_get_uintvar (tvb, off+1, &len, pinfo, &ei_wbxml_oversized_uintvar);
if ((len <= tvb_len) && (idx < tvb_len))
{
proto_tree_add_bytes_format(tree, hf_wbxml_opaque_data, tvb, off, 1 + len + idx, NULL,
@@ -7524,7 +7525,7 @@ parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, gu
tag_len = 0;
if ((peek & 0x3F) == 4) { /* LITERAL */
DebugLog(("STAG: LITERAL tag (peek = 0x%02X, off = %u) - TableRef follows!\n", peek, off));
- idx = tvb_get_guintvar (tvb, off+1, &tag_len, pinfo, &ei_wbxml_oversized_uintvar);
+ idx = tvb_get_uintvar (tvb, off+1, &tag_len, pinfo, &ei_wbxml_oversized_uintvar);
tag_new_literal = tvb_get_stringz_enc(pinfo->pool, tvb, str_tbl+idx, &str_len, encoding);
tag_new_known = 0; /* invalidate known tag_new */
} else { /* Known tag */
@@ -7550,8 +7551,7 @@ parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, gu
DebugLog(("STAG: Tag in Tag - RECURSE! (off = %u)\n", off));
/* Do not process the attribute list:
* recursion will take care of it */
- recursion_level++;
- p_set_proto_depth(pinfo, proto_wbxml, recursion_level);
+ p_set_proto_depth(pinfo, proto_wbxml, recursion_level + 1);
len = parse_wbxml_tag_defined (tree, tvb, pinfo, off, str_tbl,
codepage_stag, codepage_attr, map);
off += len;
@@ -7612,7 +7612,7 @@ parse_wbxml_tag_defined (proto_tree *tree, tvbuff_t *tvb, packet_info *pinfo, gu
* we've just processed in the lines above.
* Next time we encounter a tag with content: recurse
*/
- parsing_tag_content = TRUE;
+ parsing_tag_content = true;
DebugLog(("Tag in Tag - No recursion this time! (off = %u)\n", off));
}
} else { /* No Content */
@@ -7694,22 +7694,22 @@ dissect_wbxml_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
proto_tree *wbxml_str_tbl_tree; /* String table subtree */
proto_tree *wbxml_content_tree; /* Content subtree */
proto_tree *tag_tree;
- guint8 version;
- guint offset = 0;
- guint32 len;
- guint32 charset = 0;
- guint32 charset_len = 0;
- guint encoding;
- guint32 publicid;
- guint32 publicid_index = 0;
- guint32 publicid_len;
- guint32 str_tbl;
- guint32 str_tbl_len;
- guint32 str_tbl_len_len = 0;
+ uint8_t version;
+ unsigned offset = 0;
+ uint32_t len;
+ uint32_t charset = 0;
+ uint32_t charset_len = 0;
+ unsigned encoding;
+ uint32_t publicid;
+ uint32_t publicid_index = 0;
+ uint32_t publicid_len;
+ uint32_t str_tbl;
+ uint32_t str_tbl_len;
+ uint32_t str_tbl_len_len = 0;
const wbxml_decoding *content_map = NULL;
- gchar *summary = NULL;
- guint8 codepage_stag = 0;
- guint8 codepage_attr = 0;
+ char *summary = NULL;
+ uint8_t codepage_stag = 0;
+ uint8_t codepage_attr = 0;
DebugLog(("dissect_wbxml: Dissecting packet %u\n", pinfo->num));
/* WBXML format
@@ -7719,7 +7719,7 @@ dissect_wbxml_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
*
* Last valid format: WBXML 1.3
*/
- switch ( version = tvb_get_guint8 (tvb, 0) ) {
+ switch ( version = tvb_get_uint8 (tvb, 0) ) {
case 0x00: /* WBXML/1.0 */
break;
@@ -7744,10 +7744,10 @@ dissect_wbxml_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
*/
/* Public ID */
- publicid = tvb_get_guintvar(tvb, 1, &publicid_len, pinfo, &ei_wbxml_oversized_uintvar);
+ publicid = tvb_get_uintvar(tvb, 1, &publicid_len, pinfo, &ei_wbxml_oversized_uintvar);
if (! publicid) {
/* Public identifier in string table */
- publicid_index = tvb_get_guintvar (tvb, 1+publicid_len, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ publicid_index = tvb_get_uintvar (tvb, 1+publicid_len, &len, pinfo, &ei_wbxml_oversized_uintvar);
publicid_len += len;
}
offset = 1 + publicid_len;
@@ -7762,7 +7762,7 @@ dissect_wbxml_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
case 0x02: /* WBXML/1.2 */
case 0x03: /* WBXML/1.3 */
/* Get charset */
- charset = tvb_get_guintvar (tvb, offset, &charset_len, pinfo, &ei_wbxml_oversized_uintvar);
+ charset = tvb_get_uintvar (tvb, offset, &charset_len, pinfo, &ei_wbxml_oversized_uintvar);
offset += charset_len;
break;
@@ -7783,7 +7783,7 @@ dissect_wbxml_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
p_add_proto_data(pinfo->pool, pinfo, proto_wbxml, 0, GUINT_TO_POINTER(encoding));
/* String table: read string table length in bytes */
- tvb_get_guintvar (tvb, offset, &str_tbl_len_len, pinfo, &ei_wbxml_oversized_uintvar);
+ tvb_get_uintvar (tvb, offset, &str_tbl_len_len, pinfo, &ei_wbxml_oversized_uintvar);
str_tbl = offset + str_tbl_len_len; /* Start of 1st string in string table */
/* Compose the summary line */
@@ -7830,7 +7830,7 @@ dissect_wbxml_common(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree,
offset += charset_len;
}
- str_tbl_len = tvb_get_guintvar (tvb, offset, &len, pinfo, &ei_wbxml_oversized_uintvar);
+ str_tbl_len = tvb_get_uintvar (tvb, offset, &len, pinfo, &ei_wbxml_oversized_uintvar);
str_tbl = offset + len; /* Start of 1st string in string table */
/* String Table */
@@ -8126,7 +8126,7 @@ proto_register_wbxml(void)
};
/* Setup protocol subtree array */
- static gint *ett[] = {
+ static int *ett[] = {
&ett_wbxml,
&ett_wbxml_str_tbl,
&ett_wbxml_content,
@@ -8254,6 +8254,9 @@ proto_reg_handoff_wbxml(void)
/* Same as application/vnd.nokia.syncset+wbxml */
dissector_add_string("media_type",
"application/x-prov.syncset+wbxml", wbxml_handle);
+
+ /* RFC 6839 */
+ dissector_add_string("media_type.suffix", "wbxml", wbxml_handle);
}
/*