diff options
author | guy <guy@f5534014-38df-0310-8fa8-9805f1628bb7> | 2002-10-23 21:17:03 +0000 |
---|---|---|
committer | guy <guy@f5534014-38df-0310-8fa8-9805f1628bb7> | 2002-10-23 21:17:03 +0000 |
commit | 7bfeb66c5938fb20eaca3ee1f1a0316ddd0252e8 (patch) | |
tree | c89f8870831ade2133bd93de09ca10833fa33f5d /packet-ypserv.c | |
parent | 706a463690ea61bf587034924fd86beba43d136e (diff) |
Add an extra argument to "rpc_init_proc_table()" that can specify an hf_
value for a field to be used for the procedure number for that version
of the protocol; use that field, if specified, instead of just putting
in a generic "rpc.procedure" field.
Have the ypserv dissector register those fields and supply them to
"rpc_init_proc_table()". Supply -1 for other RPC programs (for now),
meaning "no such field exists".
git-svn-id: http://anonsvn.wireshark.org/wireshark/trunk@6486 f5534014-38df-0310-8fa8-9805f1628bb7
Diffstat (limited to 'packet-ypserv.c')
-rw-r--r-- | packet-ypserv.c | 49 |
1 files changed, 45 insertions, 4 deletions
diff --git a/packet-ypserv.c b/packet-ypserv.c index 275cf4e46d..1e0da48821 100644 --- a/packet-ypserv.c +++ b/packet-ypserv.c @@ -1,7 +1,7 @@ /* packet-ypserv.c * Routines for ypserv dissection * - * $Id: packet-ypserv.c,v 1.24 2002/08/28 21:00:40 jmayer Exp $ + * $Id: packet-ypserv.c,v 1.25 2002/10/23 21:17:03 guy Exp $ * * Ethereal - Network traffic analyzer * By Gerald Combs <gerald@ethereal.com> @@ -37,6 +37,8 @@ #include "packet-ypserv.h" static int proto_ypserv = -1; +static int hf_ypserv_procedure_v1 = -1; +static int hf_ypserv_procedure_v2 = -1; static int hf_ypserv_domain = -1; static int hf_ypserv_servesdomain = -1; static int hf_ypserv_map = -1; @@ -319,6 +321,22 @@ dissect_ypresp_maplist(tvbuff_t *tvb, int offset, packet_info *pinfo _U_, proto_ /* NULL as function pointer means: type of arguments is "void". */ /* someone please get me a version 1 trace */ + +static const value_string ypserv1_proc_vals[] = { + { YPPROC_DOMAIN, "DOMAIN" }, + { YPPROC_DOMAIN_NONACK, "DOMAIN_NONACK" }, + { YPPROC_MATCH, "MATCH" }, + { YPPROC_FIRST, "FIRST" }, + { YPPROC_NEXT, "NEXT" }, + { YPPROC_XFR, "XFR" }, + { YPPROC_CLEAR, "CLEAR" }, + { YPPROC_ALL, "ALL" }, + { YPPROC_MASTER, "MASTER" }, + { YPPROC_ORDER, "ORDER" }, + { YPPROC_MAPLIST, "MAPLIST" }, + { 0, NULL } +}; + static const vsff ypserv1_proc[] = { { 0, "NULL", NULL, NULL }, { YPPROC_DOMAIN, "DOMAIN", @@ -345,7 +363,22 @@ static const vsff ypserv1_proc[] = { NULL, NULL }, { 0, NULL, NULL, NULL } }; -/* end of YPServ version 2 */ +/* end of YPServ version 1 */ + +static const value_string ypserv2_proc_vals[] = { + { YPPROC_DOMAIN, "DOMAIN" }, + { YPPROC_DOMAIN_NONACK, "DOMAIN_NONACK" }, + { YPPROC_MATCH, "MATCH" }, + { YPPROC_FIRST, "FIRST" }, + { YPPROC_NEXT, "NEXT" }, + { YPPROC_XFR, "XFR" }, + { YPPROC_CLEAR, "CLEAR" }, + { YPPROC_ALL, "ALL" }, + { YPPROC_MASTER, "MASTER" }, + { YPPROC_ORDER, "ORDER" }, + { YPPROC_MAPLIST, "MAPLIST" }, + { 0, NULL } +}; static const vsff ypserv2_proc[] = { { 0, "NULL", NULL, NULL }, @@ -383,6 +416,12 @@ proto_register_ypserv(void) static struct true_false_string yesno = { "Yes", "No" }; static hf_register_info hf[] = { + { &hf_ypserv_procedure_v1, { + "V1 Procedure", "ypserv.procedure_v1", FT_UINT32, BASE_DEC, + VALS(ypserv1_proc_vals), 0, "V1 Procedure", HFILL }}, + { &hf_ypserv_procedure_v2, { + "V2 Procedure", "ypserv.procedure_v2", FT_UINT32, BASE_DEC, + VALS(ypserv2_proc_vals), 0, "V2 Procedure", HFILL }}, { &hf_ypserv_domain, { "Domain", "ypserv.domain", FT_STRING, BASE_DEC, NULL, 0, "Domain", HFILL }}, @@ -443,6 +482,8 @@ proto_reg_handoff_ypserv(void) /* Register the protocol as RPC */ rpc_init_prog(proto_ypserv, YPSERV_PROGRAM, ett_ypserv); /* Register the procedure tables */ - rpc_init_proc_table(YPSERV_PROGRAM, 1, ypserv1_proc); - rpc_init_proc_table(YPSERV_PROGRAM, 2, ypserv2_proc); + rpc_init_proc_table(YPSERV_PROGRAM, 1, ypserv1_proc, + hf_ypserv_procedure_v1); + rpc_init_proc_table(YPSERV_PROGRAM, 2, ypserv2_proc, + hf_ypserv_procedure_v2); } |