AP_Mission: Added force resume for when MIS_RESTART=1
This commit is contained in:
parent
8f76573ed6
commit
0434d496c7
@ -163,10 +163,11 @@ bool AP_Mission::starts_with_takeoff_cmd()
|
||||
/// start_or_resume - if MIS_AUTORESTART=0 this will call resume(), otherwise it will call start()
|
||||
void AP_Mission::start_or_resume()
|
||||
{
|
||||
if (_restart) {
|
||||
if (_restart == 1 && !_force_resume) {
|
||||
start();
|
||||
} else {
|
||||
resume();
|
||||
_force_resume = false;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -303,6 +303,7 @@ public:
|
||||
_flags.state = MISSION_STOPPED;
|
||||
_flags.nav_cmd_loaded = false;
|
||||
_flags.do_cmd_loaded = false;
|
||||
_force_resume = false;
|
||||
}
|
||||
|
||||
// get singleton instance
|
||||
@ -471,6 +472,9 @@ public:
|
||||
// jumps the mission to the closest landing abort that is planned, returns false if unable to find a valid abort
|
||||
bool jump_to_abort_landing_sequence(void);
|
||||
|
||||
// force mission to resume when start_or_resume() is called
|
||||
void set_force_resume(bool force_resume) { _force_resume = force_resume; }
|
||||
|
||||
// get a reference to the AP_Mission semaphore, allowing an external caller to lock the
|
||||
// storage while working with multiple waypoints
|
||||
HAL_Semaphore_Recursive &get_semaphore(void) {
|
||||
@ -567,6 +571,7 @@ private:
|
||||
uint16_t _prev_nav_cmd_id; // id of the previous "navigation" command. (WAYPOINT, LOITER_TO_ALT, ect etc)
|
||||
uint16_t _prev_nav_cmd_index; // index of the previous "navigation" command. Rarely used which is why we don't store the whole command
|
||||
uint16_t _prev_nav_cmd_wp_index; // index of the previous "navigation" command that contains a waypoint. Rarely used which is why we don't store the whole command
|
||||
bool _force_resume; // when set true it forces mission to resume irrespective of MIS_RESTART param.
|
||||
|
||||
// jump related variables
|
||||
struct jump_tracking_struct {
|
||||
|
Loading…
Reference in New Issue
Block a user