Copter: add option to disable CIRCLE flight mode
Saves about 2.4kB of flash
This commit is contained in:
parent
e4898e1d60
commit
5b355214fd
@ -25,6 +25,7 @@
|
|||||||
//#define WINCH_ENABLED DISABLED // disable winch support
|
//#define WINCH_ENABLED DISABLED // disable winch support
|
||||||
//#define MODE_AUTO_ENABLED DISABLED // disable auto mode support
|
//#define MODE_AUTO_ENABLED DISABLED // disable auto mode support
|
||||||
//#define MODE_BRAKE_ENABLED DISABLED // disable brake mode support
|
//#define MODE_BRAKE_ENABLED DISABLED // disable brake mode support
|
||||||
|
//#define MODE_CIRCLE_ENABLED DISABLED // disable circle mode support
|
||||||
//#define MODE_DRIFT_ENABLED DISABLED // disable drift mode support
|
//#define MODE_DRIFT_ENABLED DISABLED // disable drift mode support
|
||||||
//#define MODE_GUIDED_ENABLED DISABLED // disable guided mode support
|
//#define MODE_GUIDED_ENABLED DISABLED // disable guided mode support
|
||||||
//#define MODE_GUIDED_NOGPS_ENABLED DISABLED // disable guided/nogps mode support
|
//#define MODE_GUIDED_NOGPS_ENABLED DISABLED // disable guided/nogps mode support
|
||||||
|
@ -485,7 +485,9 @@ private:
|
|||||||
AC_AttitudeControl_t *attitude_control;
|
AC_AttitudeControl_t *attitude_control;
|
||||||
AC_PosControl *pos_control;
|
AC_PosControl *pos_control;
|
||||||
AC_WPNav *wp_nav;
|
AC_WPNav *wp_nav;
|
||||||
|
#if MODE_CIRCLE_ENABLED == ENABLED
|
||||||
AC_Circle *circle_nav;
|
AC_Circle *circle_nav;
|
||||||
|
#endif
|
||||||
|
|
||||||
// System Timers
|
// System Timers
|
||||||
// --------------
|
// --------------
|
||||||
@ -965,7 +967,9 @@ private:
|
|||||||
#if MODE_BRAKE_ENABLED == ENABLED
|
#if MODE_BRAKE_ENABLED == ENABLED
|
||||||
ModeBrake mode_brake;
|
ModeBrake mode_brake;
|
||||||
#endif
|
#endif
|
||||||
|
#if MODE_CIRCLE_ENABLED == ENABLED
|
||||||
ModeCircle mode_circle;
|
ModeCircle mode_circle;
|
||||||
|
#endif
|
||||||
#if MODE_DRIFT_ENABLED == ENABLED
|
#if MODE_DRIFT_ENABLED == ENABLED
|
||||||
ModeDrift mode_drift;
|
ModeDrift mode_drift;
|
||||||
#endif
|
#endif
|
||||||
|
@ -602,9 +602,11 @@ const AP_Param::Info Copter::var_info[] = {
|
|||||||
// @Path: ../libraries/AC_WPNav/AC_WPNav.cpp
|
// @Path: ../libraries/AC_WPNav/AC_WPNav.cpp
|
||||||
GOBJECTPTR(wp_nav, "WPNAV_", AC_WPNav),
|
GOBJECTPTR(wp_nav, "WPNAV_", AC_WPNav),
|
||||||
|
|
||||||
|
#if MODE_CIRCLE_ENABLED == ENABLED
|
||||||
// @Group: CIRCLE_
|
// @Group: CIRCLE_
|
||||||
// @Path: ../libraries/AC_WPNav/AC_Circle.cpp
|
// @Path: ../libraries/AC_WPNav/AC_Circle.cpp
|
||||||
GOBJECTPTR(circle_nav, "CIRCLE_", AC_Circle),
|
GOBJECTPTR(circle_nav, "CIRCLE_", AC_Circle),
|
||||||
|
#endif
|
||||||
|
|
||||||
// @Group: ATC_
|
// @Group: ATC_
|
||||||
// @Path: ../libraries/AC_AttitudeControl/AC_AttitudeControl.cpp,../libraries/AC_AttitudeControl/AC_AttitudeControl_Multi.cpp,../libraries/AC_AttitudeControl/AC_AttitudeControl_Heli.cpp
|
// @Path: ../libraries/AC_AttitudeControl/AC_AttitudeControl.cpp,../libraries/AC_AttitudeControl/AC_AttitudeControl_Multi.cpp,../libraries/AC_AttitudeControl/AC_AttitudeControl_Heli.cpp
|
||||||
|
@ -279,6 +279,12 @@
|
|||||||
# define MODE_BRAKE_ENABLED ENABLED
|
# define MODE_BRAKE_ENABLED ENABLED
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Circle - fly vehicle around a central point
|
||||||
|
#ifndef MODE_CIRCLE_ENABLED
|
||||||
|
# define MODE_CIRCLE_ENABLED ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
// Drift - fly vehicle in altitude-held, coordinated-turn mode
|
// Drift - fly vehicle in altitude-held, coordinated-turn mode
|
||||||
#ifndef MODE_DRIFT_ENABLED
|
#ifndef MODE_DRIFT_ENABLED
|
||||||
@ -644,6 +650,10 @@
|
|||||||
#error ModeAuto requires ModeGuided which is disabled
|
#error ModeAuto requires ModeGuided which is disabled
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if MODE_AUTO_ENABLED && !MODE_CIRCLE_ENABLED
|
||||||
|
#error ModeAuto requires ModeCircle which is disabled
|
||||||
|
#endif
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
// Developer Items
|
// Developer Items
|
||||||
//
|
//
|
||||||
|
@ -56,9 +56,11 @@ Copter::Mode *Copter::mode_from_mode_num(const uint8_t mode)
|
|||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if MODE_CIRCLE_ENABLED == ENABLED
|
||||||
case CIRCLE:
|
case CIRCLE:
|
||||||
ret = &mode_circle;
|
ret = &mode_circle;
|
||||||
break;
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
#if MODE_LOITER_ENABLED == ENABLED
|
#if MODE_LOITER_ENABLED == ENABLED
|
||||||
case LOITER:
|
case LOITER:
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
#include "Copter.h"
|
#include "Copter.h"
|
||||||
|
|
||||||
|
#if MODE_CIRCLE_ENABLED == ENABLED
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Init and run calls for circle flight mode
|
* Init and run calls for circle flight mode
|
||||||
*/
|
*/
|
||||||
@ -103,3 +105,5 @@ int32_t Copter::ModeCircle::wp_bearing() const
|
|||||||
{
|
{
|
||||||
return wp_nav->get_loiter_bearing_to_target();
|
return wp_nav->get_loiter_bearing_to_target();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -615,11 +615,13 @@ void Copter::allocate_motors(void)
|
|||||||
}
|
}
|
||||||
AP_Param::load_object_from_eeprom(wp_nav, wp_nav->var_info);
|
AP_Param::load_object_from_eeprom(wp_nav, wp_nav->var_info);
|
||||||
|
|
||||||
|
#if MODE_CIRCLE_ENABLED == ENABLED
|
||||||
circle_nav = new AC_Circle(inertial_nav, *ahrs_view, *pos_control);
|
circle_nav = new AC_Circle(inertial_nav, *ahrs_view, *pos_control);
|
||||||
if (circle_nav == nullptr) {
|
if (circle_nav == nullptr) {
|
||||||
AP_HAL::panic("Unable to allocate CircleNav");
|
AP_HAL::panic("Unable to allocate CircleNav");
|
||||||
}
|
}
|
||||||
AP_Param::load_object_from_eeprom(circle_nav, circle_nav->var_info);
|
AP_Param::load_object_from_eeprom(circle_nav, circle_nav->var_info);
|
||||||
|
#endif
|
||||||
|
|
||||||
// reload lines from the defaults file that may now be accessible
|
// reload lines from the defaults file that may now be accessible
|
||||||
AP_Param::reload_defaults_file();
|
AP_Param::reload_defaults_file();
|
||||||
|
@ -133,10 +133,12 @@ void Copter::tuning() {
|
|||||||
compass.set_declination(ToRad((2.0f * control_in - g.radio_tuning_high)/100.0f), false); // 2nd parameter is false because we do not want to save to eeprom because this would have a performance impact
|
compass.set_declination(ToRad((2.0f * control_in - g.radio_tuning_high)/100.0f), false); // 2nd parameter is false because we do not want to save to eeprom because this would have a performance impact
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
#if MODE_CIRCLE_ENABLED == ENABLED
|
||||||
case TUNING_CIRCLE_RATE:
|
case TUNING_CIRCLE_RATE:
|
||||||
// set circle rate up to approximately 45 deg/sec in either direction
|
// set circle rate up to approximately 45 deg/sec in either direction
|
||||||
circle_nav->set_rate((float)control_in/25.0f-20.0f);
|
circle_nav->set_rate((float)control_in/25.0f-20.0f);
|
||||||
break;
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
case TUNING_RANGEFINDER_GAIN:
|
case TUNING_RANGEFINDER_GAIN:
|
||||||
// set rangefinder gain
|
// set rangefinder gain
|
||||||
|
Loading…
Reference in New Issue
Block a user