GCS_MAVLink: fixed some places where packets are sent without space

we always need sufficient space for the packet in the send buffer
This commit is contained in:
Andrew Tridgell 2016-05-23 22:02:12 +10:00
parent 13722b8858
commit 0bbddd38cf

View File

@ -239,7 +239,8 @@ void GCS_MAVLINK::send_ahrs2(AP_AHRS &ahrs)
loc.lng); loc.lng);
} }
AP_AHRS_NavEKF &_ahrs = reinterpret_cast<AP_AHRS_NavEKF&>(ahrs); AP_AHRS_NavEKF &_ahrs = reinterpret_cast<AP_AHRS_NavEKF&>(ahrs);
if (_ahrs.get_NavEKF2().activeCores() > 0) { if (_ahrs.get_NavEKF2().activeCores() > 0 &&
HAVE_PAYLOAD_SPACE(chan, AHRS3)) {
_ahrs.get_NavEKF2().getLLH(loc); _ahrs.get_NavEKF2().getLLH(loc);
_ahrs.get_NavEKF2().getEulerAngles(-1,euler); _ahrs.get_NavEKF2().getEulerAngles(-1,euler);
mavlink_msg_ahrs3_send(chan, mavlink_msg_ahrs3_send(chan,
@ -578,6 +579,10 @@ void GCS_MAVLINK::handle_param_request_read(mavlink_message_t *msg)
mavlink_param_request_read_t packet; mavlink_param_request_read_t packet;
mavlink_msg_param_request_read_decode(msg, &packet); mavlink_msg_param_request_read_decode(msg, &packet);
if (!HAVE_PAYLOAD_SPACE(chan, PARAM_VALUE)) {
return;
}
enum ap_var_type p_type; enum ap_var_type p_type;
AP_Param *vp; AP_Param *vp;
char param_name[AP_MAX_NAME_SIZE+1]; char param_name[AP_MAX_NAME_SIZE+1];
@ -1124,6 +1129,9 @@ void GCS_MAVLINK::send_raw_imu(const AP_InertialSensor &ins, const Compass &comp
compass.get_count() <= 1) { compass.get_count() <= 1) {
return; return;
} }
if (!HAVE_PAYLOAD_SPACE(chan, SCALED_IMU2)) {
return;
}
const Vector3f &accel2 = ins.get_accel(1); const Vector3f &accel2 = ins.get_accel(1);
const Vector3f &gyro2 = ins.get_gyro(1); const Vector3f &gyro2 = ins.get_gyro(1);
if (compass.get_count() >= 2) { if (compass.get_count() >= 2) {
@ -1149,6 +1157,9 @@ void GCS_MAVLINK::send_raw_imu(const AP_InertialSensor &ins, const Compass &comp
compass.get_count() <= 2) { compass.get_count() <= 2) {
return; return;
} }
if (!HAVE_PAYLOAD_SPACE(chan, SCALED_IMU3)) {
return;
}
const Vector3f &accel3 = ins.get_accel(2); const Vector3f &accel3 = ins.get_accel(2);
const Vector3f &gyro3 = ins.get_gyro(2); const Vector3f &gyro3 = ins.get_gyro(2);
if (compass.get_count() >= 3) { if (compass.get_count() >= 3) {
@ -1181,7 +1192,8 @@ void GCS_MAVLINK::send_scaled_pressure(AP_Baro &barometer)
(pressure - barometer.get_ground_pressure(0))*0.01f, // hectopascal (pressure - barometer.get_ground_pressure(0))*0.01f, // hectopascal
barometer.get_temperature(0)*100); // 0.01 degrees C barometer.get_temperature(0)*100); // 0.01 degrees C
if (barometer.num_instances() > 1) { if (barometer.num_instances() > 1 &&
HAVE_PAYLOAD_SPACE(chan, SCALED_PRESSURE2)) {
pressure = barometer.get_pressure(1); pressure = barometer.get_pressure(1);
mavlink_msg_scaled_pressure2_send( mavlink_msg_scaled_pressure2_send(
chan, chan,
@ -1191,7 +1203,8 @@ void GCS_MAVLINK::send_scaled_pressure(AP_Baro &barometer)
barometer.get_temperature(1)*100); // 0.01 degrees C barometer.get_temperature(1)*100); // 0.01 degrees C
} }
if (barometer.num_instances() > 2) { if (barometer.num_instances() > 2 &&
HAVE_PAYLOAD_SPACE(chan, SCALED_PRESSURE3)) {
pressure = barometer.get_pressure(2); pressure = barometer.get_pressure(2);
mavlink_msg_scaled_pressure3_send( mavlink_msg_scaled_pressure3_send(
chan, chan,