obc_to_ps.lua 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. -- Define the protocol
  2. IPCC_PROTOCOL = Proto("IPCC", "IPCC")
  3. -- Define protocol fields
  4. local f_sof1 = ProtoField.uint8("IPCC_PROTOCOL.sof1", "SOF1", base.HEX)
  5. local f_ipcc_ctrl = ProtoField.uint8("IPCC_PROTOCOL.ipcc_ctrl", "IPCC Ctrl", base.HEX)
  6. local f_timestamp = ProtoField.uint32("IPCC_PROTOCOL.timestamp", "Timestamp", base.HEX)
  7. local f_seq_no = ProtoField.uint16("IPCC_PROTOCOL.seq_no", "Sequence No", base.HEX)
  8. local f_qos = ProtoField.uint8("IPCC_PROTOCOL.qos", "QoS", base.HEX)
  9. local f_sa_id = ProtoField.uint16("IPCC_PROTOCOL.sa_id", "SA Id", base.HEX)
  10. local f_da_id = ProtoField.uint16("IPCC_PROTOCOL.da_id", "DA Id", base.HEX)
  11. local f_ipcc_id = ProtoField.uint8("IPCC_PROTOCOL.ipcc_id", "IPCC Id", base.HEX)
  12. local f_ipcc_len = ProtoField.uint16("IPCC_PROTOCOL.ipcc_len", "IPCC Len", base.HEX)
  13. local f_ipcc_data = ProtoField.uint8("IPCC_PROTOCOL.ipcc_data", "IPCC Data", base.HEX)
  14. local f_keys = ProtoField.uint8("IPCC_PROTOCOL.keys", "Keys", base.HEX)
  15. local f_sec_cfg = ProtoField.uint16("IPCC_PROTOCOL.sec_cfg", "Security Config", base.HEX)
  16. local f_mac_cfg = ProtoField.uint16("IPCC_PROTOCOL.mac_cfg", "MAC Config", base.HEX)
  17. local f_crc_32 = ProtoField.uint32("IPCC_PROTOCOL.crc_32", "CRC 32", base.HEX)
  18. local f_cmac_hmac = ProtoField.uint8("IPCC_PROTOCOL.cmac_hmac", "CMAC/HMAC", base.HEX)
  19. local disp = ProtoField.uint8("IPCC_PROTOCOL.disp", "disp", base.HEX)
  20. -- Add the fields to the protocol
  21. IPCC_PROTOCOL.fields = {
  22. f_sof1, f_ipcc_ctrl, f_timestamp, f_seq_no, f_qos, f_sa_id, f_da_id,
  23. f_ipcc_id, f_ipcc_len, f_ipcc_data, f_keys, f_sec_cfg, f_mac_cfg,
  24. f_crc_32, f_cmac_hmac
  25. }
  26. --------------------------------------------------------------------------------------------------------------------------------------------
  27. -- Dissector function for Telemetry (OBC to GS)
  28. function IPCC_TM_dissector(buffer, pinfo, tree)
  29. --pinfo.cols.protocol = "IPCC"
  30. --local tcp_flags = buffer(13, 1):uint()
  31. --if bit.band(tcp_flags, 0x10) == 0x10 then -- ACK flag (0x10)
  32. --Handle ACK packets or empty packets
  33. -- local subtree = tree:add(IPCC_PROTOCOL, buffer(), "IPCC")
  34. --subtree:add(disp, buffer())
  35. --else
  36. local subtree = tree:add(IPCC_PROTOCOL, buffer(), "IPCC")
  37. local add=0
  38. local magic=0
  39. local info_display
  40. -- Add the fields to the protocol subtree
  41. subtree:add(f_sof1, buffer(add, 1):le_uint())
  42. add=add+1
  43. subtree:add(f_ipcc_ctrl, buffer(add, 1):le_uint())
  44. add=add+1
  45. subtree:add(f_timestamp, buffer(add, 4):le_uint())
  46. add=add+4
  47. subtree:add(f_seq_no, buffer(add, 2):le_uint())
  48. add=add+2
  49. subtree:add(f_qos, buffer(add, 1):le_uint())
  50. add=add+1
  51. -- logic for SA_ID-----
  52. magic =buffer(add,1):le_uint()
  53. if bit.band(magic, 0x80) == 0 then
  54. subtree:add(f_sa_id, buffer(add, 1):le_uint()) -- SA Id in HEX
  55. add=add+1
  56. else
  57. magic=buffer(add, 2):le_uint()
  58. local dummy=magic & 0x8000 --to check 7th byte is 1
  59. if dummy == 0 then
  60. magic = magic & 0xff7f -- if 15th bit is 0 set 7th bit 0
  61. else
  62. magic = magic & 0x7fff -- if 15 bit is 1 set 15th bit to 0
  63. end
  64. subtree:add(f_sa_id, magic) -- SAT Id in HEX
  65. add=add+2
  66. end
  67. -- logic for DA_ID---
  68. magic =buffer(add,1):le_uint()
  69. if bit.band(magic, 0x80) == 0 then
  70. subtree:add(f_da_id, buffer(add, 1):le_uint()) -- DA Id in HEX
  71. add=add+1
  72. else
  73. magic=buffer(add, 2):le_uint()
  74. local dummy=magic & 0x8000 --to check 7th byte is 1
  75. if dummy == 0 then
  76. magic = magic & 0xff7f -- if 15th bit is 0 set 7th bit 0
  77. else
  78. magic = magic & 0x7fff -- if 15 bit is 1 set 15th bit to 0
  79. end
  80. subtree:add(f_da_id, magic) -- SAT Id in HEX
  81. add=add+2
  82. end
  83. subtree:add(f_ipcc_id, buffer(add, 1):le_uint())
  84. info_display= {buffer(add, 1):le_uint(),buffer(3, 4):le_uint() ,buffer(6, 2):le_uint()}
  85. add=add+1
  86. magic=buffer(add, 2):le_uint()
  87. subtree:add(f_ipcc_len, buffer(add, 2):le_uint())
  88. add=add+2
  89. local subtree2 = subtree:add(IPCC_PROTOCOL, buffer(), "IPCC_DATA")
  90. subtree2:add(f_ipcc_data, buffer(add,1)) -- Rest of the data
  91. add=add+magic
  92. subtree:add(f_keys, buffer(buffer:len() - 10, 1)) -- Keys
  93. subtree:add(f_sec_cfg, buffer(buffer:len() - 9, 1)) -- Security Config
  94. subtree:add(f_mac_cfg, buffer(buffer:len() - 8, 1)) -- MAC Config
  95. subtree:add(f_crc_32, buffer(buffer:len() - 4, 4)) -- CRC 32
  96. subtree:add(f_cmac_hmac, buffer(buffer:len() - 1, 1)) -- CMAC/HMAC
  97. pinfo.cols.info ="IPSS_ID=" ..info_display[1] .." TS=" ..info_display[2].." SEQ_NO="..info_display[3] -- for info display in wireshark
  98. end
  99. --end
  100. --------------------------------------------------------------------------------------------------------------------------------------------
  101. -- Register the dissector function to the protocol
  102. function IPCC_PROTOCOL.dissector(buffer, pinfo, tree)
  103. -- Set protocol column name in Wireshark
  104. pinfo.cols.protocol = "IPCC"
  105. -- Call the Telemetry dissector for the current packet
  106. IPCC_TM_dissector(buffer, pinfo, tree)
  107. end
  108. --------------------------------------------------------------------------------------------------------------------------------------------
  109. -- Register the dissector for TCP port 8774
  110. local tcp_port = 8774
  111. local tcp_table = DissectorTable.get("tcp.port")
  112. -- Add our custom dissector to the TCP table for the specified port
  113. tcp_table:add(tcp_port, IPCC_PROTOCOL)