blob: f389de4cc9b9eb3a58b68cd1ebb274a108488938 [file] [log] [blame]
:: # Copyright 2013, Big Switch Networks, Inc.
:: #
:: # LoxiGen is licensed under the Eclipse Public License, version 1.0 (EPL), with
:: # the following special exception:
:: #
:: # LOXI Exception
:: #
:: # As a special exception to the terms of the EPL, you may distribute libraries
:: # generated by LoxiGen (LoxiGen Libraries) under the terms of your choice, provided
:: # that copyright and licensing notices generated by LoxiGen are not altered or removed
:: # from the LoxiGen Libraries and the notice provided below is (i) included in
:: # the LoxiGen Libraries, if distributed in source code form and (ii) included in any
:: # documentation for the LoxiGen Libraries, if distributed in binary form.
:: #
:: # Notice: "Copyright 2013, Big Switch Networks, Inc. This library was generated by the LoxiGen Compiler."
:: #
:: # You may not use this file except in compliance with the EPL or LOXI Exception. You may obtain
:: # a copy of the EPL at:
:: #
:: # http://www.eclipse.org/legal/epl-v10.html
:: #
:: # Unless required by applicable law or agreed to in writing, software
:: # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
:: # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
:: # EPL for the specific language governing permissions and limitations
:: # under the EPL.
function read_scalar(reader, subtree, field_name, length)
subtree:add(fields[field_name], reader.read(length))
end
function read_uint8_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 1)
end
function read_uint16_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 2)
end
function read_uint32_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 4)
end
function read_uint64_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 8)
end
local hex2bin_tab = {
["0"] = "0000",
["1"] = "0001",
["2"] = "0010",
["3"] = "0011",
["4"] = "0100",
["5"] = "0101",
["6"] = "0110",
["7"] = "0111",
["8"] = "1000",
["9"] = "1001",
["a"] = "1010",
["b"] = "1011",
["c"] = "1100",
["d"] = "1101",
["e"] = "1110",
["f"] = "1111"
}
function hex2bin(str)
local bin = ''
for byte in string.gmatch(tostring(str), '%x') do
bin = bin .. hex2bin_tab[byte]
end
return bin
end
function read_of_bitmap_128_t(reader, version, subtree, field_name)
if string.match(field_name, 'value_mask') then
local masked_ports = ''
local bitmap_string = hex2bin(reader.read(16))
local len = string.len(bitmap_string)
i = len
while i > 0 do
if string.sub(bitmap_string, i, i) == '0' then
masked_ports = masked_ports .. tostring(len - i) .. ' '
end
i = i - 1
end
subtree:add("masked_ports:", masked_ports)
else
subtree:add(fields[field_name], reader.read(16))
end
end
function read_of_checksum_128_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 16)
end
function read_of_octets_t(reader, version, subtree, field_name)
if not reader.is_empty() then
subtree:add(fields[field_name], reader.read_all())
end
end
function read_list_of_hello_elem_t(reader, version, subtree, field_name)
-- TODO
end
function read_of_match_t(reader, version, subtree, field_name)
if version == 1 then
dissect_of_match_v1_v1(reader, subtree:add("of_match"))
elseif version == 2 then
dissect_of_match_v2_v2(reader, subtree:add("of_match"))
elseif version >= 3 then
dissect_of_match_v3_v3(reader, subtree:add("of_match"))
end
end
function read_of_wc_bmap_t(reader, version, subtree, field_name)
if version <= 2 then
read_scalar(reader, subtree, field_name, 4)
else
read_scalar(reader, subtree, field_name, 8)
end
end
function read_of_port_no_t(reader, version, subtree, field_name)
if version == 1 then
read_scalar(reader, subtree, field_name, 2)
else
read_scalar(reader, subtree, field_name, 4)
end
end
function read_of_port_name_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 16)
end
function read_of_mac_addr_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 6)
end
function read_of_ipv4_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 4)
end
function read_of_ipv6_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 16)
end
function read_of_fm_cmd_t(reader, version, subtree, field_name)
if version == 1 then
read_scalar(reader, subtree, field_name, 2)
else
read_scalar(reader, subtree, field_name, 1)
end
end
function read_of_desc_str_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 256)
end
function read_of_serial_num_t(reader, version, subtree, field_name)
read_scalar(reader, subtree, field_name, 32)
end
function read_of_port_desc_t(reader, version, subtree, field_name)
if reader.is_empty() then
return
end
local child_subtree = subtree:add(fields[field_name], reader.peek_all(0))
local info = of_port_desc_dissectors[version](reader, child_subtree)
child_subtree:set_text(info)
end
function read_of_oxm_t(reader, version, subtree, field_name)
if reader.is_empty() then
return
end
local child_subtree = subtree:add(fields[field_name], reader.peek_all(0))
local info = of_oxm_dissectors[version](reader, child_subtree)
child_subtree:set_text(info)
end
function read_list(reader, dissector, subtree, field_name)
if not reader.is_empty() then
local list_subtree = subtree:add(field_name .. " list", reader.peek_all(0))
while not reader.is_empty() do
local atom_subtree = list_subtree:add(field_name, reader.peek_all(0))
local info = dissector(reader, atom_subtree)
atom_subtree:set_text(info)
end
else
return
end
end
function read_ethernet(reader, version, subtree, field_name)
if reader.is_empty() then
return
end
local child_subtree = subtree:add(fields[field_name], reader.peek_all(0))
child_subtree:set_text("Ethernet packet")
ethernet_dissector:call(reader.read_all():tvb(), current_pkt, child_subtree)
end