Commit c071e3d8 authored by Don Gagne's avatar Don Gagne

Correctly set fragment information

parent 6e63553b
...@@ -41,16 +41,25 @@ void RTCMMavlink::RTCMDataUpdate(QByteArray message) ...@@ -41,16 +41,25 @@ void RTCMMavlink::RTCMDataUpdate(QByteArray message)
memcpy(&mavlinkRtcmData.data, message.data(), message.size()); memcpy(&mavlinkRtcmData.data, message.data(), message.size());
sendMessageToVehicle(mavlinkRtcmData); sendMessageToVehicle(mavlinkRtcmData);
} else { } else {
//we need to fragment // We need to fragment
static uint8_t sequenceId = 0; // Sequence id is used to indicate that the individual fragements belong to the same set
uint8_t fragmentId = 0; // Fragment id indicates the fragement within a set
int start = 0; int start = 0;
while (start < message.size()) { while (start < message.size()) {
int length = std::min(message.size() - start, maxMessageLength); int length = std::min(message.size() - start, maxMessageLength);
mavlinkRtcmData.flags = 1; //fragmented mavlinkRtcmData.flags = 1; // LSB set indicates messsage is fragmented
mavlinkRtcmData.flags |= fragmentId++ << 1; // Next 2 bits are fragment id
mavlinkRtcmData.flags |= sequenceId++ << 3; // Next 5 bits are sequence id
mavlinkRtcmData.len = length; mavlinkRtcmData.len = length;
memcpy(&mavlinkRtcmData.data, message.data() + start, length); memcpy(&mavlinkRtcmData.data, message.data() + start, length);
sendMessageToVehicle(mavlinkRtcmData); sendMessageToVehicle(mavlinkRtcmData);
start += length; start += length;
} }
if (sequenceId == 0x1F) {
sequenceId = 0;
}
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment