tc_tm_protocols.lua 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727
  1. -- Define the protocol
  2. TC_TM_PROTOCOL = Proto("tc_tm", "TC_TM")
  3. local f_sof1 = ProtoField.uint8("TC_TM_PROTOCOL.sof1", "SOF1", base.HEX)
  4. local f_sof2 = ProtoField.uint8("TC_TM_PROTOCOL.sof2", "SOF2", base.HEX)
  5. local f_tm_ctrl = ProtoField.uint8("TC_TM_PROTOCOL.tm_ctrl", "TM Ctrl", base.HEX)
  6. local f_GS_Id = ProtoField.uint8("TC_TM_PROTOCOL.GS_Id", "GS Id", base.HEX)
  7. local f_timestamp = ProtoField.string("TC_TM_PROTOCOL.timestamp", "Timestamp", base.NONE)
  8. local f_ist = ProtoField.string("TC_TM_PROTOCOL.timestamp_ist", "IST TIME ", base.NONE)
  9. local f_pst = ProtoField.string("TC_TM_PROTOCOL.timestamp_pst", "PST TIME", base.NONE)
  10. local f_est = ProtoField.string("TC_TM_PROTOCOL.timestamp_est", "EST TIME", base.NONE)
  11. local f_mt = ProtoField.string("TC_TM_PROTOCOL.timestamp", "MST TIME", base.NONE)
  12. local f_sequence_no = ProtoField.uint16("TC_TM_PROTOCOL.sequence_no", "Sequence No", base.DEC)
  13. local f_sat_id = ProtoField.uint16("TC_TM_PROTOCOL.sat_id", "SAT Id", base.DEC)
  14. local f_qos = ProtoField.uint8("TC_TM_PROTOCOL.qos", "QoS", base.DEC)
  15. local f_sa_id = ProtoField.uint16("TC_TM_PROTOCOL.sa_id", "SA Id", base.DEC)
  16. local f_da_id = ProtoField.uint16("TC_TM_PROTOCOL.da_id", "DA Id", base.DEC)
  17. local f_rm_id = ProtoField.uint8("TC_TM_PROTOCOL.rm_id", "RM Id", base.DEC)
  18. local f_tm_id = ProtoField.uint16("TC_TM_PROTOCOL.tm_id", "TM Id", base.DEC)
  19. local f_co_id = ProtoField.uint16("TC_TM_PROTOCOL.co_id", "Co Id", base.DEC)
  20. local f_tm_len = ProtoField.uint16("TC_TM_PROTOCOL.tm_len", "TM Len", base.DEC)
  21. local f_tm_data = ProtoField.uint8("TC_TM_PROTOCOL.tm_data", "TM Data", base.DEC)
  22. local f_ext_header_len = ProtoField.uint8("TC_TM_PROTOCOL.ext_header_len", "Ext Header Len", base.DEC)
  23. local f_ext_header_data = ProtoField.uint8("TC_TM_PROTOCOL.ext_header_data", "Ext Header Data", base.DEC)
  24. local f_crc = ProtoField.uint8("TC_TM_PROTOCOL.crc", "CRC", base.DEC)
  25. local f_c_mac = ProtoField.uint8("TC_TM_PROTOCOL.c_mac", "C MAC", base.DEC)
  26. local f_eof1 = ProtoField.uint8("TC_TM_PROTOCOL.eof1", "EOF", base.HEX)
  27. local f_tc_id = ProtoField.uint16("TC_TM_PROTOCOL.tc_id", "TC Id", base.DEC)
  28. local f_tc_len = ProtoField.uint16("TC_TM_PROTOCOL.tc_len", "TC Len", base.DEC)
  29. local f_tc_data = ProtoField.uint32("TC_TM_PROTOCOL.tc_data", "TC Data", base.DEC)
  30. -- Add the fields to the protocol
  31. TC_TM_PROTOCOL.fields = {
  32. f_sof1, f_sof2, f_tm_ctrl,f_GS_Id, f_timestamp, f_sequence_no, f_sat_id, f_ist, f_pst, f_est, f_mt,
  33. f_qos, f_sa_id, f_da_id, f_rm_id, f_tm_id, f_co_id, f_tm_len, f_tm_data,
  34. f_ext_header_len, f_ext_header_data, f_crc, f_c_mac, f_eof1,f_tc_id ,f_tc_len ,f_tc_data
  35. }
  36. ------------------------------------------------------------------------------------------------------------------------------------
  37. function TC_dissector(buffer, pinfo, tree)
  38. --Set the protocol coloumn name in wireshark
  39. local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "TELECOMMAND")
  40. -- Dissect SOF1 and SOF2
  41. local offset = 0
  42. for i = 0,1000 do
  43. local data = buffer(i,1):le_uint()
  44. if data == 0xa5 then
  45. offset = i
  46. break
  47. end
  48. end
  49. subtree:add(f_sof1 , buffer(offset, 1))
  50. offset = offset + 1
  51. subtree:add(f_sof2, buffer(offset, 1))
  52. offset = offset + 1
  53. -- Dissect TC Control byte (TC_Ctrl)
  54. local tc_ctrl = buffer(offset, 1):le_uint() -- Get the value of TC Ctrl byte
  55. subtree:add(f_tm_ctrl , tc_ctrl)
  56. offset = offset + 1
  57. -- Dissect Timestamp (4 bytes)
  58. if buffer:len() >= offset + 4 then
  59. local timestamp = buffer(offset, 4):le_uint()
  60. local utc_time = os.date("!%Y-%m-%d %H:%M:%S", timestamp)
  61. subtree:add(f_timestamp, timestamp.." ".."("..utc_time..")" )
  62. local time = timestamp + 19800
  63. local ist_time = os.date("!%Y-%m-%d %H:%M:%S", time)
  64. subtree:add(f_ist, ist_time)
  65. time = timestamp - 28800
  66. local pst_time = os.date("!%Y-%m-%d %H:%M:%S", time)
  67. subtree:add(f_pst, pst_time)
  68. time = timestamp - 18000
  69. local est_time = os.date("!%Y-%m-%d %H:%M:%S", time)
  70. subtree:add(f_est, est_time)
  71. time = timestamp - 25200
  72. local mt_time = os.date("!%Y-%m-%d %H:%M:%S", time)
  73. subtree:add(f_mt, mt_time)
  74. offset = offset + 4
  75. else
  76. subtree:add(f_timestamp, "Invalid data (timestamp)")
  77. end
  78. -- Dissect Sequence No (2 bytes)
  79. if buffer:len() >= offset + 2 then
  80. local sequence = buffer(offset, 2):le_uint()
  81. subtree:add(f_sequence_no, sequence)
  82. offset = offset + 2
  83. else
  84. subtree:add(f_sequence_no, "Invalid data (sequence number)")
  85. end
  86. -- Dissect SAT_Id (1 byte)
  87. if buffer:len() >= offset + 1 then
  88. local sat_id = buffer(offset, 1):uint() -- Get SAT Id (1st byte)
  89. --offset = offset + 1
  90. if bit.band(sat_id, 0x80) == 0x80 then --if 7th bit is set and
  91. if buffer:len() >= offset + 1 then
  92. local second = buffer(offset, 2):le_uint()
  93. if bit.band(second, 0x8000) == 0x0000 then --and 15th bit is set then unset 15th bit
  94. sat_id = buffer(offset, 2):le_uint()
  95. sat_id = bit.band(sat_id, 0xFF7F)
  96. offset = offset + 1
  97. else
  98. sat_id = buffer(offset, 2):le_uint()
  99. sat_id = bit.band(sat_id, 0x7FFF) -- and 15th bit is unset then unset the 7th bit
  100. offset = offset + 1
  101. end
  102. end
  103. end
  104. subtree:add(f_sat_id, sat_id)
  105. offset = offset + 1
  106. end
  107. -- Dissect GS_Id (1 byte)
  108. if buffer:len() >= offset + 1 then
  109. local gs_id = buffer(offset, 1):uint() -- Get SAT Id (1st byte)
  110. --offset = offset + 1
  111. if bit.band(gs_id, 0x80) == 0x80 then
  112. if buffer:len() >= offset + 1 then
  113. local second = buffer(offset, 2):le_uint()
  114. if bit.band(second, 0x8000) == 0x0000 then
  115. gs_id = buffer(offset, 2):le_uint()
  116. gs_id = bit.band(gs_id, 0xFF7F)
  117. offset = offset + 1
  118. else
  119. gs_id = buffer(offset, 2):le_uint()
  120. gs_id = bit.band(gs_id, 0x7FFF)
  121. offset = offset + 1
  122. end
  123. end
  124. end
  125. subtree:add(f_GS_Id, gs_id)
  126. offset = offset + 1
  127. end
  128. -- Dissect QoS (1 byte)
  129. if buffer:len() >= offset + 1 then
  130. subtree:add(f_qos, buffer(offset, 1))
  131. offset = offset + 1
  132. end
  133. -- Dissect SA_Id (Source Application ID) and DA_Id (Destination Application ID)
  134. if buffer:len() >= offset + 1 then
  135. local sa_id = buffer(offset, 1):uint() -- Get source Application Id (1st byte)
  136. --offset = offset + 1
  137. if bit.band(sa_id, 0x80) == 0x80 then
  138. if buffer:len() >= offset + 1 then
  139. local second = buffer(offset, 2):le_uint()
  140. if bit.band(second, 0x8000) == 0x0000 then
  141. sa_id = buffer(offset, 2):le_uint()
  142. sa_id = bit.band(sa_id, 0xFF7F)
  143. offset = offset + 1
  144. else
  145. sa_id = buffer(offset, 2):le_uint()
  146. sa_id = bit.band(sa_id, 0x7FFF)
  147. offset = offset + 1
  148. end
  149. end
  150. end
  151. subtree:add(f_sa_id, sa_id)
  152. offset = offset + 1
  153. end
  154. if buffer:len() >= offset + 1 then
  155. --subtree:add(f_DA_Id, buffer(offset, 1))
  156. local da_id = buffer(offset, 1):le_uint() -- Get Destination Application Id (1st byte)
  157. --offset = offset + 1
  158. if bit.band(da_id, 0x80) == 0x80 then
  159. if buffer:len() >= offset + 1 then
  160. local second = buffer(offset, 2):le_uint()
  161. if bit.band(second, 0x8000) == 0x0000 then
  162. da_id = buffer(offset, 2):le_uint()
  163. da_id = bit.band(da_id, 0xFF7F)
  164. offset = offset + 1
  165. else
  166. da_id = buffer(offset, 2):le_uint()
  167. da_id = bit.band(da_id, 0x7FFF)
  168. offset = offset + 1
  169. end
  170. end
  171. end
  172. subtree:add(f_da_id, da_id)
  173. offset = offset + 1
  174. end
  175. -- Dissect RM_Id (1 byte)
  176. if buffer:len() >= offset + 1 then
  177. subtree:add(f_rm_id, buffer(offset, 1))
  178. offset = offset + 1
  179. end
  180. -- Dissect TC_Id (2 bytes)
  181. -- Dissect TC_Id (2 bytes)
  182. local info_display
  183. local tc_id = buffer(offset, 1):le_uint() -- Read 1 byte for tc_id
  184. if tc_id == 100 or tc_id == 102 or tc_id == 103 then
  185. pinfo.cols.protocol = "FTM(UL)"
  186. elseif tc_id == 105 then
  187. pinfo.cols.protocol = "FTM(DL)"
  188. else
  189. pinfo.cols.protocol = "TELECOMMAND"
  190. end
  191. if buffer:len() >= offset + 2 then -- Ensure enough data is available to read 2 bytes
  192. -- Check if the 7th bit (0x80) is set in tc_id
  193. if bit.band(tc_id, 0x80) == 0x80 then
  194. if buffer:len() >= offset + 2 then -- Ensure enough data for the next 2 bytes
  195. local second = buffer(offset, 2):le_uint()
  196. if bit.band(second, 0x8000) == 0x0000 then
  197. tc_id = buffer(offset, 2):le_uint()
  198. tc_id = bit.band(tc_id, 0xFF7F)
  199. offset = offset + 1
  200. else
  201. tc_id = buffer(offset, 2):le_uint()
  202. tc_id = bit.band(tc_id, 0x7FFF)
  203. offset = offset + 1
  204. end
  205. end
  206. end
  207. -- Add tc_id to the subtree (display in dissection tree)
  208. subtree:add(f_tc_id, tc_id)
  209. -- Move the offset forward by 1 (since we initially read 1 byte)
  210. offset = offset + 1
  211. end
  212. -- Dissect TC_Len (2 bytes)
  213. local tc_len = 0 -- Declare tc_len as a local variable here
  214. if buffer:len() >= offset + 2 then
  215. tc_len = buffer(offset, 2):le_uint()
  216. subtree:add(f_tc_len, tc_len)
  217. offset = offset + 2
  218. end
  219. -- Dissect TC_Data (variable length)
  220. --local subtree2 = subtree:add(TC_TM_PROTOCOL, buffer(), TC_DATA())
  221. local data
  222. if buffer:len() >= offset + tc_len then
  223. if tc_len == 0 then
  224. subtree:add("TC DATA : NIL")
  225. else
  226. if tc_id == 621 then
  227. require("hm_dissector")
  228. data = HM_TC_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, offset)
  229. offset = offset + tc_len
  230. elseif tc_id == 100 then
  231. require("ftci_dissector")
  232. ftci_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, offset)
  233. offset = offset + tc_len
  234. elseif tc_id == 103 then
  235. require("ftfci_dissector")
  236. ftfci_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, offset)
  237. offset = offset + tc_len
  238. elseif tc_id == 102 then
  239. require("ftds_dissector")
  240. ftds_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, offset)
  241. offset = offset + tc_len
  242. elseif tc_id == 105 then
  243. require("ftsr_dissector")
  244. ftsr_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, offset)
  245. offset = offset + tc_len
  246. else
  247. for i=0,tc_len - 1 do
  248. subtree:add(f_tc_data, buffer(offset, 1))
  249. offset = offset + 1
  250. end
  251. end
  252. end
  253. end
  254. -- Check if we can dissect Ext_Header_Len
  255. if bit.band(tc_ctrl, 0x80) == 0x80 and buffer:len() >= offset + 1 then
  256. subtree:add(f_ext_header_len, buffer(offset, 1))
  257. local ext_header_len = buffer(offset, 1):uint()
  258. offset = offset + 1
  259. if buffer:len() >= offset + ext_header_len then
  260. for i=1,ext_header_len do
  261. subtree:add(f_ext_header_data, buffer(offset, 1))
  262. offset = offset + 1
  263. end
  264. end
  265. end
  266. -- Dissect CRC (1 byte)
  267. if buffer:len() >= offset + 1 then
  268. subtree:add(f_crc, buffer(offset, 1))
  269. offset = offset + 1
  270. end
  271. -- Dissect C-MAC/H-MAC (if TC Ctrl bit 4 is set)
  272. if bit.band(tc_ctrl, 0x10) == 0x10 and buffer:len() >= offset + 32 then
  273. for i=1,32 do
  274. subtree:add(f_c_mac, buffer(offset, 1))
  275. offset = offset + 1
  276. end
  277. end
  278. -- Dissect EOF (1 byte)
  279. if buffer:len() >= offset + 1 then
  280. subtree:add(f_eof1, buffer(offset, 1))
  281. end
  282. local string
  283. if tc_id == 621 then
  284. local switch = {
  285. [9] = function() return "EPS" end,
  286. [22] = function() return "ADCS" end,
  287. [14] = function() return "SBAND" end,
  288. [15] = function() return "UHF" end,
  289. [42] = function() return "SENSOR" end,
  290. [27] = function() return "OBC" end
  291. }
  292. string = (switch[data] or function() return "All Module" end)()
  293. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tc_id, string} --- for info display in wireshark
  294. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TC_ID = "..info_display[3]..", Module = " ..info_display[4] -- for info display in wireshark
  295. elseif tc_id == 100 then
  296. string = "FTCI FRAME"
  297. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tc_id, string} --- for info display in wireshark
  298. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TC_ID = "..info_display[3]..", " ..info_display[4] -- for info display in wireshark
  299. elseif tc_id == 105 then
  300. string = "FTSR FRAME"
  301. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tc_id, string} --- for info display in wireshark
  302. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TC_ID = "..info_display[3]..", " ..info_display[4] -- for info display in wireshark
  303. elseif tc_id == 102 then
  304. string = "FTDS FRAME"
  305. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tc_id, string} --- for info display in wireshark
  306. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TC_ID = "..info_display[3]..", " ..info_display[4] -- for info display in wireshark
  307. elseif tc_id == 103 then
  308. string = "FTFCI FRAME"
  309. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tc_id, string} --- for info display in wireshark
  310. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TC_ID = "..info_display[3]..", " ..info_display[4] -- for info display in wireshark
  311. else
  312. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tc_id} --- for info display in wireshark
  313. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TC_ID = "..info_display[3] -- for info display in wireshark
  314. end
  315. end
  316. -----------------------------------------------------------------------------------------------------------------------------------
  317. function TM_dissector(buffer, pinfo, tree) -- OBC to GS
  318. local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "TELEMETRY")
  319. -- Extract the fields in order as defined in the structure
  320. local add
  321. for i = 0,1000 do
  322. local data = buffer(i,1):le_uint()
  323. if data == 0xa5 then
  324. add = i
  325. break
  326. end
  327. end
  328. subtree:add(f_sof1, buffer(add, 1):le_uint()) -- SOF1 in HEX
  329. add = add + 1
  330. subtree:add(f_sof2, buffer(add, 1):le_uint()) -- SOF2 in HEX
  331. add = add + 1
  332. subtree:add(f_tm_ctrl, buffer(add, 1):le_uint()) -- TM Ctrl in HEX
  333. add = add + 1
  334. -- Dissect timestamp
  335. local timestamp = buffer(add, 4):le_uint()
  336. local utc_time = os.date("!%Y-%m-%d %H:%M:%S", timestamp)
  337. subtree:add(f_timestamp, timestamp.." ".."("..utc_time..")" )
  338. local time = timestamp + 19800
  339. local ist_time = os.date("!%Y-%m-%d %H:%M:%S", time)
  340. subtree:add(f_ist, ist_time)
  341. time = timestamp - 28800
  342. local pst_time = os.date("!%Y-%m-%d %H:%M:%S", time)
  343. subtree:add(f_pst, pst_time)
  344. time = timestamp - 18000
  345. local est_time = os.date("!%Y-%m-%d %H:%M:%S", time)
  346. subtree:add(f_est, est_time)
  347. time = timestamp - 25200
  348. local mt_time = os.date("!%Y-%m-%d %H:%M:%S", time)
  349. subtree:add(f_mt, mt_time)
  350. add = add + 4
  351. subtree:add(f_sequence_no, buffer(add, 2):le_uint()) -- Sequence No in HEX
  352. add = add + 2
  353. -- My logic for SAT Id
  354. local magic = buffer(add, 1):le_uint()
  355. if bit.band(magic, 0x80) == 0 then
  356. subtree:add(f_sat_id, buffer(add, 1):le_uint()) -- SAT Id in HEX
  357. add=add+1
  358. else
  359. magic=buffer(add, 2):le_uint()
  360. local dummy=magic & 0x8000 --to check 7th byte is 1
  361. if dummy == 0 then
  362. magic = magic & 0xff7f -- if 15th bit is 0 set 7th bit 0
  363. else
  364. magic = magic & 0x7fff -- if 15 bit is 1 set 15th bit to 0
  365. end
  366. subtree:add(f_sat_id, magic) -- SAT Id in HEX
  367. add=add+2
  368. end
  369. -- QoS in HEX
  370. subtree:add(f_qos, buffer(add, 1):le_uint())
  371. add=add+1
  372. -- My logic for SA Id
  373. magic = buffer(add, 1):le_uint()
  374. if bit.band(magic, 0x80) == 0 then
  375. subtree:add(f_sa_id, buffer(add, 1):le_uint()) -- SA Id in HEX
  376. add=add+1
  377. else
  378. magic=buffer(add, 2):le_uint()
  379. local dummy=magic & 0x8000
  380. if dummy == 0 then
  381. magic = magic & 0xff7f
  382. else
  383. magic = magic & 0x7fff
  384. end
  385. subtree:add(f_sa_id,magic) -- SA Id in HEX
  386. add=add+2
  387. end
  388. -- My logic for DA Id
  389. magic = buffer(add, 1):uint()
  390. if bit.band(magic, 0x80) == 0 then
  391. subtree:add(f_da_id, buffer(add, 1):le_uint()) -- DA Id in HEX
  392. add=add+1
  393. else
  394. magic=buffer(add, 2):le_uint()
  395. local dummy=magic & 0x8000
  396. if dummy == 0 then
  397. magic = magic & 0xff7f
  398. else
  399. magic = magic & 0x7fff
  400. end
  401. subtree:add(f_da_id, magic) -- DA Id in HEX
  402. add=add+2
  403. end
  404. -- RM Id in HEX
  405. subtree:add(f_rm_id, buffer(add, 1):le_uint())
  406. add=add+1
  407. -- My logic for TM Id
  408. local info_display -- for display in wireshark
  409. local tm_id
  410. magic = buffer(add, 1):uint()
  411. if bit.band(magic, 0x80) == 0 then
  412. subtree:add(f_tm_id, buffer(add, 1):le_uint()) -- TM Id in HEX
  413. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,buffer(add, 1):le_uint()} --- for info display in wireshark
  414. add=add+1
  415. else
  416. magic=buffer(add, 2):le_uint()
  417. local dummy=magic & 0x8000
  418. if dummy == 0 then
  419. magic = magic & 0xff7f
  420. else
  421. magic = magic & 0x7fff
  422. end
  423. subtree:add(f_tm_id, magic) -- TM Id in HEX
  424. add=add+2
  425. end
  426. tm_id = magic
  427. if tm_id == 104 or tm_id == 106 or tm_id == 107 then
  428. pinfo.cols.protocol = "FTM(DL)"
  429. elseif tm_id == 101 then
  430. pinfo.cols.protocol = "FTM(UL)"
  431. else
  432. pinfo.cols.protocol = "TELEMETRY"
  433. end
  434. -- Co Id in HEX
  435. subtree:add(f_co_id, buffer(add, 2):le_uint())
  436. add=add+2
  437. -- TM Len in HEX
  438. local tm_len
  439. magic = buffer(add, 2):le_uint()
  440. tm_len = magic
  441. subtree:add(f_tm_len, buffer(add, 2):le_uint())
  442. add=add+2
  443. -- logic for TM Data
  444. local array
  445. --local subtree2 = subtree:add(TC_TM_PROTOCOL, buffer(), "TM_DATA")
  446. -- Dissect TM_Data (variable length)
  447. if tm_id == 621 or tm_id == 815 or tm_id == 104 or tm_id == 107 or tm_id == 101 or tm_id == 106 then
  448. if tm_id == 621 then
  449. require("hm_dissector")
  450. array = HM_TM_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, add, tm_len)
  451. add = add + tm_len
  452. elseif tm_id == 815 then
  453. require("bcon")
  454. bcon_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, add, tm_len)
  455. add = add + tm_len
  456. elseif tm_id == 104 then
  457. require("ftci_dissector")
  458. ftci_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, add)
  459. add = add + tm_len
  460. elseif tm_id == 107 then
  461. require("ftfci_dissector")
  462. ftfci_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, add)
  463. add = add + tm_len
  464. elseif tm_id == 101 then
  465. require("ftsr_dissector")
  466. ftsr_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, add)
  467. add = add + tm_len
  468. elseif tm_id == 106 then
  469. require("ftds_dissector")
  470. ftds_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, add)
  471. add = add + tm_len
  472. end
  473. else
  474. for i=0,magic-1 do
  475. subtree:add(f_tm_data, buffer(add, 1):le_uint())
  476. add=add+1
  477. end
  478. end
  479. -- Ext Header Len in HEX
  480. magic = buffer(6, 1):le_uint() -- to check tm control
  481. if bit.band(magic, 0x80) == 0x80 then
  482. magic= buffer(add, 1):uint()
  483. subtree:add(f_ext_header_len, buffer(add, 1):uint())
  484. add=add+1
  485. -- logic for Ext Header Data
  486. for i=0,magic-1 do
  487. subtree:add(f_ext_header_data, buffer(add, 1):uint()) -- Ext Header Data in HEX
  488. add=add+1
  489. end
  490. end
  491. -- CRC in HEX
  492. subtree:add(f_crc, buffer(add, 1):le_uint())
  493. add=add+1
  494. -- C MAC in HEX
  495. magic = buffer(6, 1):le_uint() -- tm control
  496. if bit.band(magic, 0x10) == 0x10 then
  497. for i=1,32 do
  498. subtree:add(f_c_mac, buffer(add, 1):uint())
  499. add=add+1
  500. end
  501. end
  502. -- EOF1 in HEX
  503. subtree:add(f_eof1, buffer(add, 1):uint())
  504. local string
  505. if tm_id == 621 then
  506. local switch = {
  507. [0] = function() return "EPS" end,
  508. [1] = function() return "ADCS" end,
  509. [2] = function() return "SBAND" end,
  510. [3] = function() return "UHF" end,
  511. [4] = function() return "SENSOR" end,
  512. [5] = function() return "OBC" end,
  513. [6] = function() return "ERROR HANDLER" end
  514. }
  515. string = (switch[array[1]] or function() return "All Module" end)()
  516. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tm_id, string, array[2], array[3]} --- for info display in wireshark
  517. pinfo.cols.info ="seq_no = " ..info_display[1]..", TS = " ..info_display[2]..", TM ID = "..info_display[3]..", Module = "..info_display[4]..", Queue id = "..info_display[5]..", Number of instance = "..info_display[6] -- for info display in wireshark
  518. elseif tm_id == 104 then
  519. string = "FTCI FRAME"
  520. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tm_id, string} --- for info display in wireshark
  521. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TM_ID = "..info_display[3]..", " ..info_display[4] -- for info display in wireshark
  522. elseif tm_id == 101 then
  523. string = "FTSR FRAME"
  524. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tm_id, string} --- for info display in wireshark
  525. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TM_ID = "..info_display[3]..", " ..info_display[4] --for info display in wireshark
  526. elseif tm_id == 106 then
  527. string = "FTDS FRAME"
  528. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tm_id, string} --- for info display in wireshark
  529. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TM_ID = "..info_display[3]..", " ..info_display[4] -- for info display in wireshark
  530. elseif tm_id == 107 then
  531. string = "FTFCI FRAME"
  532. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tm_id, string} --- for info display in wireshark
  533. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TM_ID = "..info_display[3]..", " ..info_display[4] -- for info display in wireshark
  534. elseif tm_id == 815 then
  535. string = "BEACON"
  536. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tm_id, string} --- for info display in wireshark
  537. pinfo.cols.info ="seq_no = " ..info_display[1] ..", TS = " ..info_display[2]..", TM_ID = "..info_display[3]..", " ..info_display[4] -- for info display in wireshark
  538. else
  539. info_display= {buffer(11, 2):le_uint(),buffer(7, 4):le_uint() ,tm_id} --- for info display in wireshark
  540. pinfo.cols.info ="seq_no = " ..info_display[1]..", TS = " ..info_display[2]..", TM ID = "..info_display[3] -- for info display in wireshark
  541. end
  542. -- Check if the buffer contains enough data for the expected total length
  543. --if buffer:len() < 38 + buffer(21, 2):uint() then
  544. -- subtree:add_expert_info(PI_MALFORMED, PI_WARN, "Incomplete data")
  545. --end
  546. end
  547. -- Register the dissector for udp port
  548. -------------------------------------------------------------------------------------------------------------------------------
  549. -- Dissector function
  550. function TC_TM_PROTOCOL.dissector(buffer, pinfo, tree)
  551. -- Register protocol in preferences (add this part)
  552. --my_udp_protocol:register_preference()
  553. pinfo.cols.protocol = "TC_TM"
  554. local offset1
  555. for i = 0,1000 do
  556. local data = buffer(i,1):le_uint()
  557. if data == 0xa5 then
  558. offset1 = i
  559. break
  560. end
  561. end
  562. offset1 = offset1 + 2
  563. -- Create a subtree for this protocol
  564. --local subtree = tree:add(my_udp_protocol, buffer(), "TE")
  565. local direction = buffer(offset1, 1):uint() -- taking tM or tc control byte
  566. if direction & 0x40 == 0x40 then -- if 6th bit is set then it is TM
  567. TM_dissector(buffer, pinfo, tree) -- OBC to GS
  568. else
  569. TC_dissector(buffer, pinfo, tree) -- GS to OBC
  570. end
  571. end
  572. ------------------------------------------------------------------------------------------------------------------------------------------------
  573. -- Add a preference for the port number
  574. TC_TM_PROTOCOL.prefs.port = Pref.uint("UDP Port", 6779, "UDP port for TC_TM protocol")
  575. -- Register the dissector based on the preference
  576. function TC_TM_PROTOCOL.init()
  577. local udp_table = DissectorTable.get("udp.port")
  578. udp_table:add(TC_TM_PROTOCOL.prefs.port, TC_TM_PROTOCOL)
  579. end