mirror of
https://github.com/PX4/PX4-Autopilot.git
synced 2026-06-05 22:24:47 +08:00
vmount mavlink input: fix polling for position_setpoint_triplet
The code was violating the rule 'every successfull poll must be followed by an orb_copy'. The result was a busy loop.
This commit is contained in:
@@ -150,9 +150,15 @@ int InputMavlinkROI::update_impl(unsigned int timeout_ms, ControlData **control_
|
|||||||
}
|
}
|
||||||
|
|
||||||
// check whether the position setpoint got updated
|
// check whether the position setpoint got updated
|
||||||
if ((polls[1].revents & POLLIN) && _cur_roi_mode == vehicle_roi_s::VEHICLE_ROI_WPNEXT) {
|
if (polls[1].revents & POLLIN) {
|
||||||
_read_control_data_from_position_setpoint_sub();
|
if (_cur_roi_mode == vehicle_roi_s::VEHICLE_ROI_WPNEXT) {
|
||||||
*control_data = &_control_data;
|
_read_control_data_from_position_setpoint_sub();
|
||||||
|
*control_data = &_control_data;
|
||||||
|
|
||||||
|
} else { // must do an orb_copy() in *every* case
|
||||||
|
position_setpoint_triplet_s position_setpoint_triplet;
|
||||||
|
orb_copy(ORB_ID(position_setpoint_triplet), _position_setpoint_triplet_sub, &position_setpoint_triplet);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user