Copter: implement FLTMODE_GCSBLOCK bitmask
This commit is contained in:
parent
df8aee1567
commit
678017c577
@ -857,6 +857,9 @@ private:
|
|||||||
void update_flight_mode();
|
void update_flight_mode();
|
||||||
void notify_flight_mode();
|
void notify_flight_mode();
|
||||||
|
|
||||||
|
// Check if this mode can be entered from the GCS
|
||||||
|
bool gcs_mode_enabled(const Mode::Number mode_num);
|
||||||
|
|
||||||
// mode_land.cpp
|
// mode_land.cpp
|
||||||
void set_mode_land_with_pause(ModeReason reason);
|
void set_mode_land_with_pause(ModeReason reason);
|
||||||
bool landing_with_GPS();
|
bool landing_with_GPS();
|
||||||
|
@ -194,6 +194,52 @@ void Copter::mode_change_failed(const Mode *mode, const char *reason)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check if this mode can be entered from the GCS
|
||||||
|
bool Copter::gcs_mode_enabled(const Mode::Number mode_num)
|
||||||
|
{
|
||||||
|
// List of modes that can be blocked, index is bit number in parameter bitmask
|
||||||
|
static const uint8_t mode_list [] {
|
||||||
|
(uint8_t)Mode::Number::STABILIZE,
|
||||||
|
(uint8_t)Mode::Number::ACRO,
|
||||||
|
(uint8_t)Mode::Number::ALT_HOLD,
|
||||||
|
(uint8_t)Mode::Number::AUTO,
|
||||||
|
(uint8_t)Mode::Number::GUIDED,
|
||||||
|
(uint8_t)Mode::Number::LOITER,
|
||||||
|
(uint8_t)Mode::Number::CIRCLE,
|
||||||
|
(uint8_t)Mode::Number::DRIFT,
|
||||||
|
(uint8_t)Mode::Number::SPORT,
|
||||||
|
(uint8_t)Mode::Number::FLIP,
|
||||||
|
(uint8_t)Mode::Number::AUTOTUNE,
|
||||||
|
(uint8_t)Mode::Number::POSHOLD,
|
||||||
|
(uint8_t)Mode::Number::BRAKE,
|
||||||
|
(uint8_t)Mode::Number::THROW,
|
||||||
|
(uint8_t)Mode::Number::AVOID_ADSB,
|
||||||
|
(uint8_t)Mode::Number::GUIDED_NOGPS,
|
||||||
|
(uint8_t)Mode::Number::SMART_RTL,
|
||||||
|
(uint8_t)Mode::Number::FLOWHOLD,
|
||||||
|
(uint8_t)Mode::Number::FOLLOW,
|
||||||
|
(uint8_t)Mode::Number::ZIGZAG,
|
||||||
|
(uint8_t)Mode::Number::SYSTEMID,
|
||||||
|
(uint8_t)Mode::Number::AUTOROTATE,
|
||||||
|
(uint8_t)Mode::Number::AUTO_RTL,
|
||||||
|
(uint8_t)Mode::Number::TURTLE
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!block_GCS_mode_change((uint8_t)mode_num, mode_list, ARRAY_SIZE(mode_list))) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Mode disabled, try and grab a mode name to give a better warning.
|
||||||
|
Mode *new_flightmode = mode_from_mode_num(mode_num);
|
||||||
|
if (new_flightmode != nullptr) {
|
||||||
|
mode_change_failed(new_flightmode, "GCS entry disabled (FLTMODE_GCSBLOCK)");
|
||||||
|
} else {
|
||||||
|
notify_no_such_mode((uint8_t)mode_num);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// set_mode - change flight mode and perform any necessary initialisation
|
// set_mode - change flight mode and perform any necessary initialisation
|
||||||
// optional force parameter used to force the flight mode change (used only first time mode is set)
|
// optional force parameter used to force the flight mode change (used only first time mode is set)
|
||||||
// returns true if mode was successfully set
|
// returns true if mode was successfully set
|
||||||
@ -218,6 +264,11 @@ bool Copter::set_mode(Mode::Number mode, ModeReason reason)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check if GCS mode change is disabled via parameter
|
||||||
|
if ((reason == ModeReason::GCS_COMMAND) && !gcs_mode_enabled(mode)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
#if MODE_AUTO_ENABLED == ENABLED
|
#if MODE_AUTO_ENABLED == ENABLED
|
||||||
if (mode == Mode::Number::AUTO_RTL) {
|
if (mode == Mode::Number::AUTO_RTL) {
|
||||||
// Special case for AUTO RTL, not a true mode, just AUTO in disguise
|
// Special case for AUTO RTL, not a true mode, just AUTO in disguise
|
||||||
|
Loading…
Reference in New Issue
Block a user