aboutsummaryrefslogtreecommitdiffstats
path: root/epan/dissectors/packet-glusterfs_hndsk.c
diff options
context:
space:
mode:
authorPascal Quantin <pascal.quantin@gmail.com>2012-06-03 17:15:21 +0000
committerPascal Quantin <pascal.quantin@gmail.com>2012-06-03 17:15:21 +0000
commit6a4606b1f14c3769d6fc7bd70fcf4af2251c40f4 (patch)
treed8cea71769dbd3ab0c27d500652b74fe8c8a41c0 /epan/dissectors/packet-glusterfs_hndsk.c
parent1c03669611cc7de5527bcbb97d1cab8c762bc3c0 (diff)
From Niels de Vos via https://bugs.wireshark.org/bugzilla/show_bug.cgi?id=7324 :
Add support for the Gluster Handshake and Callback RPC-protocols svn path=/trunk/; revision=43035
Diffstat (limited to 'epan/dissectors/packet-glusterfs_hndsk.c')
-rw-r--r--epan/dissectors/packet-glusterfs_hndsk.c338
1 files changed, 338 insertions, 0 deletions
diff --git a/epan/dissectors/packet-glusterfs_hndsk.c b/epan/dissectors/packet-glusterfs_hndsk.c
new file mode 100644
index 0000000000..4ff3e841e9
--- /dev/null
+++ b/epan/dissectors/packet-glusterfs_hndsk.c
@@ -0,0 +1,338 @@
+/* packet-gluster_hndsk.c
+ * Routines for GlusterFS Handshake dissection
+ * Copyright 2012, Niels de Vos <ndevos@redhat.com>
+ *
+ * $Id$
+ *
+ * Wireshark - Network traffic analyzer
+ * By Gerald Combs <gerald@wireshark.org>
+ * Copyright 1998 Gerald Combs
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ *
+ *
+ * References to source files point in general to the glusterfs sources.
+ * There is currently no RFC or other document where the protocol is
+ * completely described. The glusterfs sources can be found at:
+ * - http://git.gluster.com/?p=glusterfs.git
+ * - https://github.com/gluster/glusterfs
+ *
+ * The coding-style is roughly the same as the one use in the Linux kernel,
+ * see http://www.kernel.org/doc/Documentation/CodingStyle.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <glib.h>
+#include <string.h>
+#include <epan/packet.h>
+#include <epan/tfs.h>
+
+#include "packet-rpc.h"
+#include "packet-gluster.h"
+
+/* Initialize the protocol and registered fields */
+static gint proto_gluster_cbk = -1;
+static gint proto_gluster_hndsk = -1;
+
+/* programs and procedures */
+static gint hf_gluster_cbk_proc = -1;
+static gint hf_gluster_hndsk_proc = -1;
+static gint hf_gluster_hndsk_dict = -1;
+static gint hf_gluster_hndsk_spec = -1; /* GETSPEC Reply */
+static gint hf_gluster_hndsk_key = -1; /* GETSPEC Call */
+static gint hf_gluster_hndsk_event_op = -1; /* EVENT NOTIFY call */
+static gint hf_gluster_hndsk_uid = -1; /* LOCK VERSION*/
+static gint hf_gluster_hndsk_lk_ver= -1;
+static gint hf_gluster_hndsk_flags = -1;
+
+/* Initialize the subtree pointers */
+static gint ett_gluster_cbk = -1;
+static gint ett_gluster_hndsk = -1;
+
+/* procedures for GLUSTER_HNDSK_PROGRAM */
+static int
+gluster_hndsk_setvolume_reply(tvbuff_t *tvb, int offset, packet_info *pinfo,
+ proto_tree *tree)
+{
+ offset = gluster_dissect_common_reply(tvb, offset, pinfo, tree);
+ offset = gluster_rpc_dissect_dict(tree, tvb, hf_gluster_hndsk_dict,
+ offset);
+ return offset;
+}
+
+static int
+gluster_hndsk_setvolume_call(tvbuff_t *tvb, int offset,
+ packet_info *pinfo _U_, proto_tree *tree)
+{
+ offset = gluster_rpc_dissect_dict(tree, tvb, hf_gluster_hndsk_dict,
+ offset);
+ return offset;
+}
+
+static int
+gluster_hndsk_2_setvolume_reply(tvbuff_t *tvb, int offset, packet_info *pinfo,
+ proto_tree *tree)
+{
+ offset = gluster_dissect_common_reply(tvb, offset, pinfo, tree);
+ offset = gluster_rpc_dissect_dict(tree, tvb, hf_gluster_hndsk_dict,
+ offset);
+ return offset;
+}
+
+static int
+gluster_hndsk_2_setvolume_call(tvbuff_t *tvb, int offset,
+ packet_info *pinfo _U_, proto_tree *tree)
+{
+ offset = gluster_rpc_dissect_dict(tree, tvb, hf_gluster_hndsk_dict,
+ offset);
+ return offset;
+}
+
+static int
+gluster_hndsk_2_getspec_reply(tvbuff_t *tvb, int offset, packet_info *pinfo,
+ proto_tree *tree)
+{
+ gchar* spec = NULL;
+ offset = gluster_dissect_common_reply(tvb, offset, pinfo, tree);
+ offset = dissect_rpc_string(tvb, tree, hf_gluster_hndsk_spec, offset,
+ &spec);
+ offset = gluster_rpc_dissect_dict(tree, tvb, hf_gluster_hndsk_dict,
+ offset);
+ return offset;
+}
+
+static int
+gluster_hndsk_2_getspec_call(tvbuff_t *tvb, int offset,
+ packet_info *pinfo _U_, proto_tree *tree)
+{
+ gchar *key = NULL;
+
+ if (tree)
+ proto_tree_add_item(tree, hf_gluster_hndsk_flags, tvb, offset,
+ 4, ENC_NA);
+ offset += 4;
+ offset = dissect_rpc_string(tvb, tree, hf_gluster_hndsk_key, offset,
+ &key);
+ offset = gluster_rpc_dissect_dict(tree, tvb, hf_gluster_hndsk_dict,
+ offset);
+ return offset;
+}
+
+static int
+gluster_hndsk_2_set_lk_ver_reply(tvbuff_t *tvb, int offset, packet_info *pinfo,
+ proto_tree *tree)
+{
+ offset = gluster_dissect_common_reply(tvb, offset, pinfo, tree);
+ offset = dissect_rpc_uint32(tvb, tree,hf_gluster_hndsk_lk_ver, offset);
+ return offset;
+}
+
+static int
+gluster_hndsk_2_set_lk_ver_call(tvbuff_t *tvb, int offset,
+ packet_info *pinfo _U_, proto_tree *tree)
+{
+ gchar* uid = NULL;
+ offset = dissect_rpc_string(tvb, tree, hf_gluster_hndsk_uid, offset,
+ &uid);
+ offset = dissect_rpc_uint32(tvb, tree,hf_gluster_hndsk_lk_ver, offset);
+ return offset;
+}
+
+static int
+gluster_hndsk_2_event_notify_call(tvbuff_t *tvb, int offset,
+ packet_info *pinfo _U_, proto_tree *tree)
+{
+ offset = dissect_rpc_uint32(tvb, tree, hf_gluster_hndsk_event_op,
+ offset);
+ offset = gluster_rpc_dissect_dict(tree, tvb, hf_gluster_hndsk_dict,
+ offset);
+ return offset;
+}
+
+/* In rpc/xdr/src/glusterfs3-xdr.c. xdr_gf_event_notify_rsp */
+
+static int
+gluster_hndsk_2_event_notify_reply(tvbuff_t *tvb, int offset,
+ packet_info *pinfo, proto_tree *tree)
+{
+ offset = gluster_dissect_common_reply(tvb, offset, pinfo, tree);
+ offset = gluster_rpc_dissect_dict(tree, tvb, hf_gluster_hndsk_dict,
+ offset);
+ return offset;
+}
+
+static const vsff gluster_hndsk_proc[] = {
+ { GF_HNDSK_NULL, "NULL", NULL, NULL },
+ {
+ GF_HNDSK_SETVOLUME, "SETVOLUME",
+ gluster_hndsk_setvolume_call, gluster_hndsk_setvolume_reply
+ },
+ { GF_HNDSK_GETSPEC, "GETSPEC", NULL, NULL },
+ { GF_HNDSK_PING, "PING", NULL, gluster_dissect_common_reply },
+ { 0, NULL, NULL, NULL }
+};
+
+static const vsff gluster_hndsk_2_proc[] = {
+ { GF_HNDSK_NULL, "NULL", NULL, NULL },
+ {
+ GF_HNDSK_SETVOLUME, "SETVOLUME",
+ gluster_hndsk_2_setvolume_call, gluster_hndsk_2_setvolume_reply
+ },
+ {
+ GF_HNDSK_GETSPEC, "GETSPEC",
+ gluster_hndsk_2_getspec_call, gluster_hndsk_2_getspec_reply
+ },
+ { GF_HNDSK_PING, "PING", NULL, gluster_dissect_common_reply },
+ {
+ GF_HNDSK_SET_LK_VER,"LOCK VERSION",
+ gluster_hndsk_2_set_lk_ver_call, gluster_hndsk_2_set_lk_ver_reply
+ },
+ {
+ GF_HNDSK_EVENT_NOTIFY, "EVENTNOTIFY",
+ gluster_hndsk_2_event_notify_call,
+ gluster_hndsk_2_event_notify_reply
+ },
+ { 0, NULL, NULL, NULL }
+};
+
+
+static const value_string gluster_hndsk_proc_vals[] = {
+ { GF_HNDSK_NULL, "NULL" },
+ { GF_HNDSK_SETVOLUME, "DUMP" },
+ { GF_HNDSK_GETSPEC, "GETSPEC" },
+ { GF_HNDSK_PING, "PING" },
+ { GF_HNDSK_SET_LK_VER,"LOCK VERSION" },
+ { GF_HNDSK_EVENT_NOTIFY, "EVENTNOTIFY" },
+ { 0, NULL }
+};
+
+void
+proto_register_gluster_hndsk(void)
+{
+ static hf_register_info hf[] = {
+ { &hf_gluster_hndsk_proc,
+ { "GlusterFS Handshake", "glusterfs.hndsk.proc",
+ FT_UINT32, BASE_DEC,
+ VALS(gluster_hndsk_proc_vals), 0, NULL, HFILL }
+ },
+ /* fields used by Gluster Handshake */
+ { &hf_gluster_hndsk_dict,
+ { "Dict", "glusterfs.hndsk.dict", FT_STRING, BASE_NONE,
+ NULL, 0, NULL, HFILL }
+ },
+ /* For Gluster handshake event notify */
+ { &hf_gluster_hndsk_event_op,
+ { "Event Op", "glusterfs.hndsk.event_notify_op",
+ FT_UINT32, BASE_DEC, NULL, 0, NULL, HFILL }
+ },
+ { &hf_gluster_hndsk_key,
+ { "Key", "glusterfs.hndsk.getspec.key", FT_STRING,
+ BASE_NONE, NULL, 0, NULL, HFILL }
+ },
+ { &hf_gluster_hndsk_spec,
+ /* FIXME: rename spec to something clearer */
+ { "Spec", "glusterfs.hndsk.getspec", FT_STRING,
+ BASE_NONE, NULL, 0, NULL, HFILL }
+ },
+ /* For hand shake set_lk_ver */
+ { &hf_gluster_hndsk_uid,
+ { "Name", "glusterfs.hndsk.uid", FT_STRING, BASE_NONE,
+ NULL, 0, NULL, HFILL }
+ },
+ { &hf_gluster_hndsk_lk_ver,
+ { "Event Op", "glusterfs.hndsk.lk_ver", FT_UINT32,
+ BASE_DEC, NULL, 0, NULL, HFILL }
+ },
+ { &hf_gluster_hndsk_flags,
+ { "Flags", "glusterfs.hndsk.flags", FT_UINT32, BASE_OCT,
+ NULL, 0, NULL, HFILL }
+ }
+ };
+
+ /* Setup protocol subtree array */
+ static gint *ett[] = {
+ &ett_gluster_hndsk
+ };
+
+ /* Register the protocol name and description */
+ proto_gluster_hndsk = proto_register_protocol("GlusterFS Handshake",
+ "GlusterFS Handshake",
+ "glusterfs.hndsk");
+ proto_register_subtree_array(ett, array_length(ett));
+ proto_register_field_array(proto_gluster_hndsk, hf, array_length(hf));
+
+}
+
+void
+proto_reg_handoff_gluster_hndsk(void)
+{
+ rpc_init_prog(proto_gluster_hndsk, GLUSTER_HNDSK_PROGRAM,
+ ett_gluster_hndsk);
+ rpc_init_proc_table(GLUSTER_HNDSK_PROGRAM, 1, gluster_hndsk_proc,
+ hf_gluster_hndsk_proc);
+ rpc_init_proc_table(GLUSTER_HNDSK_PROGRAM, 2, gluster_hndsk_2_proc,
+ hf_gluster_hndsk_proc);
+}
+
+/* Legacy GlusterFS Callback procedures, they don't contain any data. */
+static const vsff gluster_cbk_proc[] = {
+ { GF_CBK_NULL, "NULL", NULL, NULL },
+ { GF_CBK_FETCHSPEC, "FETCHSPEC", NULL, NULL },
+ { GF_CBK_INO_FLUSH, "INO_FLUSH", NULL, NULL },
+ { 0, NULL, NULL, NULL }
+};
+static const value_string gluster_cbk_proc_vals[] = {
+ { GF_CBK_NULL, "NULL" },
+ { GF_CBK_FETCHSPEC, "FETCHSPEC" },
+ { GF_CBK_INO_FLUSH, "INO_FLUSH" },
+ { 0, NULL }
+};
+
+void
+proto_register_gluster_cbk(void)
+{
+ /* Setup list of header fields See Section 1.6.1 for details */
+ static hf_register_info hf[] = {
+ /* programs */
+ { &hf_gluster_cbk_proc,
+ { "GlusterFS Callback", "glusterfs.cbk.proc",
+ FT_UINT32, BASE_DEC,
+ VALS(gluster_cbk_proc_vals), 0, NULL, HFILL }
+ }
+ };
+
+ /* Setup protocol subtree array */
+ static gint *ett[] = {
+ &ett_gluster_cbk
+ };
+
+ /* Register the protocol name and description */
+ proto_gluster_cbk = proto_register_protocol("GlusterFS Callback",
+ "GlusterFS Callback", "glusterfs.cbk");
+ proto_register_subtree_array(ett, array_length(ett));
+ proto_register_field_array(proto_gluster_cbk, hf, array_length(hf));
+}
+
+void
+proto_reg_handoff_gluster_cbk(void)
+{
+ rpc_init_prog(proto_gluster_cbk, GLUSTER_CBK_PROGRAM, ett_gluster_cbk);
+ rpc_init_proc_table(GLUSTER_CBK_PROGRAM, 1, gluster_cbk_proc,
+ hf_gluster_cbk_proc);
+}
+