12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157 |
- function adcs_dissector(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3,data2)
- if data2 == 32 then
- require("adcs_dissector")
- adcs_dissector_32(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 31 then
- require("adcs_dissector")
- adcs_dissector_31(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 30 then
- require("adcs_dissector")
- adcs_dissector_30(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 29 then
- require("adcs_dissector")
- adcs_dissector_29(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 28 then
- require("adcs_dissector")
- adcs_dissector_28(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 27 then
- require("adcs_dissector")
- adcs_dissector_27(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 26 then
- require("adcs_dissector")
- adcs_dissector_26(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 25 then
- require("adcs_dissector")
- adcs_dissector_25(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 24 then
- require("adcs_dissector")
- adcs_dissector_24(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 23 then
- require("adcs_dissector")
- adcs_dissector_23(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 22 then
- require("adcs_dissector")
- adcs_dissector_22(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 21 then
- require("adcs_dissector")
- adcs_dissector_21(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 20 then
- require("adcs_dissector")
- adcs_dissector_20(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 19 then
- require("adcs_dissector")
- adcs_dissector_19(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 18 then
- require("adcs_dissector")
- adcs_dissector_18(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 17 then
- require("adcs_dissector")
- adcs_dissector_17(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 16 then
- require("adcs_dissector")
- adcs_dissector_16(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
-
- elseif data2 == 15 then
- require("adcs_dissector")
- adcs_dissector_15(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 14 then
- require("adcs_dissector")
- adcs_dissector_14(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- --elseif data2 == 13 then
- -- require("adcs_dissector")
- -- adcs_dissector_13(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 12 then
- require("adcs_dissector")
- adcs_dissector_12(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- elseif data2 == 11 then
- require("adcs_dissector")
- adcs_dissector_11(buffer, pinfo, tree, TC_TM_PROTOCOL, offset, tm_len,data3)
- else
- end
- end
- ------------------------------------------------------------------------------------------------------------------------------
- function adcs_dissector_32(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for each field in the structure
- local f_op_status = ProtoField.uint8("OperationData.op_status", "Operation Status", base.DEC)
- local f_epoch_time = ProtoField.uint32("OperationData.epoch_time", "Epoch Time", base.DEC)
- local f_eci_x_velocity = ProtoField.int16("OperationData.eci_x_velocity", "ECI Referenced X Velocity", base.DEC)
- local f_eci_y_velocity = ProtoField.int16("OperationData.eci_y_velocity", "ECI Referenced Y Velocity", base.DEC)
- local f_eci_z_velocity = ProtoField.int16("OperationData.eci_z_velocity", "ECI Referenced Z Velocity", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_eci_x_velocity, f_eci_y_velocity, f_eci_z_velocity
- }
- for i = 1, data3 do
- -- Add the operation data subtree
- local subtree = tree:add(HM_TM_PROTOCOL, buffer(), "adcs_qid_32")
- -- dissect operation status (1 byte, UINT)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes, UINT)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect ECI X velocity (2 bytes, INT)
- local eci_x_velocity = buffer(offset, 2):le_int()
- subtree:add(f_eci_x_velocity, eci_x_velocity)
- offset = offset + 2
- -- dissect ECI Y velocity (2 bytes, INT)
- local eci_y_velocity = buffer(offset, 2):le_int()
- subtree:add(f_eci_y_velocity, eci_y_velocity)
- offset = offset + 2
- -- dissect ECI Z velocity (2 bytes, INT)
- local eci_z_velocity = buffer(offset, 2):le_int()
- subtree:add(f_eci_z_velocity, eci_z_velocity)
- offset = offset + 2
- end
- end
- --------------------------------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the Nadir Sensor Data
- function adcs_dissector_18(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the Nadir Sensor Data structure
- local f_op_status = ProtoField.uint8("NadirSensorData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("NadirSensorData.epoch_time", "Epoch Time", base.DES)
- local f_x_angle = ProtoField.int16("NadirSensorData.x_angle", "Nadir Sensor Raw X Angle", base.DEC)
- local f_y_angle = ProtoField.int16("NadirSensorData.y_angle", "Nadir Sensor Raw Y Angle", base.DEC)
- -- Define the ProtoFields for the ENUM values (Capture Status and Detection Result)
- local f_capture_status = ProtoField.uint8("NadirSensorData.capture_status", "Nadir Sensor Capture Status", base.HEX)
- local f_detection_result = ProtoField.uint8("NadirSensorData.detection_result", "Nadir Sensor Detection Result", base.HEX)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_angle, f_y_angle, f_capture_status, f_detection_result
- }
- -- Add the Nadir Sensor data as a subtree
- for i = 1, data3 do
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adc_qid_18")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect nadir sensor raw X angle (2 bytes)
- local x_angle = buffer(offset, 2):le_int()
- subtree:add(f_x_angle, x_angle)
- offset = offset + 2
- -- dissect nadir sensor raw Y angle (2 bytes)
- local y_angle = buffer(offset, 2):le_int()
- subtree:add(f_y_angle, y_angle)
- offset = offset + 2
- -- dissect nadir sensor capture status (1 byte - ENUM)
- local capture_status = buffer(offset, 1):le_uint()
- subtree:add(f_capture_status, capture_status)
- offset = offset + 1
- -- dissect nadir sensor detection result (1 byte - ENUM)
- local detection_result = buffer(offset, 1):le_uint()
- subtree:add(f_detection_result, detection_result)
- offset = offset + 1
- end
- end
- -------------------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the Nadir Vector Data
- function adcs_dissector_16(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the Nadir Vector Data structure
- local f_op_status = ProtoField.uint8("NadirVectorData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("NadirVectorData.epoch_time", "Epoch Time", base.DES)
- local f_x_nadir = ProtoField.uint16("NadirVectorData.x_nadir", "X axis Nadir Vector (formatted)", base.DEC)
- local f_y_nadir = ProtoField.uint16("NadirVectorData.y_nadir", "Y axis Nadir Vector (formatted)", base.DEC)
- local f_z_nadir = ProtoField.uint16("NadirVectorData.z_nadir", "Z axis Nadir Vector (formatted)", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_nadir, f_y_nadir, f_z_nadir
- }
- for i = 1, data3 do
- -- Add the Nadir Vector data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_16")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect X axis Nadir vector (2 bytes)
- local x_nadir = buffer(offset, 2):le_uint()
- subtree:add(f_x_nadir, x_nadir) -- Apply the scaling factor (RAWVAL * 0.001)
- offset = offset + 2
- -- dissect Y axis Nadir vector (2 bytes)
- local y_nadir = buffer(offset, 2):le_uint()
- subtree:add(f_y_nadir, y_nadir) -- Apply the scaling factor (RAWVAL * 0.001)
- offset = offset + 2
- -- dissect Z axis Nadir vector (2 bytes)
- local z_nadir = buffer(offset, 2):le_uint()
- subtree:add(f_z_nadir, z_nadir ) -- Apply the scaling factor (RAWVAL * 0.001)
- offset = offset + 2
- end
- end
- ---------------------------------------------------------------------------------------------
- -- Define the dissector function for the Magnetic Field Vector Data
- function adcs_dissector_15(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the Magnetic Field Vector Data structure
- local f_op_status = ProtoField.uint8("MagneticFieldVectorData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("MagneticFieldVectorData.epoch_time", "Epoch Time", base.DES)
- local f_x_mag = ProtoField.int16("MagneticFieldVectorData.x_mag", "X axis Magnetic Field Vector (formatted)", base.DEC)
- local f_y_mag = ProtoField.int16("MagneticFieldVectorData.y_mag", "Y axis Magnetic Field Vector (formatted)", base.DEC)
- local f_z_mag = ProtoField.int16("MagneticFieldVectorData.z_mag", "Z axis Magnetic Field Vector (formatted)", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_mag, f_y_mag, f_z_mag
- }
- for i = 1, data3 do
- -- Add the Magnetic Field Vector data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_15")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect X axis magnetic field vector (2 bytes)
- local x_mag = buffer(offset, 2):le_int()
- subtree:add(f_x_mag, x_mag ) -- Apply the scaling factor (RAWVAL * 0.01)
- offset = offset + 2
- -- dissect Y axis magnetic field vector (2 bytes)
- local y_mag = buffer(offset, 2):le_int()
- subtree:add(f_y_mag, y_mag ) -- Apply the scaling factor (RAWVAL * 0.01)
- offset = offset + 2
- -- dissect Z axis magnetic field vector (2 bytes)
- local z_mag = buffer(offset, 2):le_int()
- subtree:add(f_z_mag, z_mag ) -- Apply the scaling factor (RAWVAL * 0.01)
- offset = offset + 2
- end
- end
- ----------------------------------------------------------------------------------------------------------------
- function adcs_dissector_31(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for each field in the structure
- local f_op_status = ProtoField.uint8("OperationCoordinates.op_status", "Operation Status", base.DEC)
- local f_epoch_time = ProtoField.uint32("OperationCoordinates.epoch_time", "Epoch Time", base.DEC)
- local f_eci_x_coord = ProtoField.int16("OperationCoordinates.eci_x_coord", "ECI Referenced X Coordinate", base.DEC)
- local f_eci_y_coord = ProtoField.int16("OperationCoordinates.eci_y_coord", "ECI Referenced Y Coordinate", base.DEC)
- local f_eci_z_coord = ProtoField.int16("OperationCoordinates.eci_z_coord", "ECI Referenced Z Coordinate", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_eci_x_coord, f_eci_y_coord, f_eci_z_coord
- }
- for i = 1, data3 do
- -- Add the operation data coordinates subtree
- local subtree = tree:add(HM_TM_PROTOCOL, buffer(), "adcs_qid_31")
- -- dissect operation status (1 byte, UINT)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes, UINT)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect ECI X coordinate (2 bytes, INT)
- local eci_x_coord = buffer(offset, 2):le_int()
- subtree:add(f_eci_x_coord, eci_x_coord)
- offset = offset + 2
- -- dissect ECI Y coordinate (2 bytes, INT)
- local eci_y_coord = buffer(offset, 2):le_int()
- subtree:add(f_eci_y_coord, eci_y_coord)
- offset = offset + 2
- -- dissect ECI Z coordinate (2 bytes, INT)
- local eci_z_coord = buffer(offset, 2):le_int()
- subtree:add(f_eci_z_coord, eci_z_coord)
- offset = offset + 2
- end
- end
- -------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_30(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("PowerSystemData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("PowerSystemData.epoch_time", "Epoch Time", base.DES)
- local f_x_coord = ProtoField.int16("PowerSystemData.x_coord", "ECEF X Coordinate", base.DEC)
- local f_y_coord = ProtoField.int16("PowerSystemData.y_coord", "ECEF Y Coordinate", base.DEC)
- local f_z_coord = ProtoField.int16("PowerSystemData.z_coord", "ECEF Z Coordinate", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_coord, f_y_coord, f_z_coord
- }
- -- Loop through the data (data3 could represent the number of iterations or packets to dissect)
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_30")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect ECEF X coordinate (2 bytes)
- local x_coord = buffer(offset, 2):le_int()
- subtree:add(f_x_coord, x_coord)
- offset = offset + 2
- -- dissect ECEF Y coordinate (2 bytes)
- local y_coord = buffer(offset, 2):le_int()
- subtree:add(f_y_coord, y_coord)
- offset = offset + 2
- -- dissect ECEF Z coordinate (2 bytes)
- local z_coord = buffer(offset, 2):le_int()
- subtree:add(f_z_coord, z_coord)
- offset = offset + 2
- end
- end
- ----------------------------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_29(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("PowerSystemData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("PowerSystemData.epoch_time", "Epoch Time", base.DES)
- local f_roll_angle = ProtoField.int16("PowerSystemData.roll_angle", "Commanded Roll Angle (degrees)", base.DEC)
- local f_pitch_angle = ProtoField.int16("PowerSystemData.pitch_angle", "Commanded Pitch Angle (degrees)", base.DEC)
- local f_yaw_angle = ProtoField.int16("PowerSystemData.yaw_angle", "Commanded Yaw Angle (degrees)", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_roll_angle, f_pitch_angle, f_yaw_angle
- }
- -- Loop through the data (data3 could represent the number of iterations or packets to dissect)
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_29")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect commanded roll angle (2 bytes)
- local roll_angle_raw = buffer(offset, 2):le_int()
- local roll_angle = roll_angle_raw * 0.01 -- Apply scaling factor
- subtree:add(f_roll_angle, roll_angle)
- offset = offset + 2
- -- dissect commanded pitch angle (2 bytes)
- local pitch_angle_raw = buffer(offset, 2):le_int()
- local pitch_angle = pitch_angle_raw * 0.01 -- Apply scaling factor
- subtree:add(f_pitch_angle, pitch_angle)
- offset = offset + 2
- -- dissect commanded yaw angle (2 bytes)
- local yaw_angle_raw = buffer(offset, 2):le_int()
- local yaw_angle = yaw_angle_raw * 0.01 -- Apply scaling factor
- subtree:add(f_yaw_angle, yaw_angle)
- offset = offset + 2
- end
- end
- ----------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_28(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("PowerSystemData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("PowerSystemData.epoch_time", "Epoch Time", base.DES)
- local f_innovation_x = ProtoField.int16("PowerSystemData.innovation_x", "Innovation Vector X", base.DEC)
- local f_innovation_y = ProtoField.int16("PowerSystemData.innovation_y", "Innovation Vector Y", base.DEC)
- local f_innovation_z = ProtoField.int16("PowerSystemData.innovation_z", "Innovation Vector Z", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_innovation_x, f_innovation_y, f_innovation_z
- }
- -- Loop through the data (data3 could represent the number of iterations or packets to dissect)
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_28")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect innovation vector X (2 bytes)
- local innovation_x_raw = buffer(offset, 2):le_int()
- local innovation_x = innovation_x_raw * 0.001 -- Apply scaling factor
- subtree:add(f_innovation_x, innovation_x)
- offset = offset + 2
- -- dissect innovation vector Y (2 bytes)
- local innovation_y_raw = buffer(offset, 2):le_int()
- local innovation_y = innovation_y_raw * 0.001 -- Apply scaling factor
- subtree:add(f_innovation_y, innovation_y)
- offset = offset + 2
- -- dissect innovation vector Z (2 bytes)
- local innovation_z_raw = buffer(offset, 2):le_int()
- local innovation_z = innovation_z_raw * 0.001 -- Apply scaling factor
- subtree:add(f_innovation_z, innovation_z)
- offset = offset + 2
- end
- end
- ---------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_27(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("PowerSystemData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("PowerSystemData.epoch_time", "Epoch Time", base.DES)
- local f_x_gyro_bias = ProtoField.int16("PowerSystemData.x_gyro_bias", "Estimated X-Gyro Bias", base.DEC)
- local f_y_gyro_bias = ProtoField.int16("PowerSystemData.y_gyro_bias", "Estimated Y-Gyro Bias", base.DEC)
- local f_z_gyro_bias = ProtoField.int16("PowerSystemData.z_gyro_bias", "Estimated Z-Gyro Bias", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_gyro_bias, f_y_gyro_bias, f_z_gyro_bias
- }
- -- Loop through the data (data3 could represent the number of iterations or packets to dissect)
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_27")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect estimated x-gyro bias (2 bytes)
- local x_gyro_bias_raw = buffer(offset, 2):le_int()
- local x_gyro_bias = x_gyro_bias_raw * 0.001 -- Apply scaling factor
- subtree:add(f_x_gyro_bias, x_gyro_bias)
- offset = offset + 2
- -- dissect estimated y-gyro bias (2 bytes)
- local y_gyro_bias_raw = buffer(offset, 2):le_int()
- local y_gyro_bias = y_gyro_bias_raw * 0.001 -- Apply scaling factor
- subtree:add(f_y_gyro_bias, y_gyro_bias)
- offset = offset + 2
- -- dissect estimated z-gyro bias (2 bytes)
- local z_gyro_bias_raw = buffer(offset, 2):le_int()
- local z_gyro_bias = z_gyro_bias_raw * 0.001 -- Apply scaling factor
- subtree:add(f_z_gyro_bias, z_gyro_bias)
- offset = offset + 2
- end
- end
- ----------------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_26(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("PowerSystemData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("PowerSystemData.epoch_time", "Epoch Time", base.DES)
- local f_q1_error = ProtoField.int16("PowerSystemData.q1_error", "Quaternion Error - Q1", base.DEC)
- local f_q2_error = ProtoField.int16("PowerSystemData.q2_error", "Quaternion Error - Q2", base.DEC)
- local f_q3_error = ProtoField.int16("PowerSystemData.q3_error", "Quaternion Error - Q3", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_q1_error, f_q2_error, f_q3_error
- }
- -- Loop through the data (data3 could represent the number of iterations or packets to dissect)
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_26")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect quaternion error Q1 (2 bytes)
- local q1_error_raw = buffer(offset, 2):le_int()
- local q1_error = q1_error_raw * 0.01 -- Apply scaling factor
- subtree:add(f_q1_error, q1_error)
- offset = offset + 2
- -- dissect quaternion error Q2 (2 bytes)
- local q2_error_raw = buffer(offset, 2):le_int()
- local q2_error = q2_error_raw * 0.01 -- Apply scaling factor
- subtree:add(f_q2_error, q2_error)
- offset = offset + 2
- -- dissect quaternion error Q3 (2 bytes)
- local q3_error_raw = buffer(offset, 2):le_int()
- local q3_error = q3_error_raw * 0.01 -- Apply scaling factor
- subtree:add(f_q3_error, q3_error)
- offset = offset + 2
- end
- end
- -----------------------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_25(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("PowerSystemData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("PowerSystemData.epoch_time", "Epoch Time", base.DES)
- local f_x_magnetic_field = ProtoField.int16("PowerSystemData.x_magnetic_field", "X axis Modelled Magnetic Field Vector", base.DEC)
- local f_y_magnetic_field = ProtoField.int16("PowerSystemData.y_magnetic_field", "Y axis Modelled Magnetic Field Vector", base.DEC)
- local f_z_magnetic_field = ProtoField.int16("PowerSystemData.z_magnetic_field", "Z axis Modelled Magnetic Field Vector", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_magnetic_field, f_y_magnetic_field, f_z_magnetic_field
- }
- -- Loop through the data (data3 could represent the number of iterations or packets to dissect)
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_25")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect x-axis magnetic field vector (2 bytes)
- local x_magnetic_field_raw = buffer(offset, 2):le_int()
- local x_magnetic_field = x_magnetic_field_raw -- Apply scaling factor
- subtree:add(f_x_magnetic_field, x_magnetic_field)
- offset = offset + 2
- -- dissect y-axis magnetic field vector (2 bytes)
- local y_magnetic_field_raw = buffer(offset, 2):le_int()
- local y_magnetic_field = y_magnetic_field_raw -- Apply scaling factor
- subtree:add(f_y_magnetic_field, y_magnetic_field)
- offset = offset + 2
- -- dissect z-axis magnetic field vector (2 bytes)
- local z_magnetic_field_raw = buffer(offset, 2):le_int()
- local z_magnetic_field = z_magnetic_field_raw -- Apply scaling factor
- subtree:add(f_z_magnetic_field, z_magnetic_field)
- offset = offset + 2
- end
- end
- ---------------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_24(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("PowerSystemData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("PowerSystemData.epoch_time", "Epoch Time", base.DES)
- local f_geo_longitude = ProtoField.int16("PowerSystemData.geo_longitude", "Geocentric Longitude", base.DEC)
- local f_geo_latitude = ProtoField.int16("PowerSystemData.geo_latitude", "Geocentric Latitude", base.DEC)
- local f_geo_altitude = ProtoField.int16("PowerSystemData.geo_altitude", "Geocentric Altitude", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_geo_longitude, f_geo_latitude, f_geo_altitude
- }
- -- Loop through the data (data3 could represent the number of iterations or packets to dissect)
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_24")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect geocentric longitude (2 bytes)
- local geo_longitude_raw = buffer(offset, 2):le_int()
- local geo_longitude = geo_longitude_raw * 0.01 -- Apply scaling factor
- subtree:add(f_geo_longitude, geo_longitude)
- offset = offset + 2
- -- dissect geocentric latitude (2 bytes)
- local geo_latitude_raw = buffer(offset, 2):le_int()
- local geo_latitude = geo_latitude_raw * 0.01 -- Apply scaling factor
- subtree:add(f_geo_latitude, geo_latitude)
- offset = offset + 2
- -- dissect geocentric altitude (2 bytes)
- local geo_altitude_raw = buffer(offset, 2):le_int()
- local geo_altitude = geo_altitude_raw * 0.1 -- Apply scaling factor
- subtree:add(f_geo_altitude, geo_altitude)
- offset = offset + 2
- end
- end
- ----------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_23(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("StarTrackerData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("StarTrackerData.epoch_time", "Epoch Time", base.DES)
- local f_num_stars_detected = ProtoField.uint8("StarTrackerData.num_stars_detected", "Number of Stars Detected", base.DES)
- local f_star_image_noise = ProtoField.uint8("StarTrackerData.star_image_noise", "Star Image Noise", base.DES)
- local f_invalid_star = ProtoField.uint8("StarTrackerData.invalid_star", "Invalid Star", base.DES)
- local f_num_stars_identified = ProtoField.uint8("StarTrackerData.num_stars_identified", "Number of Stars Identified", base.DES)
- local f_ident_mode = ProtoField.uint8("StarTrackerData.ident_mode", "Identification Mode", base.ENUM)
- local f_image_dark_value = ProtoField.uint8("StarTrackerData.image_dark_value", "Image Dark Value", base.DES)
- local f_flags = ProtoField.uint8("StarTrackerData.flags", "Flags", base.HEX)
- -- Define ProtoFields for star confidence and magnitudes
- local f_star_conf_1 = ProtoField.uint8("StarTrackerData.star_conf_1", "Star 1 Confidence", base.PERCENT)
- local f_star_conf_2 = ProtoField.uint8("StarTrackerData.star_conf_2", "Star 2 Confidence", base.PERCENT)
- local f_star_conf_3 = ProtoField.uint8("StarTrackerData.star_conf_3", "Star 3 Confidence", base.PERCENT)
- local f_instrument_mag_1 = ProtoField.uint16("StarTrackerData.instrument_mag_1", "Instrument Magnitude Star 1", base.DEC)
- local f_instrument_mag_2 = ProtoField.uint16("StarTrackerData.instrument_mag_2", "Instrument Magnitude Star 2", base.DEC)
- local f_instrument_mag_3 = ProtoField.uint16("StarTrackerData.instrument_mag_3", "Instrument Magnitude Star 3", base.DEC)
- local f_instrument_mag_4 = ProtoField.uint16("StarTrackerData.instrument_mag_4", "Instrument Magnitude Star 4", base.DEC)
- -- Define ProtoFields for capture, detection, identification
- local f_capture = ProtoField.uint16("StarTrackerData.capture", "Capture", base.DEC)
- local f_detection = ProtoField.uint16("StarTrackerData.detection", "Detection", base.DEC)
- local f_identification = ProtoField.uint16("StarTrackerData.identification", "Identification", base.DEC)
- -- Define ProtoFields for the estimated rates (X and Y axes)
- local f_est_rate_x = ProtoField.int16("StarTrackerData.est_rate_x", "Estimated Rate X-axis", base.DEC)
- local f_est_rate_y = ProtoField.int16("StarTrackerData.est_rate_y", "Estimated Rate Y-axis", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_num_stars_detected, f_star_image_noise, f_invalid_star,
- f_num_stars_identified, f_ident_mode, f_image_dark_value, f_flags,
- f_star_conf_1, f_star_conf_2, f_star_conf_3,
- f_instrument_mag_1, f_instrument_mag_2, f_instrument_mag_3, f_instrument_mag_4,
- f_capture, f_detection, f_identification, f_est_rate_x, f_est_rate_y
- }
- -- Loop through the data (data3 could represent the number of iterations or packets to dissect)
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_23")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect number of stars detected (1 byte)
- local num_stars_detected = buffer(offset, 1):le_uint()
- subtree:add(f_num_stars_detected, num_stars_detected)
- offset = offset + 1
- -- dissect star image noise (1 byte)
- local star_image_noise = buffer(offset, 1):le_uint()
- subtree:add(f_star_image_noise, star_image_noise)
- offset = offset + 1
- -- dissect invalid star (1 byte)
- local invalid_star = buffer(offset, 1):le_uint()
- subtree:add(f_invalid_star, invalid_star)
- offset = offset + 1
- -- dissect number of stars identified (1 byte)
- local num_stars_identified = buffer(offset, 1):le_uint()
- subtree:add(f_num_stars_identified, num_stars_identified)
- offset = offset + 1
- -- dissect identification mode (1 byte, enum)
- local ident_mode = buffer(offset, 1):le_uint()
- subtree:add(f_ident_mode, ident_mode)
- offset = offset + 1
- -- dissect image dark value (1 byte)
- local image_dark_value = buffer(offset, 1):le_uint()
- subtree:add(f_image_dark_value, image_dark_value)
- offset = offset + 1
- -- dissect flags (8 flags, 1 byte)
- local flags = buffer(offset, 1):le_uint()
- subtree:add(f_flags, flags)
- offset = offset + 1
- -- dissect star confidences (1 byte each)
- local star_conf_1 = buffer(offset, 1):le_uint()
- subtree:add(f_star_conf_1, star_conf_1)
- offset = offset + 1
- local star_conf_2 = buffer(offset, 1):le_uint()
- subtree:add(f_star_conf_2, star_conf_2)
- offset = offset + 1
- local star_conf_3 = buffer(offset, 1):le_uint()
- subtree:add(f_star_conf_3, star_conf_3)
- offset = offset + 1
- -- dissect instrument magnitudes (2 bytes each)
- local instrument_mag_1 = buffer(offset, 2):le_uint()
- subtree:add(f_instrument_mag_1, instrument_mag_1)
- offset = offset + 2
- local instrument_mag_2 = buffer(offset, 2):le_uint()
- subtree:add(f_instrument_mag_2, instrument_mag_2)
- offset = offset + 2
- local instrument_mag_3 = buffer(offset, 2):le_uint()
- subtree:add(f_instrument_mag_3, instrument_mag_3)
- offset = offset + 2
- local instrument_mag_4 = buffer(offset, 2):le_uint()
- subtree:add(f_instrument_mag_4, instrument_mag_4)
- offset = offset + 2
- -- dissect capture, detection, and identification (2 bytes each)
- local capture = buffer(offset, 2):le_uint()
- subtree:add(f_capture, capture)
- offset = offset + 2
- local detection = buffer(offset, 2):le_uint()
- subtree:add(f_detection, detection)
- offset = offset + 2
- local identification = buffer(offset, 2):le_uint()
- subtree:add(f_identification, identification)
- offset = offset + 2
- -- dissect estimated rate X-axis (2 bytes)
- local est_rate_x_raw = buffer(offset, 2):le_int()
- local est_rate_x = est_rate_x_raw -- Apply scaling factor
- subtree:add(f_est_rate_x, est_rate_x)
- offset = offset + 2
- -- dissect estimated rate Y-axis (2 bytes)
- local est_rate_y_raw = buffer(offset, 2):le_int()
- local est_rate_y = est_rate_y_raw -- Apply scaling factor
- subtree:add(f_est_rate_y, est_rate_y)
- offset = offset + 2
- end
- end
- -------------------------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the new structure
- function adcs_dissector_22(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("StarTrackerData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("StarTrackerData.epoch_time", "Epoch Time", base.DES)
- local f_css_ad_values = ProtoField.uint8("StarTrackerData.css_ad_value_","CSS A/D Value ", base.HEX)
- -- Define the ProtoField for the array of CSS A/D values (10 values of 1 byte each)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_css_ad_values
- }
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_22")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect CSS A/D values (array of 10 1-byte values)
- for i = 1, 10 do
- local css_ad_value = buffer(offset, 1):le_uint()
- subtree:add(f_css_ad_values, css_ad_value)
- offset = offset + 1
- end
- end
- end
- ------------------------------------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the Magnetorquer data
- function adcs_dissector_21(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("MagnetorquerData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("MagnetorquerData.epoch_time", "Epoch Time", base.DES)
- local f_x_magnetorquer_time = ProtoField.int16("MagnetorquerData.x_magnetorquer_time", "X Magnetorquer Commanded On-time (10ms)", base.DEC)
- local f_y_magnetorquer_time = ProtoField.int16("MagnetorquerData.y_magnetorquer_time", "Y Magnetorquer Commanded On-time (10ms)", base.DEC)
- local f_z_magnetorquer_time = ProtoField.int16("MagnetorquerData.z_magnetorquer_time", "Z Magnetorquer Commanded On-time (10ms)", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_magnetorquer_time, f_y_magnetorquer_time, f_z_magnetorquer_time
- }
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_21")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect X Magnetorquer Commanded on-time (2 bytes)
- local x_magnetorquer_time = buffer(offset, 2):le_int()
- subtree:add(f_x_magnetorquer_time, x_magnetorquer_time)
- offset = offset + 2
- -- dissect Y Magnetorquer Commanded on-time (2 bytes)
- local y_magnetorquer_time = buffer(offset, 2):le_int()
- subtree:add(f_y_magnetorquer_time, y_magnetorquer_time)
- offset = offset + 2
- -- dissect Z Magnetorquer Commanded on-time (2 bytes)
- local z_magnetorquer_time = buffer(offset, 2):le_int()
- subtree:add(f_z_magnetorquer_time, z_magnetorquer_time)
- offset = offset + 2
- end
- end
- -----------------------------------------------------------------------------------------
- -- Define the dissector function for the Reaction Wheel data
- function adcs_dissector_20(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("ReactionWheelData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("ReactionWheelData.epoch_time", "Epoch Time", base.DES)
- local f_num_reaction_wheels = ProtoField.uint8("ReactionWheelData.num_reaction_wheels", "Number of Reaction Wheels", base.DES)
- local f_wheel_speed = ProtoField.uint16("ReactionWheelData.wheel_speed_", "Measured Wheel Speed ", base.DEC)
- -- Define the ProtoField for the array of Measured Wheel Speeds (N = 3, each 2 bytes)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_num_reaction_wheels, f_wheel_speed
- }
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_20")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect number of reaction wheels (1 byte)
- local num_reaction_wheels = buffer(offset, 1):le_uint()
- subtree:add(f_num_reaction_wheels, num_reaction_wheels)
- offset = offset + 1
- -- dissect wheel speeds (array of N * 2 bytes, with N = 3)
- for i = 1, num_reaction_wheels do
- local wheel_speed = buffer(offset, 2):le_uint()
- subtree:add(f_wheel_speed, wheel_speed)
- offset = offset + 2
- end
- end
- end
- -----------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the Reaction Wheel Commanded Speed data
- function adcs_dissector_19(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the new structure fields
- local f_op_status = ProtoField.uint8("ReactionWheelData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("ReactionWheelData.epoch_time", "Epoch Time", base.DES)
- local f_num_reaction_wheels = ProtoField.uint8("ReactionWheelData.num_reaction_wheels", "Number of Reaction Wheels", base.DES)
- f_wheel_speed_cmd = ProtoField.uint16("ReactionWheelData.wheel_speed_cmd_","Commanded Wheel Speed ", base.DEC)
- -- Define the ProtoField for the array of Commanded Wheel Speeds (N = 3, each 2 bytes)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_num_reaction_wheels,f_wheel_speed_cmd
- }
- for i = 1, data3 do
- -- Add the new structure data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_19")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect number of reaction wheels (1 byte)
- local num_reaction_wheels = buffer(offset, 1):le_uint()
- subtree:add(f_num_reaction_wheels, num_reaction_wheels)
- offset = offset + 1
- -- dissect commanded wheel speeds (array of N * 2 bytes, with N = 3)
- for i = 1, 3 do -- value 3 is fixed in structure
- local wheel_speed_cmd = buffer(offset, 2):le_uint()
- subtree:add(f_wheel_speed_cmd, wheel_speed_cmd)
- offset = offset + 2
- end
- end
- end
- -----------------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the FSS Data
- function adcs_dissector_17(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the FSS Data structure
- local f_op_status = ProtoField.uint8("FSSData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("FSSData.epoch_time", "Epoch Time", base.DES)
- local f_x_angle = ProtoField.int16("FSSData.x_angle", "FSS Raw X Angle", base.DEC)
- local f_y_angle = ProtoField.int16("FSSData.y_angle", "FSS Raw Y Angle", base.DEC)
- local f_capture_status = ProtoField.uint8("FSSData.capture_status", "FSS Capture Status", base.HEX)
- local f_detection_result = ProtoField.uint8("FSSData.detection_result", "FSS Detection Result", base.HEX)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_angle, f_y_angle, f_capture_status, f_detection_result
- }
- for i = 1, data3 do
- -- Add the FSS data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_17")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect FSS raw X angle (2 bytes)
- local x_angle = buffer(offset, 2):le_int16()
- subtree:add(f_x_angle, x_angle)
- offset = offset + 2
- -- dissect FSS raw Y angle (2 bytes)
- local y_angle = buffer(offset, 2):le_int()
- subtree:add(f_y_angle, y_angle)
- offset = offset + 2
- -- dissect FSS capture status (1 byte, enum)
- local capture_status = buffer(offset, 1):le_uint()
- subtree:add(f_capture_status, capture_status)
- offset = offset + 1
- -- dissect FSS detection result (1 byte, enum)
- local detection_result = buffer(offset, 1):le_uint()
- subtree:add(f_detection_result, detection_result)
- offset = offset + 1
- end
- end
- --------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the Fine Estimated Angular Rates Data
- function adcs_dissector_14(buffer, pinfo, tree, HM_TM_dissector, offset, len,data3)
- -- Define ProtoFields for the Fine Estimated Angular Rates structure
- local f_op_status = ProtoField.uint8("AngularRateData.op_status", "Operation Status", base.DES)
- local f_epoch_time = ProtoField.uint32("AngularRateData.epoch_time", "Epoch Time", base.DES)
- local f_x_angular_rate = ProtoField.int16("AngularRateData.x_angular_rate", "Fine Estimated X Angular Rate", base.DEC)
- local f_y_angular_rate = ProtoField.int16("AngularRateData.y_angular_rate", "Fine Estimated Y Angular Rate", base.DEC)
- local f_z_angular_rate = ProtoField.int16("AngularRateData.z_angular_rate", "Fine Estimated Z Angular Rate", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_angular_rate, f_y_angular_rate, f_z_angular_rate
- }
- for i = 1, data3 do
- -- Add the Fine Estimated Angular Rates data as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_14")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect Fine Estimated X Angular Rate (2 bytes, formatted value = RAWVAL*0.001)
- local x_angular_rate = buffer(offset, 2):le_int()
- subtree:add(f_x_angular_rate, x_angular_rate)
- offset = offset + 2
- -- dissect Fine Estimated Y Angular Rate (2 bytes, formatted value = RAWVAL*0.001)
- local y_angular_rate = buffer(offset, 2):le_int()
- subtree:add(f_y_angular_rate, y_angular_rate)
- offset = offset + 2
- -- dissect Fine Estimated Z Angular Rate (2 bytes, formatted value = RAWVAL*0.001)
- local z_angular_rate = buffer(offset, 2):le_int()
- subtree:add(f_z_angular_rate, z_angular_rate)
- offset = offset + 2
- end
- end
- -----------------------------------------------------------------------------------------------------------
- -- Define the dissector function for the Rate Sensor Temperature Data
- function adcs_dissector_12(buffer, pinfo, tree, HM_TM_dissector, offset, len, data3)
- -- Define ProtoFields for the structure (adjust names as per your needs)
- local f_op_status = ProtoField.uint8("RateSensorData.op_status", "Operation Status", base.HEX)
- local f_epoch_time = ProtoField.uint32("RateSensorData.epoch_time", "Epoch Time", base.DEC)
- local f_x_rate_temp = ProtoField.int16("RateSensorData.x_rate_temp", "X Rate Sensor Temperature", base.DEC)
- local f_y_rate_temp = ProtoField.int16("RateSensorData.y_rate_temp", "Y Rate Sensor Temperature", base.DEC)
- local f_z_rate_temp = ProtoField.int16("RateSensorData.z_rate_temp", "Z Rate Sensor Temperature", base.DEC)
- -- Add the fields to the protocol
- HM_TM_dissector.fields = {
- f_op_status, f_epoch_time, f_x_rate_temp, f_y_rate_temp, f_z_rate_temp
- }
- -- Loop to process multiple data3 (if needed, as per your structure)
- for i = 1, data3 do
- -- Add the data structure as a subtree
- local subtree = tree:add(TC_TM_PROTOCOL, buffer(), "adcs_qid_12")
- -- dissect operation status (1 byte)
- local op_status = buffer(offset, 1):le_uint()
- subtree:add(f_op_status, op_status)
- offset = offset + 1
- -- dissect epoch time (4 bytes)
- local epoch_time = buffer(offset, 4):le_uint()
- subtree:add(f_epoch_time, epoch_time)
- offset = offset + 4
- -- dissect X Rate Sensor Temperature (2 bytes, formatted value = RAWVAL)
- local x_rate_temp = buffer(offset, 2):le_int()
- subtree:add(f_x_rate_temp, x_rate_temp)
- offset = offset + 2
- -- dissect Y Rate Sensor Temperature (2 bytes, formatted value = RAWVAL)
- local y_rate_temp = buffer(offset, 2):le_int()
- subtree:add(f_y_rate_temp, y_rate_temp)
- offset = offset + 2
- -- dissect Z Rate Sensor Temperature (2 bytes, formatted value = RAWVAL)
- local z_rate_temp = buffer(offset, 2):le_int()
- subtree:add(f_z_rate_temp, z_rate_temp)
- offset = offset + 2
- end
- end
- --------------------------------------------------------------------------------------------------------------------
|