summaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-agentx.c
diff options
context:
space:
mode:
Diffstat (limited to 'epan/dissectors/packet-agentx.c')
-rw-r--r--epan/dissectors/packet-agentx.c243
1 files changed, 122 insertions, 121 deletions
diff --git a/epan/dissectors/packet-agentx.c b/epan/dissectors/packet-agentx.c
index 17a3d314..a3762d35 100644
--- a/epan/dissectors/packet-agentx.c
+++ b/epan/dissectors/packet-agentx.c
@@ -15,6 +15,7 @@
#include <epan/packet.h>
#include <epan/to_str.h>
+#include <epan/tfs.h>
#include <wsutil/ws_roundup.h>
#include "packet-tcp.h"
@@ -27,71 +28,71 @@ void proto_reg_handoff_agentx(void);
static dissector_handle_t agentx_handle;
/* Define the agentx proto */
-static int proto_agentx = -1;
-
-
-static int hf_version = -1;
-static int hf_type = -1;
-static int hf_flags = -1;
-static int hf_flags_register = -1;
-static int hf_flags_newindex = -1;
-static int hf_flags_anyindex = -1;
-static int hf_flags_context = -1;
-static int hf_flags_byteorder = -1;
-static int hf_session_id = -1;
-static int hf_trans_id = -1;
-static int hf_packet_id = -1;
-static int hf_payload_len = -1;
-static int hf_ostring_len = -1;
-static int hf_ostring = -1;
-static int hf_oid_sub = -1;
-static int hf_oid_prefix = -1;
-static int hf_oid_include = -1;
-static int hf_oid_str = -1;
-static int hf_resp_uptime = -1;
-static int hf_resp_error = -1;
-static int hf_resp_index = -1;
-static int hf_vtag = -1;
-static int hf_val32 = -1;
-static int hf_val64 = -1;
-static int hf_open_timeout = -1;
-static int hf_close_reason = -1;
-static int hf_reg_timeout = -1;
-static int hf_reg_prio = -1;
-static int hf_reg_rsid = -1;
-static int hf_reg_ubound = -1;
-static int hf_unreg_timeout = -1;
-static int hf_unreg_prio = -1;
-static int hf_unreg_rsid = -1;
-static int hf_unreg_ubound = -1;
-static int hf_gbulk_nrepeat = -1;
-static int hf_gbulk_mrepeat = -1;
-
-
-static gint ett_flags = -1;
-static gint ett_agentx = -1;
-static gint ett_pdu_hdr = -1;
-static gint ett_get = -1;
-static gint ett_getnext = -1;
-static gint ett_search_range = -1;
-static gint ett_obj_ident = -1;
-static gint ett_response = -1;
-static gint ett_valrep = -1;
-static gint ett_open = -1;
-static gint ett_close = -1;
-static gint ett_register = -1;
-static gint ett_unregister = -1;
-static gint ett_getbulk = -1;
-static gint ett_testset = -1;
-static gint ett_commitset = -1;
-static gint ett_undoset = -1;
-static gint ett_cleanupset = -1;
-static gint ett_notify = -1;
-static gint ett_ping = -1;
-static gint ett_idxalloc = -1;
-static gint ett_idxdalloc = -1;
-static gint ett_addcap = -1;
-static gint ett_remcap = -1;
+static int proto_agentx;
+
+
+static int hf_version;
+static int hf_type;
+static int hf_flags;
+static int hf_flags_register;
+static int hf_flags_newindex;
+static int hf_flags_anyindex;
+static int hf_flags_context;
+static int hf_flags_byteorder;
+static int hf_session_id;
+static int hf_trans_id;
+static int hf_packet_id;
+static int hf_payload_len;
+static int hf_ostring_len;
+static int hf_ostring;
+static int hf_oid_sub;
+static int hf_oid_prefix;
+static int hf_oid_include;
+static int hf_oid_str;
+static int hf_resp_uptime;
+static int hf_resp_error;
+static int hf_resp_index;
+static int hf_vtag;
+static int hf_val32;
+static int hf_val64;
+static int hf_open_timeout;
+static int hf_close_reason;
+static int hf_reg_timeout;
+static int hf_reg_prio;
+static int hf_reg_rsid;
+static int hf_reg_ubound;
+static int hf_unreg_timeout;
+static int hf_unreg_prio;
+static int hf_unreg_rsid;
+static int hf_unreg_ubound;
+static int hf_gbulk_nrepeat;
+static int hf_gbulk_mrepeat;
+
+
+static int ett_flags;
+static int ett_agentx;
+static int ett_pdu_hdr;
+static int ett_get;
+static int ett_getnext;
+static int ett_search_range;
+static int ett_obj_ident;
+static int ett_response;
+static int ett_valrep;
+static int ett_open;
+static int ett_close;
+static int ett_register;
+static int ett_unregister;
+static int ett_getbulk;
+static int ett_testset;
+static int ett_commitset;
+static int ett_undoset;
+static int ett_cleanupset;
+static int ett_notify;
+static int ett_ping;
+static int ett_idxalloc;
+static int ett_idxdalloc;
+static int ett_addcap;
+static int ett_remcap;
#define AGENTX_OPEN_PDU 1
@@ -284,9 +285,9 @@ enum OID_USAGE { OID_START_RANGE, OID_END_RANGE, OID_EXACT };
tvb_get_letohs(tvb, offset)
static int
-dissect_octet_string(tvbuff_t *tvb, proto_tree *tree, int offset, guint8 flags)
+dissect_octet_string(tvbuff_t *tvb, proto_tree *tree, int offset, uint8_t flags)
{
- guint32 n_oct, p_noct;
+ uint32_t n_oct, p_noct;
NORLEL(flags, n_oct, tvb, offset);
@@ -304,7 +305,7 @@ dissect_octet_string(tvbuff_t *tvb, proto_tree *tree, int offset, guint8 flags)
/* XXX - Is there a particular reason we're not using oid_encoded2string() here? */
static int
-convert_oid_to_str(guint32 *oid, int len, char* str, int slen, char prefix)
+convert_oid_to_str(uint32_t *oid, int len, char* str, int slen, char prefix)
{
int i, tlen = 0;
if(!oid) return 0;
@@ -324,23 +325,23 @@ convert_oid_to_str(guint32 *oid, int len, char* str, int slen, char prefix)
}
static int
-dissect_object_id(tvbuff_t *tvb, proto_tree *tree, int offset, guint8 flags, enum OID_USAGE oid_usage)
+dissect_object_id(tvbuff_t *tvb, proto_tree *tree, int offset, uint8_t flags, enum OID_USAGE oid_usage)
{
- guint8 n_subid;
- guint8 prefix;
- guint8 include;
+ uint8_t n_subid;
+ uint8_t prefix;
+ uint8_t include;
proto_tree* subtree;
- guint32 oid[2048];
+ uint32_t oid[2048];
char str_oid[2048];
int i;
memset(oid, '\0', sizeof(oid));
memset(str_oid, '\0', sizeof(str_oid));
- n_subid = tvb_get_guint8(tvb, offset);
- prefix = tvb_get_guint8(tvb, offset + 1);
- include = tvb_get_guint8(tvb, offset + 2);
- tvb_get_guint8(tvb, offset + 3);
+ n_subid = tvb_get_uint8(tvb, offset);
+ prefix = tvb_get_uint8(tvb, offset + 1);
+ include = tvb_get_uint8(tvb, offset + 2);
+ tvb_get_uint8(tvb, offset + 3);
for(i=0; i<n_subid; i++) {
NORLEL(flags, oid[i], tvb, (offset+4) + (i*4));
@@ -371,7 +372,7 @@ dissect_object_id(tvbuff_t *tvb, proto_tree *tree, int offset, guint8 flags, enu
}
static int
-dissect_search_range(tvbuff_t *tvb, proto_tree *tree, int start_offset, guint8 flags, guint8 pdu_type)
+dissect_search_range(tvbuff_t *tvb, proto_tree *tree, int start_offset, uint8_t flags, uint8_t pdu_type)
{
int offset = start_offset;
offset += dissect_object_id(tvb, tree, offset, flags, (pdu_type == AGENTX_GET_PDU) ? OID_EXACT : OID_START_RANGE);
@@ -381,9 +382,9 @@ dissect_search_range(tvbuff_t *tvb, proto_tree *tree, int start_offset, guint8 f
}
static int
-dissect_val64(tvbuff_t *tvb, proto_tree *tree, int offset, guint8 flags)
+dissect_val64(tvbuff_t *tvb, proto_tree *tree, int offset, uint8_t flags)
{
- guint encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
+ unsigned encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
proto_tree_add_item(tree, hf_val64, tvb, offset, 8, encoding);
@@ -391,9 +392,9 @@ dissect_val64(tvbuff_t *tvb, proto_tree *tree, int offset, guint8 flags)
}
static int
-dissect_val32(tvbuff_t *tvb, proto_tree *tree, int offset, guint8 flags)
+dissect_val32(tvbuff_t *tvb, proto_tree *tree, int offset, uint8_t flags)
{
- guint encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
+ unsigned encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
proto_tree_add_item(tree, hf_val32, tvb, offset, 4, encoding);
@@ -401,9 +402,9 @@ dissect_val32(tvbuff_t *tvb, proto_tree *tree, int offset, guint8 flags)
}
static int
-dissect_varbind(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_varbind(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
- guint16 vtag;
+ uint16_t vtag;
int tlen;
proto_tree* subtree;
@@ -450,11 +451,11 @@ dissect_varbind(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 fla
}
static void
-dissect_response_pdu(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_response_pdu(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
- guint encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
- guint32 r_uptime;
+ unsigned encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
+ uint32_t r_uptime;
subtree = proto_tree_add_subtree(tree, tvb, offset, len, ett_response, NULL, "Response-PDU");
@@ -472,7 +473,7 @@ dissect_response_pdu(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, int of
}
static void
-dissect_getnext_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_getnext_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -490,7 +491,7 @@ dissect_getnext_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8
}
static void
-dissect_get_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_get_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -508,10 +509,10 @@ dissect_get_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 fla
}
static void
-dissect_getbulk_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_getbulk_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
- guint encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
+ unsigned encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
subtree = proto_tree_add_subtree(tree, tvb, offset, len, ett_getbulk, NULL, "GetBulk-PDU");
@@ -530,14 +531,14 @@ dissect_getbulk_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8
}
static int
-dissect_open_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_open_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
- guint8 timeout;
+ uint8_t timeout;
subtree = proto_tree_add_subtree(tree, tvb, offset, len, ett_open, NULL, "Open-PDU");
- timeout = tvb_get_guint8(tvb, offset);
+ timeout = tvb_get_uint8(tvb, offset);
tvb_get_ntoh24(tvb, offset + 1);
proto_tree_add_uint(subtree, hf_open_timeout, tvb, offset, 1, timeout);
@@ -566,10 +567,10 @@ dissect_close_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len)
static int
-dissect_register_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_register_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
- guint encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
+ unsigned encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
subtree = proto_tree_add_subtree(tree, tvb, offset, len, ett_register, NULL, "Register-PDU");
@@ -598,10 +599,10 @@ dissect_register_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint
static int
-dissect_unregister_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_unregister_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
- guint encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
+ unsigned encoding = (flags & NETWORK_BYTE_ORDER) ? ENC_BIG_ENDIAN : ENC_LITTLE_ENDIAN;
subtree = proto_tree_add_subtree(tree, tvb, offset, len, ett_unregister, NULL, "Unregister-PDU");
@@ -629,7 +630,7 @@ dissect_unregister_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, gui
}
static void
-dissect_testset_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_testset_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -646,7 +647,7 @@ dissect_testset_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8
}
static void
-dissect_notify_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_notify_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -663,7 +664,7 @@ dissect_notify_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8
}
static int
-dissect_ping_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_ping_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -677,7 +678,7 @@ dissect_ping_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 fl
}
static void
-dissect_idx_alloc_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_idx_alloc_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -695,7 +696,7 @@ dissect_idx_alloc_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guin
static void
-dissect_idx_dealloc_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_idx_dealloc_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -712,7 +713,7 @@ dissect_idx_dealloc_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, gu
}
static int
-dissect_add_caps_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_add_caps_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -731,7 +732,7 @@ dissect_add_caps_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint
}
static int
-dissect_rem_caps_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint8 flags)
+dissect_rem_caps_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, uint8_t flags)
{
proto_tree* subtree;
@@ -748,16 +749,16 @@ dissect_rem_caps_pdu(tvbuff_t *tvb, proto_tree *tree, int offset, int len, guint
}
-static guint
+static unsigned
get_agentx_pdu_len(packet_info *pinfo _U_, tvbuff_t *tvb, int offset, void *data _U_)
{
- guint8 flags;
- guint32 plen;
+ uint8_t flags;
+ uint32_t plen;
/*
* Get the payload length.
*/
- flags = tvb_get_guint8(tvb, offset + 2);
+ flags = tvb_get_uint8(tvb, offset + 2);
NORLEL(flags, plen, tvb, offset + 16);
/*
@@ -779,13 +780,13 @@ dissect_agentx_pdu(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* da
int offset = 0;
proto_tree* agentx_tree, *pdu_hdr_tree;
proto_item *t_item;
- guint8 version;
- guint8 type;
- guint8 flags;
- guint32 session_id;
- guint32 trans_id;
- guint32 packet_id;
- guint32 payload_len;
+ uint8_t version;
+ uint8_t type;
+ uint8_t flags;
+ uint32_t session_id;
+ uint32_t trans_id;
+ uint32_t packet_id;
+ uint32_t payload_len;
static int * const pdu_flags[] = {
&hf_flags_register,
&hf_flags_newindex,
@@ -795,9 +796,9 @@ dissect_agentx_pdu(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* da
NULL
};
- version = tvb_get_guint8(tvb, 0); offset+=1;
- type = tvb_get_guint8(tvb, 1); offset+=1;
- flags = tvb_get_guint8(tvb, 2); offset+=1;
+ version = tvb_get_uint8(tvb, 0); offset+=1;
+ type = tvb_get_uint8(tvb, 1); offset+=1;
+ flags = tvb_get_uint8(tvb, 2); offset+=1;
/* skip reserved byte */
offset+=1;
@@ -910,7 +911,7 @@ dissect_agentx_pdu(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* da
static int
dissect_agentx(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void* data)
{
- tcp_dissect_pdus(tvb, pinfo, tree, TRUE, 20, get_agentx_pdu_len,
+ tcp_dissect_pdus(tvb, pinfo, tree, true, 20, get_agentx_pdu_len,
dissect_agentx_pdu, data);
return tvb_captured_length(tvb);
}
@@ -1072,7 +1073,7 @@ proto_register_agentx(void)
};
- static gint *ett[] = {
+ static int *ett[] = {
&ett_agentx,
&ett_pdu_hdr,
&ett_get,