mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
AP_RCProtocol: protect against invalid data in SBUS
This commit is contained in:
parent
659db36efe
commit
120a8c1b1d
@ -113,11 +113,27 @@ bool AP_RCProtocol_SBUS::sbus_decode(const uint8_t frame[25], uint16_t *values,
|
|||||||
/* note the number of channels decoded */
|
/* note the number of channels decoded */
|
||||||
*num_values = chancount;
|
*num_values = chancount;
|
||||||
|
|
||||||
|
/*
|
||||||
|
as SBUS is such a weak protocol we additionally check if any of
|
||||||
|
the first 4 channels are at or below the minimum value of
|
||||||
|
875. We consider the frame as a failsafe in that case, which
|
||||||
|
means we log the data but won't use it
|
||||||
|
*/
|
||||||
|
bool invalid_data = false;
|
||||||
|
for (uint8_t i=0; i<4; i++) {
|
||||||
|
if (values[i] <= SBUS_SCALE_OFFSET) {
|
||||||
|
invalid_data = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* decode and handle failsafe and frame-lost flags */
|
/* decode and handle failsafe and frame-lost flags */
|
||||||
if (frame[SBUS_FLAGS_BYTE] & (1 << SBUS_FAILSAFE_BIT)) { /* failsafe */
|
if (frame[SBUS_FLAGS_BYTE] & (1 << SBUS_FAILSAFE_BIT)) { /* failsafe */
|
||||||
/* report that we failed to read anything valid off the receiver */
|
/* report that we failed to read anything valid off the receiver */
|
||||||
*sbus_failsafe = true;
|
*sbus_failsafe = true;
|
||||||
*sbus_frame_drop = true;
|
*sbus_frame_drop = true;
|
||||||
|
} else if (invalid_data) {
|
||||||
|
*sbus_failsafe = true;
|
||||||
|
*sbus_frame_drop = false;
|
||||||
} else if (frame[SBUS_FLAGS_BYTE] & (1 << SBUS_FRAMELOST_BIT)) { /* a frame was lost */
|
} else if (frame[SBUS_FLAGS_BYTE] & (1 << SBUS_FRAMELOST_BIT)) { /* a frame was lost */
|
||||||
/* set a special warning flag
|
/* set a special warning flag
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user