blob: 586bbbf1143a808355d61055088b1701f0e61cb5 [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
48function read_of_octets_t(reader, version, subtree, field_name)
Rich Lane4a868262013-10-02 15:19:44 -070049 if not reader.is_empty() then
50 subtree:add(fields[field_name], reader.read_all())
51 end
Rich Lane7708c182013-10-01 23:27:27 -070052end
53
54function read_list_of_hello_elem_t(reader, version, subtree, field_name)
55 -- TODO
56end
Rich Lanea6e650e2013-10-02 16:30:06 -070057
58function read_of_match_t(reader, version, subtree, field_name)
59 if version == 1 then
Tomasza0dfec02013-12-14 21:51:04 -080060 dissect_of_match_v1_v1(reader, subtree:add("of_match"))
Rich Lanea6e650e2013-10-02 16:30:06 -070061 elseif version == 2 then
Tomasza0dfec02013-12-14 21:51:04 -080062 dissect_of_match_v2_v2(reader, subtree:add("of_match"))
Rich Lanea6e650e2013-10-02 16:30:06 -070063 elseif version >= 3 then
Tomasza0dfec02013-12-14 21:51:04 -080064 dissect_of_match_v3_v3(reader, subtree:add("of_match"))
Rich Lanea6e650e2013-10-02 16:30:06 -070065 end
66end
67
68function read_of_wc_bmap_t(reader, version, subtree, field_name)
69 if version <= 2 then
70 read_scalar(reader, subtree, field_name, 4)
71 else
72 read_scalar(reader, subtree, field_name, 8)
73 end
74end
75
76function read_of_port_no_t(reader, version, subtree, field_name)
77 if version == 1 then
78 read_scalar(reader, subtree, field_name, 2)
79 else
80 read_scalar(reader, subtree, field_name, 4)
81 end
82end
83
Tomaszc595d5b2013-11-02 13:30:32 -070084function read_of_port_name_t(reader, version, subtree, field_name)
85 read_scalar(reader, subtree, field_name, 16)
86end
87
Rich Lanea6e650e2013-10-02 16:30:06 -070088function read_of_mac_addr_t(reader, version, subtree, field_name)
89 read_scalar(reader, subtree, field_name, 6)
90end
91
92function read_of_ipv4_t(reader, version, subtree, field_name)
93 read_scalar(reader, subtree, field_name, 4)
94end
95
Rich Lane5c56c3b2013-10-25 14:39:29 -070096function read_of_ipv6_t(reader, version, subtree, field_name)
97 read_scalar(reader, subtree, field_name, 16)
98end
99
Rich Lanea6e650e2013-10-02 16:30:06 -0700100function read_of_fm_cmd_t(reader, version, subtree, field_name)
101 if version == 1 then
102 read_scalar(reader, subtree, field_name, 2)
103 else
104 read_scalar(reader, subtree, field_name, 1)
105 end
106end
107
Tomaszc595d5b2013-11-02 13:30:32 -0700108function read_of_desc_str_t(reader, version, subtree, field_name)
109 read_scalar(reader, subtree, field_name, 256)
110end
111
112function read_of_serial_num_t(reader, version, subtree, field_name)
113 read_scalar(reader, subtree, field_name, 32)
Rich Lanea6e650e2013-10-02 16:30:06 -0700114end
Tomasze0584352013-10-23 16:43:26 -0700115
Tomasza17a6692013-10-30 17:34:18 -0700116function read_of_oxm_t(reader, version, subtree, field_name)
117 if reader.is_empty() then
118 return
119 end
120 local child_subtree = subtree:add(fields[field_name], reader.peek_all(0))
Tomasz2663f4f2013-12-10 05:12:42 -0800121 local info = of_oxm_dissectors[version](reader, child_subtree)
Tomasza17a6692013-10-30 17:34:18 -0700122 child_subtree:set_text(info)
123end
Tomaszabaeac32013-12-16 21:22:13 -0800124
125function read_list(reader, dissector, subtree, field_name)
126 if not reader.is_empty() then
127 local list_subtree = subtree:add(field_name .. " list", reader.peek_all(0))
128 while not reader.is_empty() do
129 local atom_subtree = list_subtree:add(field_name, reader.peek_all(0))
130 local info = dissector(reader, atom_subtree)
131 atom_subtree:set_text(info)
132 end
133 else
134 return
135 end
136end