hm_dissector.lua 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. function HM_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, offset)
  2. local f_sub_mod_id = ProtoField.uint8("TC_TM_PROTOCOL.sub_mod_id", "SUB MODULE ID", base.DEC)
  3. local f_Queue_id = ProtoField.uint8("TC_TM_PROTOCOL.Queue_id", "QUEUE ID", base.DEC)
  4. local f_priority = ProtoField.uint8("TC_TM_PROTOCOL.priority", "PRIORITY", base.DEC)
  5. local f_opt_sel_sin_mul_que = ProtoField.uint8("TC_TM_PROTOCOL.opt_sel_sin_mul_que", "Option To Select Single Or Multiple Queue", base.DEC)
  6. -- Add the fields to the protocol
  7. TC_TM_PROTOCOL.fields = { f_sub_mod_id, f_Queue_id, f_priority, f_opt_sel_sin_mul_que }
  8. --local info_display
  9. local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "HEALTH_METRIC_DATA")
  10. --dissect submodule_id
  11. local data1 = buffer(offset,1):le_uint()
  12. subtree:add(f_sub_mod_id , data1)
  13. offset = offset + 1
  14. --dissect queue_id
  15. local data2 = buffer(offset,1):le_uint()
  16. subtree:add(f_Queue_id, data2)
  17. offset = offset + 1
  18. --dissect f_priority
  19. local data3 = buffer(offset,1):le_uint()
  20. subtree:add(f_priority, data3)
  21. offset = offset + 1
  22. --dissect option to select_single or multiple queue
  23. local data4 = buffer(offset,1):le_uint()
  24. subtree:add(f_opt_sel_sin_mul_que, data4)
  25. --info_display= {data1} --- for info display in wireshark
  26. --pinfo.cols.info ="sub_mod_id" ..info_display[1]
  27. return data1
  28. end
  29. --------------------------------------------------------------------------------------------------------------------------------
  30. function HM_TM_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, len)
  31. local f_sub_mod_id = ProtoField.uint8("TC_TM_PROTOCOL.sub_mod_id", "SUB MODULE ID", base.DEC)
  32. local f_Queue_id = ProtoField.uint8("TC_TM_PROTOCOL.Queue_id", "QUEUE ID", base.DEC)
  33. local f_num_of_instance = ProtoField.uint16("TC_TM_PROTOCOL.num_of_instance", "Number of Instance", base.DEC)
  34. local f_Health_Data = ProtoField.uint8("TC_TM_PROTOCOL.Health_Data", "Health Data", base.DEC)
  35. -- Add the fields to the protocol
  36. TC_TM_PROTOCOL.fields = { f_sub_mod_id, f_Queue_id, f_num_of_instance, f_Health_Data }
  37. --local info_display
  38. local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "HEALTH_METRIC_DATA")
  39. --dissect submodule_id
  40. local data1 = buffer(offset,1):le_uint()
  41. subtree:add(f_sub_mod_id , data1)
  42. offset = offset + 1
  43. --dissect queue_id
  44. local data2 = buffer(offset,1):le_uint()
  45. subtree:add(f_Queue_id, data2)
  46. offset = offset + 1
  47. --dissect f_num_of_instance
  48. local data3 = buffer(offset,2):le_uint()
  49. subtree:add(f_num_of_instance, data3)
  50. offset = offset + 2
  51. local array1
  52. --dissect Health_Data
  53. if data1 == 0 then
  54. require("eps_dissector")
  55. dissect_power_system_data(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
  56. end
  57. if data1 == 3 then
  58. require("uhf_dissector")
  59. UHF_DISSECTOR(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
  60. end
  61. local array = {data1, data2, data3,array1}
  62. return array
  63. end