AP_Arming: Added DDS Method for Arming/Disarming
This commit is contained in:
parent
7f8df080f8
commit
5f17e33b39
@ -623,7 +623,7 @@ bool AP_Arming_Copter::arm_checks(AP_Arming::Method method)
|
||||
const char *rc_item = "Throttle";
|
||||
#endif
|
||||
// check throttle is not too high - skips checks if arming from GCS/scripting in Guided,Guided_NoGPS or Auto
|
||||
if (!((method == AP_Arming::Method::MAVLINK || method == AP_Arming::Method::SCRIPTING) && (copter.flightmode->mode_number() == Mode::Number::GUIDED || copter.flightmode->mode_number() == Mode::Number::GUIDED_NOGPS || copter.flightmode->mode_number() == Mode::Number::AUTO))) {
|
||||
if (!((AP_Arming::method_is_GCS(method) || method == AP_Arming::Method::SCRIPTING) && (copter.flightmode->mode_number() == Mode::Number::GUIDED || copter.flightmode->mode_number() == Mode::Number::GUIDED_NOGPS || copter.flightmode->mode_number() == Mode::Number::AUTO))) {
|
||||
// above top of deadband is too always high
|
||||
if (copter.get_pilot_desired_climb_rate(copter.channel_throttle->get_control_in()) > 0.0f) {
|
||||
check_failed(ARMING_CHECK_RC, true, "%s too high", rc_item);
|
||||
@ -790,7 +790,7 @@ bool AP_Arming_Copter::disarm(const AP_Arming::Method method, bool do_disarm_che
|
||||
|
||||
// do not allow disarm via mavlink if we think we are flying:
|
||||
if (do_disarm_checks &&
|
||||
method == AP_Arming::Method::MAVLINK &&
|
||||
AP_Arming::method_is_GCS(method) &&
|
||||
!copter.ap.land_complete) {
|
||||
return false;
|
||||
}
|
||||
|
@ -100,7 +100,7 @@ void ModeGuided::run()
|
||||
bool ModeGuided::allows_arming(AP_Arming::Method method) const
|
||||
{
|
||||
// always allow arming from the ground station or scripting
|
||||
if (method == AP_Arming::Method::MAVLINK || method == AP_Arming::Method::SCRIPTING) {
|
||||
if (AP_Arming::method_is_GCS(method) || method == AP_Arming::Method::SCRIPTING) {
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -325,7 +325,7 @@ bool AP_Arming_Plane::arm(const AP_Arming::Method method, const bool do_arming_c
|
||||
bool AP_Arming_Plane::disarm(const AP_Arming::Method method, bool do_disarm_checks)
|
||||
{
|
||||
if (do_disarm_checks &&
|
||||
(method == AP_Arming::Method::MAVLINK ||
|
||||
(AP_Arming::method_is_GCS(method) ||
|
||||
method == AP_Arming::Method::RUDDER)) {
|
||||
if (plane.is_flying()) {
|
||||
// don't allow mavlink or rudder disarm while flying
|
||||
|
@ -1832,6 +1832,7 @@ void AP_Arming::check_forced_logging(const AP_Arming::Method method)
|
||||
case Method::TOYMODELANDTHROTTLE:
|
||||
case Method::TOYMODELANDFORCE:
|
||||
case Method::LANDING:
|
||||
case Method::DDS:
|
||||
case Method::UNKNOWN:
|
||||
AP::logger().set_long_log_persist(false);
|
||||
return;
|
||||
|
@ -78,6 +78,7 @@ public:
|
||||
LANDING = 32, // only disarm uses this...
|
||||
DEADRECKON_FAILSAFE = 33, // only disarm uses this...
|
||||
BLACKBOX = 34,
|
||||
DDS = 35,
|
||||
UNKNOWN = 100,
|
||||
};
|
||||
|
||||
@ -144,6 +145,9 @@ public:
|
||||
return (_arming_options & uint32_t(option)) != 0;
|
||||
}
|
||||
|
||||
static bool method_is_GCS(Method method) {
|
||||
return (method == Method::MAVLINK || method == Method::DDS);
|
||||
}
|
||||
protected:
|
||||
|
||||
// Parameters
|
||||
|
Loading…
Reference in New Issue
Block a user