mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-20 15:48:29 -04:00
AP_BoardConfig: added BRD_SAFETYOPTION parameter
allow control of safety button behaviour
This commit is contained in:
parent
ef2f2d7e1c
commit
3abd7ea051
@ -67,7 +67,14 @@
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if AP_FEATURE_SAFETY_BUTTON
|
||||||
|
#ifndef BOARD_SAFETY_OPTION_DEFAULT
|
||||||
|
#define BOARD_SAFETY_OPTION_DEFAULT (BOARD_SAFETY_OPTION_BUTTON_ACTIVE_SAFETY_OFF|BOARD_SAFETY_OPTION_BUTTON_ACTIVE_SAFETY_ON)
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
extern const AP_HAL::HAL& hal;
|
extern const AP_HAL::HAL& hal;
|
||||||
|
AP_BoardConfig *AP_BoardConfig::instance;
|
||||||
|
|
||||||
// table of user settable parameters
|
// table of user settable parameters
|
||||||
const AP_Param::GroupInfo AP_BoardConfig::var_info[] = {
|
const AP_Param::GroupInfo AP_BoardConfig::var_info[] = {
|
||||||
@ -171,6 +178,15 @@ const AP_Param::GroupInfo AP_BoardConfig::var_info[] = {
|
|||||||
|
|
||||||
// ID number 11 reserved for AP_Radio (pending PR)
|
// ID number 11 reserved for AP_Radio (pending PR)
|
||||||
|
|
||||||
|
#if AP_FEATURE_SAFETY_BUTTON
|
||||||
|
// @Param: SAFETYOPTION
|
||||||
|
// @DisplayName: Options for safety button behavior
|
||||||
|
// @Description: This controls the activation of the safety button. It allows you to control if the safety button can be used for safety enable and/or disable, and whether the button is only active when disarmed
|
||||||
|
// @Bitmask: 0:ActiveForSafetyEnable,1:ActiveForSafetyDisable,2:ActiveWhenDisarmed
|
||||||
|
// @User: Standard
|
||||||
|
AP_GROUPINFO("SAFETYOPTION", 13, AP_BoardConfig, px4.safety_option, BOARD_SAFETY_OPTION_DEFAULT),
|
||||||
|
#endif
|
||||||
|
|
||||||
AP_GROUPEND
|
AP_GROUPEND
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -7,14 +7,31 @@
|
|||||||
|
|
||||||
extern "C" typedef int (*main_fn_t)(int argc, char **);
|
extern "C" typedef int (*main_fn_t)(int argc, char **);
|
||||||
|
|
||||||
|
#if CONFIG_HAL_BOARD == HAL_BOARD_PX4 || CONFIG_HAL_BOARD == HAL_BOARD_VRBRAIN
|
||||||
|
#define AP_FEATURE_SAFETY_BUTTON 1
|
||||||
|
#else
|
||||||
|
#define AP_FEATURE_SAFETY_BUTTON 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
class AP_BoardConfig {
|
class AP_BoardConfig {
|
||||||
public:
|
public:
|
||||||
// constructor
|
// constructor
|
||||||
AP_BoardConfig(void)
|
AP_BoardConfig(void)
|
||||||
{
|
{
|
||||||
|
instance = this;
|
||||||
AP_Param::setup_object_defaults(this, var_info);
|
AP_Param::setup_object_defaults(this, var_info);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Do not allow copies */
|
||||||
|
AP_BoardConfig(const AP_BoardConfig &other) = delete;
|
||||||
|
AP_BoardConfig &operator=(const AP_BoardConfig&) = delete;
|
||||||
|
|
||||||
|
// singleton support
|
||||||
|
static AP_BoardConfig *get_instance(void) {
|
||||||
|
return instance;
|
||||||
|
}
|
||||||
|
|
||||||
void init(void);
|
void init(void);
|
||||||
void init_safety(void);
|
void init_safety(void);
|
||||||
|
|
||||||
@ -67,13 +84,29 @@ public:
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if AP_FEATURE_SAFETY_BUTTON
|
||||||
|
enum board_safety_button_option {
|
||||||
|
BOARD_SAFETY_OPTION_BUTTON_ACTIVE_SAFETY_OFF=1,
|
||||||
|
BOARD_SAFETY_OPTION_BUTTON_ACTIVE_SAFETY_ON=2,
|
||||||
|
BOARD_SAFETY_OPTION_BUTTON_ACTIVE_ARMED=4,
|
||||||
|
};
|
||||||
|
|
||||||
|
// return safety button options. Bits are in enum board_safety_button_option
|
||||||
|
uint16_t get_safety_button_options(void) {
|
||||||
|
return uint16_t(px4.safety_option.get());
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
static AP_BoardConfig *instance;
|
||||||
|
|
||||||
AP_Int16 vehicleSerialNumber;
|
AP_Int16 vehicleSerialNumber;
|
||||||
|
|
||||||
#if CONFIG_HAL_BOARD == HAL_BOARD_PX4 || CONFIG_HAL_BOARD == HAL_BOARD_VRBRAIN
|
#if CONFIG_HAL_BOARD == HAL_BOARD_PX4 || CONFIG_HAL_BOARD == HAL_BOARD_VRBRAIN
|
||||||
struct {
|
struct {
|
||||||
AP_Int8 pwm_count;
|
AP_Int8 pwm_count;
|
||||||
AP_Int8 safety_enable;
|
AP_Int8 safety_enable;
|
||||||
|
AP_Int16 safety_option;
|
||||||
AP_Int32 ignore_safety_channels;
|
AP_Int32 ignore_safety_channels;
|
||||||
#if CONFIG_HAL_BOARD == HAL_BOARD_PX4
|
#if CONFIG_HAL_BOARD == HAL_BOARD_PX4
|
||||||
AP_Int8 ser1_rtscts;
|
AP_Int8 ser1_rtscts;
|
||||||
|
Loading…
Reference in New Issue
Block a user