mirror of https://github.com/ArduPilot/ardupilot
AP_CRSF_Telem: adjusted status text frame size based on actually used bytes
This commit is contained in:
parent
1850851869
commit
b97e335940
|
@ -96,7 +96,7 @@ void AP_CRSF_Telem::setup_custom_telemetry()
|
|||
}
|
||||
|
||||
// check if passthru already assigned
|
||||
const int8_t frsky_port = AP::serialmanager().find_portnum(AP_SerialManager::SerialProtocol_FrSky_SPort_Passthrough,0);
|
||||
const int8_t frsky_port = AP::serialmanager().find_portnum(AP_SerialManager::SerialProtocol_FrSky_SPort_Passthrough,0);
|
||||
if (frsky_port != -1) {
|
||||
gcs().send_text(MAV_SEVERITY_CRITICAL, "CRSF: passthrough telemetry conflict on SERIAL%d",frsky_port);
|
||||
_custom_telem.init_done = true;
|
||||
|
@ -1279,10 +1279,11 @@ void AP_CRSF_Telem::calc_status_text()
|
|||
_telem_type = get_custom_telem_frame_id();
|
||||
_telem.bcast.custom_telem.status_text.sub_type = AP_RCProtocol_CRSF::CustomTelemSubTypeID::CRSF_AP_CUSTOM_TELEM_STATUS_TEXT;
|
||||
_telem.bcast.custom_telem.status_text.severity = _statustext.next.severity;
|
||||
strncpy_noterm(_telem.bcast.custom_telem.status_text.text, _statustext.next.text, PASSTHROUGH_STATUS_TEXT_FRAME_MAX_SIZE);
|
||||
// add a potentially missing terminator
|
||||
_telem.bcast.custom_telem.status_text.text[PASSTHROUGH_STATUS_TEXT_FRAME_MAX_SIZE-1] = 0;
|
||||
_telem_size = 2 + PASSTHROUGH_STATUS_TEXT_FRAME_MAX_SIZE; // sub_type(1) + severity(1) + text(50)
|
||||
// Note: snprintf() always terminates the string
|
||||
hal.util->snprintf(_telem.bcast.custom_telem.status_text.text, AP_CRSF_Telem::PASSTHROUGH_STATUS_TEXT_FRAME_MAX_SIZE, "%s", _statustext.next.text);
|
||||
// frame size = sub_type(1) + severity(1) + strlen(text) + terminator
|
||||
// Note: strlen(_telem.bcast.custom_telem.status_text.text) is safe because called on a guaranteed null terminated string
|
||||
_telem_size = 2 + strlen(_telem.bcast.custom_telem.status_text.text) + 1;
|
||||
_telem_pending = true;
|
||||
_statustext.available = false;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue