AP_UAVCAN: support safety buttons on UAVCAN
the button works in parallel with any button attached by IOMCU or by a pin, and obeys all the same BRD_SAFETY* options
This commit is contained in:
parent
03c1a8bfd9
commit
21cce1385a
@ -37,6 +37,7 @@
|
||||
#include <uavcan/equipment/indication/BeepCommand.hpp>
|
||||
#include <uavcan/equipment/indication/RGB565.hpp>
|
||||
#include <ardupilot/indication/SafetyState.hpp>
|
||||
#include <ardupilot/indication/Button.hpp>
|
||||
|
||||
#include <AP_Baro/AP_Baro_UAVCAN.h>
|
||||
#include <AP_RangeFinder/AP_RangeFinder_UAVCAN.h>
|
||||
@ -103,6 +104,11 @@ static uavcan::Publisher<uavcan::equipment::indication::LightsCommand>* rgb_led[
|
||||
static uavcan::Publisher<uavcan::equipment::indication::BeepCommand>* buzzer[MAX_NUMBER_OF_CAN_DRIVERS];
|
||||
static uavcan::Publisher<ardupilot::indication::SafetyState>* safety_state[MAX_NUMBER_OF_CAN_DRIVERS];
|
||||
|
||||
// subscribers
|
||||
// handler SafteyButton
|
||||
UC_REGISTRY_BINDER(ButtonCb, ardupilot::indication::Button);
|
||||
static uavcan::Subscriber<ardupilot::indication::Button, ButtonCb> *safety_button_listener[MAX_NUMBER_OF_CAN_DRIVERS];
|
||||
|
||||
AP_UAVCAN::AP_UAVCAN() :
|
||||
_node_allocator()
|
||||
{
|
||||
@ -234,6 +240,11 @@ void AP_UAVCAN::init(uint8_t driver_index, bool enable_filters)
|
||||
safety_state[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(20));
|
||||
safety_state[driver_index]->setPriority(uavcan::TransferPriority::OneHigherThanLowest);
|
||||
|
||||
safety_button_listener[driver_index] = new uavcan::Subscriber<ardupilot::indication::Button, ButtonCb>(*_node);
|
||||
if (safety_button_listener[driver_index]) {
|
||||
safety_button_listener[driver_index]->start(ButtonCb(this, &handle_button));
|
||||
}
|
||||
|
||||
_led_conf.devices_count = 0;
|
||||
if (enable_filters) {
|
||||
configureCanAcceptanceFilters(*_node);
|
||||
@ -536,4 +547,25 @@ void AP_UAVCAN::safety_state_send()
|
||||
safety_state[_driver_index]->broadcast(msg);
|
||||
}
|
||||
|
||||
/*
|
||||
handle Button message
|
||||
*/
|
||||
void AP_UAVCAN::handle_button(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ButtonCb &cb)
|
||||
{
|
||||
switch (cb.msg->button) {
|
||||
case ardupilot::indication::Button::BUTTON_SAFETY: {
|
||||
AP_BoardConfig *brdconfig = AP_BoardConfig::get_singleton();
|
||||
if (brdconfig && brdconfig->safety_button_handle_pressed(cb.msg->press_time)) {
|
||||
AP_HAL::Util::safety_state state = hal.util->safety_switch_state();
|
||||
if (state == AP_HAL::Util::SAFETY_ARMED) {
|
||||
hal.rcout->force_safety_on();
|
||||
} else {
|
||||
hal.rcout->force_safety_off();
|
||||
}
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#endif // HAL_WITH_UAVCAN
|
||||
|
@ -46,6 +46,9 @@
|
||||
|
||||
#define AP_UAVCAN_MAX_LED_DEVICES 4
|
||||
|
||||
// fwd-declare callback classes
|
||||
class ButtonCb;
|
||||
|
||||
/*
|
||||
Frontend Backend-Registry Binder: Whenever a message of said DataType_ from new node is received,
|
||||
the Callback will invoke registery to register the node as separate backend.
|
||||
@ -207,7 +210,11 @@ private:
|
||||
uint8_t pending_mask; // mask of interfaces to send to
|
||||
} _buzzer;
|
||||
|
||||
// safety status send state
|
||||
uint32_t _last_safety_state_ms;
|
||||
|
||||
// safety button handling
|
||||
static void handle_button(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ButtonCb &cb);
|
||||
};
|
||||
|
||||
#endif /* AP_UAVCAN_H_ */
|
||||
|
Loading…
Reference in New Issue
Block a user