ee2ad21aad4f207da4db02e9a94fd8da39019781
[obnox/wireshark/wip.git] / plugins / docsis / packet-bpkmrsp.c
1 /* packet-bpkmrsp.c
2  * Routines for Baseline Privacy Key Management Response dissection
3  * Copyright 2002, Anand V. Narwani <anand[AT]narwani.org>
4  *
5  * $Id$
6  *
7  * Wireshark - Network traffic analyzer
8  * By Gerald Combs <gerald@wireshark.org>
9  * Copyright 1998 Gerald Combs
10  *
11  * This program is free software; you can redistribute it and/or
12  * modify it under the terms of the GNU General Public License
13  * as published by the Free Software Foundation; either version 2
14  * of the License, or (at your option) any later version.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program; if not, write to the Free Software
23  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24  */
25
26 #ifdef HAVE_CONFIG_H
27 # include "config.h"
28 #endif
29
30 #include "moduleinfo.h"
31
32 #include <stdio.h>
33 #include <stdlib.h>
34 #include <string.h>
35
36 #include <gmodule.h>
37
38 #include <epan/packet.h>
39
40 /* Initialize the protocol and registered fields */
41 static int proto_docsis_bpkmrsp = -1;
42 static int hf_docsis_bpkmrsp = -1;
43 static int hf_docsis_bpkmrsp_code = -1;
44 static int hf_docsis_bpkmrsp_length = -1;
45 static int hf_docsis_bpkmrsp_ident = -1;
46
47 static const value_string code_field_vals[] = {
48   {0, "Reserved"},
49   {1, "Reserved"},
50   {2, "Reserved"},
51   {3, "Reserved"},
52   {4, "Auth Response"},
53   {5, "Auth Reply"},
54   {6, "Auth Reject"},
55   {7, "Key Response"},
56   {8, "Key Reply"},
57   {9, "Key Reject"},
58   {10, "Auth Invalid"},
59   {11, "TEK Invalid"},
60   {12, "Authent Info"},
61   {13, "Map Response"},
62   {14, "Map Reply"},
63   {15, "Map Reject"},
64   {0, NULL},
65 };
66
67
68 /* Initialize the subtree pointers */
69 static gint ett_docsis_bpkmrsp = -1;
70
71 static dissector_handle_t attrs_handle;
72
73 /* Code to actually dissect the packets */
74 static void
75 dissect_bpkmrsp (tvbuff_t * tvb, packet_info * pinfo, proto_tree * tree)
76 {
77
78   proto_item *it;
79   proto_tree *bpkmrsp_tree;
80   guint8 code;
81   tvbuff_t *attrs_tvb;
82
83
84   code = tvb_get_guint8 (tvb, 0);
85
86   if (check_col (pinfo->cinfo, COL_INFO))
87     {
88       col_clear (pinfo->cinfo, COL_INFO);
89       col_add_fstr (pinfo->cinfo, COL_INFO, "BPKM Response (%s)",
90                     val_to_str (code, code_field_vals, "%s"));
91     }
92
93   if (tree)
94     {
95       it =
96         proto_tree_add_protocol_format (tree, proto_docsis_bpkmrsp, tvb, 0, -1,
97                                         "BPKM Response Message");
98       bpkmrsp_tree = proto_item_add_subtree (it, ett_docsis_bpkmrsp);
99       proto_tree_add_item (bpkmrsp_tree, hf_docsis_bpkmrsp_code, tvb, 0, 1,
100                            FALSE);
101       proto_tree_add_item (bpkmrsp_tree, hf_docsis_bpkmrsp_ident, tvb, 1, 1,
102                            FALSE);
103       proto_tree_add_item (bpkmrsp_tree, hf_docsis_bpkmrsp_length, tvb, 2, 2,
104                            FALSE);
105     }
106
107   /* Code to Call subdissector */
108   attrs_tvb = tvb_new_subset (tvb, 4, -1, -1);
109   call_dissector (attrs_handle, attrs_tvb, pinfo, tree);
110
111
112
113 }
114
115
116
117
118 /* Register the protocol with Ethereal */
119
120 /* this format is require because a script is used to build the C function
121    that calls all the protocol registration.
122 */
123
124
125 void
126 proto_register_docsis_bpkmrsp (void)
127 {
128
129 /* Setup list of header fields  See Section 1.6.1 for details*/
130   static hf_register_info hf[] = {
131     {&hf_docsis_bpkmrsp,
132      {"BPKM Response Message", "docsis.bpkmrsp",
133       FT_BYTES, BASE_HEX, NULL, 0x0,
134       "BPKM Response Message", HFILL}
135      },
136     {&hf_docsis_bpkmrsp_code,
137      {"BPKM Code", "docsis.bpkmrsp.code",
138       FT_UINT8, BASE_DEC, VALS (code_field_vals), 0x0,
139       "BPKM Response Message", HFILL}
140      },
141     {&hf_docsis_bpkmrsp_ident,
142      {"BPKM Identifier", "docsis.bpkmrsp.ident",
143       FT_UINT8, BASE_DEC, NULL, 0x0,
144       "BPKM Identifier", HFILL}
145      },
146     {&hf_docsis_bpkmrsp_length,
147      {"BPKM Length", "docsis.bpkmrsp.length",
148       FT_UINT16, BASE_DEC, NULL, 0x0,
149       "BPKM Length", HFILL}
150      },
151   };
152
153 /* Setup protocol subtree array */
154   static gint *ett[] = {
155     &ett_docsis_bpkmrsp,
156   };
157
158 /* Register the protocol name and description */
159   proto_docsis_bpkmrsp =
160     proto_register_protocol
161     ("DOCSIS Baseline Privacy Key Management Response", "DOCSIS BPKM-RSP",
162      "docsis_bpkmrsp");
163
164 /* Required function calls to register the header fields and subtrees used */
165   proto_register_field_array (proto_docsis_bpkmrsp, hf, array_length (hf));
166   proto_register_subtree_array (ett, array_length (ett));
167
168   register_dissector ("docsis_bpkmrsp", dissect_bpkmrsp,
169                       proto_docsis_bpkmrsp);
170 }
171
172
173 /* If this dissector uses sub-dissector registration add a registration routine.
174    This format is required because a script is used to find these routines and
175    create the code that calls these routines.
176 */
177 void
178 proto_reg_handoff_docsis_bpkmrsp (void)
179 {
180   dissector_handle_t docsis_bpkmrsp_handle;
181
182   docsis_bpkmrsp_handle = find_dissector ("docsis_bpkmrsp");
183   attrs_handle = find_dissector ("docsis_bpkmattr");
184   dissector_add ("docsis_mgmt", 0x0D, docsis_bpkmrsp_handle);
185
186 }