mirror of https://github.com/ArduPilot/ardupilot
AP_LandingGear: weight on wheels, debounce, singleton
This commit is contained in:
parent
3794f9d51e
commit
fa6afe145f
|
@ -3,9 +3,12 @@
|
||||||
#include <AP_Math/AP_Math.h>
|
#include <AP_Math/AP_Math.h>
|
||||||
#include <SRV_Channel/SRV_Channel.h>
|
#include <SRV_Channel/SRV_Channel.h>
|
||||||
#include <AP_HAL/AP_HAL.h>
|
#include <AP_HAL/AP_HAL.h>
|
||||||
|
#include <DataFlash/DataFlash.h>
|
||||||
|
|
||||||
extern const AP_HAL::HAL& hal;
|
extern const AP_HAL::HAL& hal;
|
||||||
|
|
||||||
|
#define MASK_LOG_CTUN (1<<4)
|
||||||
|
|
||||||
const AP_Param::GroupInfo AP_LandingGear::var_info[] = {
|
const AP_Param::GroupInfo AP_LandingGear::var_info[] = {
|
||||||
|
|
||||||
// @Param: SERVO_RTRACT
|
// @Param: SERVO_RTRACT
|
||||||
|
@ -33,12 +36,56 @@ const AP_Param::GroupInfo AP_LandingGear::var_info[] = {
|
||||||
// @User: Standard
|
// @User: Standard
|
||||||
AP_GROUPINFO("STARTUP", 2, AP_LandingGear, _startup_behaviour, (uint8_t)AP_LandingGear::LandingGear_Startup_WaitForPilotInput),
|
AP_GROUPINFO("STARTUP", 2, AP_LandingGear, _startup_behaviour, (uint8_t)AP_LandingGear::LandingGear_Startup_WaitForPilotInput),
|
||||||
|
|
||||||
|
// @Param: DEPLOY_PIN
|
||||||
|
// @DisplayName: Chassis deployment feedback pin
|
||||||
|
// @Description: Pin number to use for feedback of gear deployment. If set to -1 feedback is disabled.
|
||||||
|
// @Values: -1:Disabled,50:PX4 AUX1,51:PX4 AUX2,52:PX4 AUX3,53:PX4 AUX4,54:PX4 AUX5,55:PX4 AUX6
|
||||||
|
// @User: Standard
|
||||||
|
// @RebootRequired: True
|
||||||
|
AP_GROUPINFO("DEPLOY_PIN", 3, AP_LandingGear, _pin_deployed, -1),
|
||||||
|
|
||||||
|
// @Param: DEPLOY_POL
|
||||||
|
// @DisplayName: Chassis deployment feedback pin polarity
|
||||||
|
// @Description: Polarity for feedback pin. If this is 1 then the pin should be high when gear are deployed. If set to 0 then then deployed gear level is low.
|
||||||
|
// @Values: 0:Low,1:High
|
||||||
|
// @User: Standard
|
||||||
|
AP_GROUPINFO("DEPLOY_POL", 4, AP_LandingGear, _pin_deployed_polarity, 0),
|
||||||
|
|
||||||
|
// @Param: WOW_PIN
|
||||||
|
// @DisplayName: Weight on wheels feedback pin
|
||||||
|
// @Description: Pin number to use for feedback of weight on wheels condition. If set to -1 feedback is disabled.
|
||||||
|
// @Values: -1:Disabled,50:PX4 AUX1,51:PX4 AUX2,52:PX4 AUX3,53:PX4 AUX4,54:PX4 AUX5,55:PX4 AUX6
|
||||||
|
// @User: Standard
|
||||||
|
// @RebootRequired: True
|
||||||
|
AP_GROUPINFO("WOW_PIN", 5, AP_LandingGear, _pin_weight_on_wheels, DEFAULT_PIN_WOW),
|
||||||
|
|
||||||
|
// @Param: WOW_POL
|
||||||
|
// @DisplayName: Weight on wheels feedback pin polarity
|
||||||
|
// @Description: Polarity for feedback pin. If this is 1 then the pin should be high when there is weight on wheels. If set to 0 then then weight on wheels level is low.
|
||||||
|
// @Values: 0:Low,1:High
|
||||||
|
// @User: Standard
|
||||||
|
AP_GROUPINFO("WOW_POL", 6, AP_LandingGear, _pin_weight_on_wheels_polarity, DEFAULT_PIN_WOW_POL),
|
||||||
|
|
||||||
AP_GROUPEND
|
AP_GROUPEND
|
||||||
};
|
};
|
||||||
|
|
||||||
|
AP_LandingGear *AP_LandingGear::_singleton;
|
||||||
|
|
||||||
/// initialise state of landing gear
|
/// initialise state of landing gear
|
||||||
void AP_LandingGear::init()
|
void AP_LandingGear::init()
|
||||||
{
|
{
|
||||||
|
if (_pin_deployed != -1) {
|
||||||
|
hal.gpio->pinMode(_pin_deployed, HAL_GPIO_INPUT);
|
||||||
|
hal.gpio->write(_pin_deployed, 1);
|
||||||
|
log_wow_state(wow_state_current);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_pin_weight_on_wheels != -1) {
|
||||||
|
hal.gpio->pinMode(_pin_weight_on_wheels, HAL_GPIO_INPUT);
|
||||||
|
hal.gpio->write(_pin_weight_on_wheels, 1);
|
||||||
|
log_wow_state(wow_state_current);
|
||||||
|
}
|
||||||
|
|
||||||
switch ((enum LandingGearStartupBehaviour)_startup_behaviour.get()) {
|
switch ((enum LandingGearStartupBehaviour)_startup_behaviour.get()) {
|
||||||
default:
|
default:
|
||||||
case LandingGear_Startup_WaitForPilotInput:
|
case LandingGear_Startup_WaitForPilotInput:
|
||||||
|
@ -85,3 +132,90 @@ void AP_LandingGear::retract()
|
||||||
// reset deployed flag
|
// reset deployed flag
|
||||||
_deployed = false;
|
_deployed = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool AP_LandingGear::deployed()
|
||||||
|
{
|
||||||
|
if (_pin_deployed == -1) {
|
||||||
|
return _deployed;
|
||||||
|
} else {
|
||||||
|
return hal.gpio->read(_pin_deployed) == _pin_deployed_polarity ? true : false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AP_LandingGear::LG_WOW_State AP_LandingGear::get_wow_state()
|
||||||
|
{
|
||||||
|
return wow_state_current;
|
||||||
|
}
|
||||||
|
|
||||||
|
AP_LandingGear::LG_LandingGear_State AP_LandingGear::get_state()
|
||||||
|
{
|
||||||
|
return gear_state_current;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t AP_LandingGear::get_gear_state_duration_ms()
|
||||||
|
{
|
||||||
|
if (last_gear_event_ms == 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return AP_HAL::millis() - last_gear_event_ms;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t AP_LandingGear::get_wow_state_duration_ms()
|
||||||
|
{
|
||||||
|
if (last_wow_event_ms == 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return AP_HAL::millis() - last_wow_event_ms;
|
||||||
|
}
|
||||||
|
|
||||||
|
void AP_LandingGear::update()
|
||||||
|
{
|
||||||
|
if (_pin_weight_on_wheels == -1) {
|
||||||
|
last_wow_event_ms = 0;
|
||||||
|
wow_state_current = LG_WOW_UNKNOWN;
|
||||||
|
} else {
|
||||||
|
LG_WOW_State wow_state_new = hal.gpio->read(_pin_weight_on_wheels) == _pin_weight_on_wheels_polarity ? LG_WOW : LG_NO_WOW;
|
||||||
|
|
||||||
|
if (wow_state_new != wow_state_current) {
|
||||||
|
// we changed states, lets note the time.
|
||||||
|
last_wow_event_ms = AP_HAL::millis();
|
||||||
|
log_wow_state(wow_state_new);
|
||||||
|
}
|
||||||
|
|
||||||
|
wow_state_current = wow_state_new;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_pin_deployed == -1) {
|
||||||
|
last_gear_event_ms = 0;
|
||||||
|
gear_state_current = (_deployed == true ? LG_DEPLOYED : LG_RETRACTED);
|
||||||
|
} else {
|
||||||
|
LG_LandingGear_State gear_state_new;
|
||||||
|
|
||||||
|
if (_deployed) {
|
||||||
|
gear_state_new = (deployed() == true ? LG_DEPLOYED : LG_DEPLOYING);
|
||||||
|
} else {
|
||||||
|
gear_state_new = (deployed() == false ? LG_RETRACTED : LG_RETRACTING);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gear_state_new != gear_state_current) {
|
||||||
|
// we changed states, lets note the time.
|
||||||
|
last_gear_event_ms = AP_HAL::millis();
|
||||||
|
|
||||||
|
log_wow_state(wow_state_current);
|
||||||
|
}
|
||||||
|
|
||||||
|
gear_state_current = gear_state_new;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// log weight on wheels state
|
||||||
|
void AP_LandingGear::log_wow_state(LG_WOW_State state)
|
||||||
|
{
|
||||||
|
if (DataFlash_Class::instance()->should_log(MASK_LOG_CTUN)) {
|
||||||
|
DataFlash_Class::instance()->Log_Write("LGR", "TimeUS,LandingGear,WeightOnWheels", "Qbb",
|
||||||
|
AP_HAL::micros64(),
|
||||||
|
(int8_t)gear_state_current, (int8_t)state);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -8,6 +8,14 @@
|
||||||
#define AP_LANDINGGEAR_SERVO_RETRACT_PWM_DEFAULT 1250 // default PWM value to move servo to when landing gear is up
|
#define AP_LANDINGGEAR_SERVO_RETRACT_PWM_DEFAULT 1250 // default PWM value to move servo to when landing gear is up
|
||||||
#define AP_LANDINGGEAR_SERVO_DEPLOY_PWM_DEFAULT 1750 // default PWM value to move servo to when landing gear is down
|
#define AP_LANDINGGEAR_SERVO_DEPLOY_PWM_DEFAULT 1750 // default PWM value to move servo to when landing gear is down
|
||||||
|
|
||||||
|
#if CONFIG_HAL_BOARD == HAL_BOARD_SITL
|
||||||
|
#define DEFAULT_PIN_WOW 8
|
||||||
|
#define DEFAULT_PIN_WOW_POL 1
|
||||||
|
#else
|
||||||
|
#define DEFAULT_PIN_WOW -1
|
||||||
|
#define DEFAULT_PIN_WOW_POL 0
|
||||||
|
#endif
|
||||||
|
|
||||||
/// @class AP_LandingGear
|
/// @class AP_LandingGear
|
||||||
/// @brief Class managing the control of landing gear
|
/// @brief Class managing the control of landing gear
|
||||||
class AP_LandingGear {
|
class AP_LandingGear {
|
||||||
|
@ -15,12 +23,22 @@ public:
|
||||||
AP_LandingGear() {
|
AP_LandingGear() {
|
||||||
// setup parameter defaults
|
// setup parameter defaults
|
||||||
AP_Param::setup_object_defaults(this, var_info);
|
AP_Param::setup_object_defaults(this, var_info);
|
||||||
|
|
||||||
|
if (_singleton != nullptr) {
|
||||||
|
AP_HAL::panic("AP_LandingGear must be singleton");
|
||||||
|
}
|
||||||
|
_singleton = this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Do not allow copies */
|
/* Do not allow copies */
|
||||||
AP_LandingGear(const AP_LandingGear &other) = delete;
|
AP_LandingGear(const AP_LandingGear &other) = delete;
|
||||||
AP_LandingGear &operator=(const AP_LandingGear&) = delete;
|
AP_LandingGear &operator=(const AP_LandingGear&) = delete;
|
||||||
|
|
||||||
|
// get singleton instance
|
||||||
|
static AP_LandingGear &instance(void) {
|
||||||
|
return *_singleton;
|
||||||
|
}
|
||||||
|
|
||||||
// Gear command modes
|
// Gear command modes
|
||||||
enum LandingGearCommand {
|
enum LandingGearCommand {
|
||||||
LandingGear_Retract,
|
LandingGear_Retract,
|
||||||
|
@ -38,25 +56,69 @@ public:
|
||||||
void init();
|
void init();
|
||||||
|
|
||||||
/// returns true if the landing gear is deployed
|
/// returns true if the landing gear is deployed
|
||||||
bool deployed() const { return _deployed; }
|
bool deployed();
|
||||||
|
|
||||||
|
enum LG_LandingGear_State {
|
||||||
|
LG_UNKNOWN = -1,
|
||||||
|
LG_RETRACTED = 0,
|
||||||
|
LG_DEPLOYED = 1,
|
||||||
|
LG_RETRACTING = 2,
|
||||||
|
LG_DEPLOYING = 3,
|
||||||
|
};
|
||||||
|
/// returns detailed state of gear
|
||||||
|
LG_LandingGear_State get_state();
|
||||||
|
|
||||||
|
enum LG_WOW_State {
|
||||||
|
LG_WOW_UNKNOWN = -1,
|
||||||
|
LG_NO_WOW = 0,
|
||||||
|
LG_WOW = 1,
|
||||||
|
};
|
||||||
|
|
||||||
|
LG_WOW_State get_wow_state();
|
||||||
|
|
||||||
/// set landing gear position to retract, deploy or deploy-and-keep-deployed
|
/// set landing gear position to retract, deploy or deploy-and-keep-deployed
|
||||||
void set_position(LandingGearCommand cmd);
|
void set_position(LandingGearCommand cmd);
|
||||||
|
|
||||||
|
uint32_t get_gear_state_duration_ms();
|
||||||
|
uint32_t get_wow_state_duration_ms();
|
||||||
|
|
||||||
static const struct AP_Param::GroupInfo var_info[];
|
static const struct AP_Param::GroupInfo var_info[];
|
||||||
|
|
||||||
|
void update();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Parameters
|
// Parameters
|
||||||
AP_Int16 _servo_retract_pwm; // PWM value to move servo to when gear is retracted
|
AP_Int16 _servo_retract_pwm; // PWM value to move servo to when gear is retracted
|
||||||
AP_Int16 _servo_deploy_pwm; // PWM value to move servo to when gear is deployed
|
AP_Int16 _servo_deploy_pwm; // PWM value to move servo to when gear is deployed
|
||||||
AP_Int8 _startup_behaviour; // start-up behaviour (see LandingGearStartupBehaviour)
|
AP_Int8 _startup_behaviour; // start-up behaviour (see LandingGearStartupBehaviour)
|
||||||
|
|
||||||
|
AP_Int8 _pin_deployed;
|
||||||
|
AP_Int8 _pin_deployed_polarity;
|
||||||
|
AP_Int8 _pin_weight_on_wheels;
|
||||||
|
AP_Int8 _pin_weight_on_wheels_polarity;
|
||||||
|
|
||||||
// internal variables
|
// internal variables
|
||||||
bool _deployed; // true if the landing gear has been deployed, initialized false
|
bool _deployed; // true if the landing gear has been deployed, initialized false
|
||||||
|
|
||||||
|
bool _deploy_lock; // used to force landing gear to remain deployed until another regular Deploy command is received to reduce accidental retraction
|
||||||
|
bool _deploy_pin_state;
|
||||||
|
bool _weight_on_wheels_pin_state;
|
||||||
|
|
||||||
|
// debounce
|
||||||
|
LG_WOW_State wow_state_current = LG_WOW_UNKNOWN;
|
||||||
|
uint32_t last_wow_event_ms;
|
||||||
|
|
||||||
|
LG_LandingGear_State gear_state_current = LG_UNKNOWN;
|
||||||
|
uint32_t last_gear_event_ms;
|
||||||
|
|
||||||
/// retract - retract landing gear
|
/// retract - retract landing gear
|
||||||
void retract();
|
void retract();
|
||||||
|
|
||||||
/// deploy - deploy the landing gear
|
/// deploy - deploy the landing gear
|
||||||
void deploy();
|
void deploy();
|
||||||
|
|
||||||
|
// log weight on wheels state
|
||||||
|
void log_wow_state(LG_WOW_State state);
|
||||||
|
|
||||||
|
static AP_LandingGear *_singleton;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue