aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAnton Babushkin <anton.babushkin@me.com>2014-07-06 21:37:26 +0200
committerAnton Babushkin <anton.babushkin@me.com>2014-07-06 21:37:26 +0200
commit06f08ad04d4cb21047944f350e4a75e88914e1e1 (patch)
tree709116d144045efd8b4fdb08f42d65a08260648f /src
parent829a317d23093894c3d8974cce887ab3c19eba08 (diff)
downloadpx4-firmware-06f08ad04d4cb21047944f350e4a75e88914e1e1.tar.gz
px4-firmware-06f08ad04d4cb21047944f350e4a75e88914e1e1.tar.bz2
px4-firmware-06f08ad04d4cb21047944f350e4a75e88914e1e1.zip
commander: require home position for MISSION, fallback to LOITER
Diffstat (limited to 'src')
-rw-r--r--src/modules/commander/commander.cpp7
-rw-r--r--src/modules/commander/state_machine_helper.cpp2
2 files changed, 8 insertions, 1 deletions
diff --git a/src/modules/commander/commander.cpp b/src/modules/commander/commander.cpp
index efa26eb97..1da364aa5 100644
--- a/src/modules/commander/commander.cpp
+++ b/src/modules/commander/commander.cpp
@@ -1718,6 +1718,13 @@ set_main_state_rc(struct vehicle_status_s *status, struct manual_control_setpoin
}
print_reject_mode(status, "AUTO_MISSION");
+
+ // fallback to LOITER if home position not set
+ res = main_state_transition(status, MAIN_STATE_AUTO_LOITER);
+
+ if (res != TRANSITION_DENIED) {
+ break; // changed successfully or already in this state
+ }
}
// fallback to POSCTL
diff --git a/src/modules/commander/state_machine_helper.cpp b/src/modules/commander/state_machine_helper.cpp
index 423ce2f23..7fb2e08db 100644
--- a/src/modules/commander/state_machine_helper.cpp
+++ b/src/modules/commander/state_machine_helper.cpp
@@ -271,7 +271,6 @@ main_state_transition(struct vehicle_status_s *status, main_state_t new_main_sta
}
break;
- case MAIN_STATE_AUTO_MISSION:
case MAIN_STATE_AUTO_LOITER:
/* need global position estimate */
if (status->condition_global_position_valid) {
@@ -279,6 +278,7 @@ main_state_transition(struct vehicle_status_s *status, main_state_t new_main_sta
}
break;
+ case MAIN_STATE_AUTO_MISSION:
case MAIN_STATE_AUTO_RTL:
/* need global position and home position */
if (status->condition_global_position_valid && status->condition_home_position_valid) {