blob: bf83de0507d79bd4cf31678042f08a266d09f654 [file] [log] [blame]
Rich Lane7708c182013-10-01 23:27:27 -07001:: # Copyright 2013, Big Switch Networks, Inc.
2:: #
3:: # LoxiGen is licensed under the Eclipse Public License, version 1.0 (EPL), with
4:: # the following special exception:
5:: #
6:: # LOXI Exception
7:: #
8:: # As a special exception to the terms of the EPL, you may distribute libraries
9:: # generated by LoxiGen (LoxiGen Libraries) under the terms of your choice, provided
10:: # that copyright and licensing notices generated by LoxiGen are not altered or removed
11:: # from the LoxiGen Libraries and the notice provided below is (i) included in
12:: # the LoxiGen Libraries, if distributed in source code form and (ii) included in any
13:: # documentation for the LoxiGen Libraries, if distributed in binary form.
14:: #
15:: # Notice: "Copyright 2013, Big Switch Networks, Inc. This library was generated by the LoxiGen Compiler."
16:: #
17:: # You may not use this file except in compliance with the EPL or LOXI Exception. You may obtain
18:: # a copy of the EPL at:
19:: #
20:: # http://www.eclipse.org/legal/epl-v10.html
21:: #
22:: # Unless required by applicable law or agreed to in writing, software
23:: # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
24:: # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
25:: # EPL for the specific language governing permissions and limitations
26:: # under the EPL.
27
28function read_scalar(reader, subtree, field_name, length)
29 subtree:add(fields[field_name], reader.read(length))
30end
31
32function read_uint8_t(reader, version, subtree, field_name)
33 read_scalar(reader, subtree, field_name, 1)
34end
35
36function read_uint16_t(reader, version, subtree, field_name)
37 read_scalar(reader, subtree, field_name, 2)
38end
39
40function read_uint32_t(reader, version, subtree, field_name)
41 read_scalar(reader, subtree, field_name, 4)
42end
43
44function read_uint64_t(reader, version, subtree, field_name)
45 read_scalar(reader, subtree, field_name, 8)
46end
47
Tomasz24d059a2013-12-19 09:29:24 -080048function read_of_bitmap_128_t(reader, version, subtree, field_name)
49 read_scalar(reader, subtree, field_name, 16)
50end
51
Rich Lane7708c182013-10-01 23:27:27 -070052function read_of_octets_t(reader, version, subtree, field_name)
Rich Lane4a868262013-10-02 15:19:44 -070053 if not reader.is_empty() then
54 subtree:add(fields[field_name], reader.read_all())
55 end
Rich Lane7708c182013-10-01 23:27:27 -070056end
57
58function read_list_of_hello_elem_t(reader, version, subtree, field_name)
59 -- TODO
60end
Rich Lanea6e650e2013-10-02 16:30:06 -070061
62function read_of_match_t(reader, version, subtree, field_name)
63 if version == 1 then
Tomasza0dfec02013-12-14 21:51:04 -080064 dissect_of_match_v1_v1(reader, subtree:add("of_match"))
Rich Lanea6e650e2013-10-02 16:30:06 -070065 elseif version == 2 then
Tomasza0dfec02013-12-14 21:51:04 -080066 dissect_of_match_v2_v2(reader, subtree:add("of_match"))
Rich Lanea6e650e2013-10-02 16:30:06 -070067 elseif version >= 3 then
Tomasza0dfec02013-12-14 21:51:04 -080068 dissect_of_match_v3_v3(reader, subtree:add("of_match"))
Rich Lanea6e650e2013-10-02 16:30:06 -070069 end
70end
71
72function read_of_wc_bmap_t(reader, version, subtree, field_name)
73 if version <= 2 then
74 read_scalar(reader, subtree, field_name, 4)
75 else
76 read_scalar(reader, subtree, field_name, 8)
77 end
78end
79
80function read_of_port_no_t(reader, version, subtree, field_name)
81 if version == 1 then
82 read_scalar(reader, subtree, field_name, 2)
83 else
84 read_scalar(reader, subtree, field_name, 4)
85 end
86end
87
Tomaszc595d5b2013-11-02 13:30:32 -070088function read_of_port_name_t(reader, version, subtree, field_name)
89 read_scalar(reader, subtree, field_name, 16)
90end
91
Rich Lanea6e650e2013-10-02 16:30:06 -070092function read_of_mac_addr_t(reader, version, subtree, field_name)
93 read_scalar(reader, subtree, field_name, 6)
94end
95
96function read_of_ipv4_t(reader, version, subtree, field_name)
97 read_scalar(reader, subtree, field_name, 4)
98end
99
Rich Lane5c56c3b2013-10-25 14:39:29 -0700100function read_of_ipv6_t(reader, version, subtree, field_name)
101 read_scalar(reader, subtree, field_name, 16)
102end
103
Rich Lanea6e650e2013-10-02 16:30:06 -0700104function read_of_fm_cmd_t(reader, version, subtree, field_name)
105 if version == 1 then
106 read_scalar(reader, subtree, field_name, 2)
107 else
108 read_scalar(reader, subtree, field_name, 1)
109 end
110end
111
Tomaszc595d5b2013-11-02 13:30:32 -0700112function read_of_desc_str_t(reader, version, subtree, field_name)
113 read_scalar(reader, subtree, field_name, 256)
114end
115
116function read_of_serial_num_t(reader, version, subtree, field_name)
117 read_scalar(reader, subtree, field_name, 32)
Rich Lanea6e650e2013-10-02 16:30:06 -0700118end
Tomasze0584352013-10-23 16:43:26 -0700119
Tomasz359147c2013-12-17 18:34:20 -0800120function read_of_port_desc_t(reader, version, subtree, field_name)
121 if reader.is_empty() then
122 return
123 end
124 local child_subtree = subtree:add(fields[field_name], reader.peek_all(0))
125 local info = of_port_desc_dissectors[version](reader, child_subtree)
126 child_subtree:set_text(info)
127end
128
Tomasza17a6692013-10-30 17:34:18 -0700129function read_of_oxm_t(reader, version, subtree, field_name)
130 if reader.is_empty() then
131 return
132 end
133 local child_subtree = subtree:add(fields[field_name], reader.peek_all(0))
Tomasz2663f4f2013-12-10 05:12:42 -0800134 local info = of_oxm_dissectors[version](reader, child_subtree)
Tomasza17a6692013-10-30 17:34:18 -0700135 child_subtree:set_text(info)
136end
Tomaszabaeac32013-12-16 21:22:13 -0800137
138function read_list(reader, dissector, subtree, field_name)
139 if not reader.is_empty() then
140 local list_subtree = subtree:add(field_name .. " list", reader.peek_all(0))
141 while not reader.is_empty() do
142 local atom_subtree = list_subtree:add(field_name, reader.peek_all(0))
143 local info = dissector(reader, atom_subtree)
144 atom_subtree:set_text(info)
145 end
146 else
147 return
148 end
149end