sband_dissector.lua 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. -- Your function definition begins here
  2. function sband_dissectors(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, instance)
  3. -- Define ProtoFields for s_sband_cmn_tm
  4. local f_timestamp2 = ProtoField.uint64("TC_TM_PROTOCOL.timestamp2", "Timestamp", base.DEC)
  5. local f_temp_mcu = ProtoField.uint32("TC_TM_PROTOCOL.temp_mcu", "Temp MCU", base.DEC)
  6. local f_temp_fpga = ProtoField.uint32("TC_TM_PROTOCOL.temp_fpga", "Temp FPGA", base.DEC)
  7. local f_temp_xcvr = ProtoField.uint32("TC_TM_PROTOCOL.temp_xcvr", "Temp XCVR", base.DEC)
  8. local f_volt_vint = ProtoField.double("TC_TM_PROTOCOL.volt_vint", "Volt Vint", base.DEC)
  9. local f_volt_vaux = ProtoField.double("TC_TM_PROTOCOL.volt_vaux", "Volt Vaux", base.DEC)
  10. local f_volt_vbram = ProtoField.double("TC_TM_PROTOCOL.volt_vbram", "Volt Vbram", base.DEC)
  11. local f_volt_vpint = ProtoField.double("TC_TM_PROTOCOL.volt_vpint", "Volt Vpint", base.DEC)
  12. local f_volt_vpaux = ProtoField.double("TC_TM_PROTOCOL.volt_vpaux", "Volt Vpaux", base.DEC)
  13. local f_volt_vpdro = ProtoField.double("TC_TM_PROTOCOL.volt_vpdro", "Volt Vpdro", base.DEC)
  14. --local f_resv_chnl = ProtoField.uint8("TC_TM_PROTOCOL.resv_cgnl", "resvchnl", base.DEC)
  15. -- Define ProtoFields for s_sband_rx_tm
  16. local f_rx_cfg_frames = ProtoField.uint32("TC_TM_PROTOCOL.rx_cfg_frames", "RX Config Frames", base.DEC)
  17. local f_rx_cfg_detected = ProtoField.uint32("TC_TM_PROTOCOL.rx_cfg_detected", "RX Config Detected", base.DEC)
  18. local f_rx_cfg_rssi = ProtoField.float("TC_TM_PROTOCOL.rx_cfg_rssi", "RX Config RSSI", base.DEC)
  19. local f_rx_avg_rssi = ProtoField.float("TC_TM_PROTOCOL.rx_avg_rssi", "RX Average RSSI", base.DEC)
  20. local f_rx_cfg_freqerr = ProtoField.int32("TC_TM_PROTOCOL.rx_cfg_freqerr", "RX Config Frequency Error", base.DEC)
  21. local f_rx_cfg_carrier_lock = ProtoField.uint32("TC_TM_PROTOCOL.rx_cfg_carrier_lock", "RX Carrier Lock", base.DEC)
  22. local f_rx_frame_lock = ProtoField.uint32("TC_TM_PROTOCOL.rx_frame_lock", "RX Frame Lock", base.DEC)
  23. local f_rx_sir_min = ProtoField.uint32("TC_TM_PROTOCOL.rx_sir_min", "RX SIR Min", base.DEC)
  24. local f_rx_sir_max = ProtoField.uint32("TC_TM_PROTOCOL.rx_sir_max", "RX SIR Max", base.DEC)
  25. local f_rx_bch_block_cnt = ProtoField.uint32("TC_TM_PROTOCOL.rx_bch_block_cnt", "RX BCH Block Count", base.DEC)
  26. local f_rx_bch_err_cnt = ProtoField.uint32("TC_TM_PROTOCOL.rx_bch_err_cnt", "RX BCH Error Count", base.DEC)
  27. -- Define ProtoFields for s_sband_tx_tm
  28. local f_tx_cfg_frames = ProtoField.uint32("TC_TM_PROTOCOL.tx_cfg_frames", "TX Config Frames", base.DEC)
  29. local f_tx_cfg_pwr_rfl = ProtoField.float("TC_TM_PROTOCOL.tx_cfg_pwr_rfl", "TX Power RFL", base.DEC)
  30. -- For the main s_sband_periodic_tm structure
  31. --local f_cmn_tm = ProtoField.bytes("TC_TM_PROTOCOL.cmn_tm", "Common Time", base.HEX)
  32. --local f_rx_tm = ProtoField.bytes("TC_TM_PROTOCOL.rx_tm", "RX Time", base.HEX)
  33. --local f_tx_tm = ProtoField.bytes("TC_TM_PROTOCOL.tx_tm", "TX Time", base.HEX)
  34. -- Add all fields to the protocol
  35. TC_TM_PROTOCOL.fields = {
  36. f_timestamp2, f_temp_mcu, f_temp_fpga, f_temp_xcvr, f_volt_vint, f_volt_vaux, f_volt_vbram, f_volt_vpint,
  37. f_volt_vpaux, f_volt_vpdro,
  38. f_rx_cfg_frames, f_rx_cfg_detected, f_rx_cfg_rssi, f_rx_avg_rssi, f_rx_cfg_freqerr,
  39. f_rx_cfg_carrier_lock, f_rx_frame_lock, f_rx_sir_min, f_rx_sir_max, f_rx_bch_block_cnt, f_rx_bch_err_cnt,
  40. f_tx_cfg_frames, f_tx_cfg_pwr_rfl
  41. }
  42. -- Now the loop for iterating over instances
  43. for i = 0, instance - 1 do
  44. local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "HEALTH METRIC DATA SBAND")
  45. -- Offset for the different structs in s_sband_periodic_tm
  46. -- Dissect the s_sband_cmn_tm structure
  47. subtree:add(f_timestamp2, buffer(offset, 8):le_uint64())
  48. offset = offset + 8
  49. subtree:add(f_temp_mcu, buffer(offset, 4):le_uint()) -- 4 bytes for int32
  50. offset = offset + 4
  51. subtree:add(f_temp_fpga, buffer(offset, 4):le_uint()) -- 4 bytes for int32
  52. offset = offset + 4
  53. subtree:add(f_temp_xcvr, buffer(offset, 4):le_uint()) -- 4 bytes for int32
  54. offset = offset + 4
  55. local data = buffer(offset, 4):le_uint() -- First 4 bytes for z_vel
  56. local data1 = buffer(offset + 4, 4):le_uint() -- Next 4 bytes for z_vel
  57. local data3 = string.unpack("d", string.pack("<II", data1, data))
  58. subtree:add(f_volt_vint, data3 )
  59. offset = offset + 8
  60. data = buffer(offset, 4):le_uint() -- First 4 bytes for z_vel
  61. data1 = buffer(offset + 4, 4):le_uint() -- Next 4 bytes for z_vel
  62. data3 = string.unpack("d", string.pack("<II", data1, data))
  63. subtree:add(f_volt_vaux, data3 )
  64. offset = offset + 8
  65. data = buffer(offset, 4):le_uint() -- First 4 bytes for z_vel
  66. data1 = buffer(offset + 4, 4):le_uint() -- Next 4 bytes for z_vel
  67. data3 = string.unpack("d", string.pack("<II", data1, data))
  68. subtree:add(f_volt_vbram, data3 )
  69. offset = offset + 8
  70. data = buffer(offset, 4):le_uint() -- First 4 bytes for z_vel
  71. data1 = buffer(offset + 4, 4):le_uint() -- Next 4 bytes for z_vel
  72. data3 = string.unpack("d", string.pack("<II", data1, data))
  73. subtree:add(f_volt_vpint, data3 )
  74. offset = offset + 8
  75. data = buffer(offset, 4):le_uint() -- First 4 bytes for z_vel
  76. data1 = buffer(offset + 4, 4):le_uint() -- Next 4 bytes for z_vel
  77. data3 = string.unpack("d", string.pack("<II", data1, data))
  78. subtree:add(f_volt_vpaux, data3 )
  79. offset = offset + 8
  80. data = buffer(offset, 4):le_uint() -- First 4 bytes for z_vel
  81. data1 = buffer(offset + 4, 4):le_uint() -- Next 4 bytes for z_vel
  82. data3 = string.unpack("d", string.pack("<II", data1, data))
  83. subtree:add(f_volt_vpdro, data3 )
  84. offset = offset + 8
  85. -- Dissect the s_sband_rx_tm structure
  86. -- Handle the RX structure
  87. print("Recv chnl : 1")
  88. subtree:add(f_rx_cfg_frames, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  89. offset = offset + 4
  90. subtree:add(f_rx_cfg_detected, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  91. offset = offset + 4
  92. subtree:add(f_rx_cfg_rssi, buffer(offset, 4):le_float()) -- 4 bytes for float (f32)
  93. offset = offset + 4
  94. subtree:add(f_rx_avg_rssi, buffer(offset, 4):le_float()) -- 4 bytes for float (f32)
  95. offset = offset + 4
  96. subtree:add(f_rx_cfg_freqerr, buffer(offset, 4):le_uint()) -- 4 bytes for int32
  97. offset = offset + 4
  98. subtree:add(f_rx_cfg_carrier_lock, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  99. offset = offset + 4
  100. subtree:add(f_rx_frame_lock, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  101. offset = offset + 4
  102. subtree:add(f_rx_sir_min, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  103. offset = offset + 4
  104. subtree:add(f_rx_sir_max, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  105. offset = offset + 4
  106. subtree:add(f_rx_bch_block_cnt, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  107. offset = offset + 4
  108. subtree:add(f_rx_bch_err_cnt, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  109. offset = offset + 4
  110. --subtree:add(f_recv_chnl,2) -- 4 bytes for uint32
  111. print("Recv chnl - 2")
  112. subtree:add(f_rx_cfg_frames, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  113. offset = offset + 4
  114. subtree:add(f_rx_cfg_detected, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  115. offset = offset + 4
  116. subtree:add(f_rx_cfg_rssi, buffer(offset, 4):le_float()) -- 4 bytes for float (f32)
  117. offset = offset + 4
  118. subtree:add(f_rx_avg_rssi, buffer(offset, 4):le_float()) -- 4 bytes for float (f32)
  119. offset = offset + 4
  120. subtree:add(f_rx_cfg_freqerr, buffer(offset, 4):le_uint()) -- 4 bytes for int32
  121. offset = offset + 4
  122. subtree:add(f_rx_cfg_carrier_lock, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  123. offset = offset + 4
  124. subtree:add(f_rx_frame_lock, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  125. offset = offset + 4
  126. subtree:add(f_rx_sir_min, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  127. offset = offset + 4
  128. subtree:add(f_rx_sir_max, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  129. offset = offset + 4
  130. subtree:add(f_rx_bch_block_cnt, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  131. offset = offset + 4
  132. subtree:add(f_rx_bch_err_cnt, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  133. offset = offset + 4
  134. -- Dissect the s_sband_tx_tm structure
  135. --subtree:add(f_tx_cfg_frames, buffer(offset, 4):le_uint()) -- 4 bytes for uint32
  136. --offset = offset + 4
  137. --subtree:add(f_tx_cfg_pwr_rfl, buffer(offset, 4):le_float()) -- 4 bytes for float (f32)
  138. --offset = offset + 4
  139. end -- This closes the `for` loop
  140. end -- This closes the function `sband_dissectors`