mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-08 17:08:28 -04:00
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:
parent
13722b8858
commit
0bbddd38cf
@ -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,
|
||||||
|
Loading…
Reference in New Issue
Block a user