Merge branch 'master' of github.com:floodlight/loxigen
diff --git a/wireshark_gen/templates/_oftype_readers.lua b/wireshark_gen/templates/_oftype_readers.lua
index d80323c..c13c206 100644
--- a/wireshark_gen/templates/_oftype_readers.lua
+++ b/wireshark_gen/templates/_oftype_readers.lua
@@ -45,8 +45,49 @@
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)
- read_scalar(reader, subtree, field_name, 16)
+ 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)