mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
AP_UAVCAN: make himark servo optional in build
and only allocate handlers if enabled
This commit is contained in:
parent
e9912e7799
commit
10d170be75
@ -50,9 +50,13 @@
|
|||||||
#endif
|
#endif
|
||||||
#include <uavcan/equipment/gnss/RTCMStream.hpp>
|
#include <uavcan/equipment/gnss/RTCMStream.hpp>
|
||||||
#include <uavcan/protocol/debug/LogMessage.hpp>
|
#include <uavcan/protocol/debug/LogMessage.hpp>
|
||||||
|
|
||||||
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
#include <com/himark/servo/ServoCmd.hpp>
|
#include <com/himark/servo/ServoCmd.hpp>
|
||||||
#include <com/himark/servo/ServoInfo.hpp>
|
#include <com/himark/servo/ServoInfo.hpp>
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#endif
|
||||||
|
|
||||||
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
#include <com/hobbywing/esc/GetEscID.hpp>
|
#include <com/hobbywing/esc/GetEscID.hpp>
|
||||||
#include <com/hobbywing/esc/StatusMsg1.hpp>
|
#include <com/hobbywing/esc/StatusMsg1.hpp>
|
||||||
#include <com/hobbywing/esc/StatusMsg2.hpp>
|
#include <com/hobbywing/esc/StatusMsg2.hpp>
|
||||||
@ -182,7 +186,6 @@ const AP_Param::GroupInfo AP_UAVCAN::var_info[] = {
|
|||||||
|
|
||||||
// publisher interfaces
|
// publisher interfaces
|
||||||
static uavcan::Publisher<uavcan::equipment::actuator::ArrayCommand>* act_out_array[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Publisher<uavcan::equipment::actuator::ArrayCommand>* act_out_array[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
static uavcan::Publisher<com::himark::servo::ServoCmd>* himark_out[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
|
||||||
static uavcan::Publisher<uavcan::equipment::esc::RawCommand>* esc_raw[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Publisher<uavcan::equipment::esc::RawCommand>* esc_raw[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
static uavcan::Publisher<uavcan::equipment::indication::LightsCommand>* rgb_led[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Publisher<uavcan::equipment::indication::LightsCommand>* rgb_led[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
static uavcan::Publisher<uavcan::equipment::indication::BeepCommand>* buzzer[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Publisher<uavcan::equipment::indication::BeepCommand>* buzzer[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
@ -197,7 +200,7 @@ static uavcan::Publisher<ardupilot::gnss::Status>* gnss_status[HAL_MAX_CAN_PROTO
|
|||||||
static uavcan::Publisher<uavcan::equipment::gnss::RTCMStream>* rtcm_stream[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Publisher<uavcan::equipment::gnss::RTCMStream>* rtcm_stream[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
static uavcan::Publisher<ardupilot::indication::NotifyState>* notify_state[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Publisher<ardupilot::indication::NotifyState>* notify_state[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
|
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
static uavcan::Publisher<com::hobbywing::esc::RawCommand>* esc_hobbywing_raw[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Publisher<com::hobbywing::esc::RawCommand>* esc_hobbywing_raw[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
static uavcan::Publisher<com::hobbywing::esc::GetEscID>* esc_hobbywing_GetEscID[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Publisher<com::hobbywing::esc::GetEscID>* esc_hobbywing_GetEscID[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
|
|
||||||
@ -207,7 +210,7 @@ UC_REGISTRY_BINDER(HobbywingStatus1Cb, com::hobbywing::esc::StatusMsg1);
|
|||||||
static uavcan::Subscriber<com::hobbywing::esc::StatusMsg1, HobbywingStatus1Cb> *hobbywing_Status1_listener[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Subscriber<com::hobbywing::esc::StatusMsg1, HobbywingStatus1Cb> *hobbywing_Status1_listener[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
UC_REGISTRY_BINDER(HobbywingStatus2Cb, com::hobbywing::esc::StatusMsg2);
|
UC_REGISTRY_BINDER(HobbywingStatus2Cb, com::hobbywing::esc::StatusMsg2);
|
||||||
static uavcan::Subscriber<com::hobbywing::esc::StatusMsg2, HobbywingStatus2Cb> *hobbywing_Status2_listener[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Subscriber<com::hobbywing::esc::StatusMsg2, HobbywingStatus2Cb> *hobbywing_Status2_listener[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
#endif // AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#endif // AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
|
|
||||||
// Clients
|
// Clients
|
||||||
UC_CLIENT_CALL_REGISTRY_BINDER(ParamGetSetCb, uavcan::protocol::param::GetSet);
|
UC_CLIENT_CALL_REGISTRY_BINDER(ParamGetSetCb, uavcan::protocol::param::GetSet);
|
||||||
@ -242,9 +245,11 @@ static uavcan::Subscriber<com::volz::servo::ActuatorStatus, ActuatorStatusVolzCb
|
|||||||
UC_REGISTRY_BINDER(ESCStatusCb, uavcan::equipment::esc::Status);
|
UC_REGISTRY_BINDER(ESCStatusCb, uavcan::equipment::esc::Status);
|
||||||
static uavcan::Subscriber<uavcan::equipment::esc::Status, ESCStatusCb> *esc_status_listener[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Subscriber<uavcan::equipment::esc::Status, ESCStatusCb> *esc_status_listener[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
|
|
||||||
// handler himark ServoInfo
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
static uavcan::Publisher<com::himark::servo::ServoCmd>* himark_out[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
UC_REGISTRY_BINDER(HimarkServoInfoCb, com::himark::servo::ServoInfo);
|
UC_REGISTRY_BINDER(HimarkServoInfoCb, com::himark::servo::ServoInfo);
|
||||||
static uavcan::Subscriber<com::himark::servo::ServoInfo, HimarkServoInfoCb> *himark_servoinfo_listener[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
static uavcan::Subscriber<com::himark::servo::ServoInfo, HimarkServoInfoCb> *himark_servoinfo_listener[HAL_MAX_CAN_PROTOCOL_DRIVERS];
|
||||||
|
#endif
|
||||||
|
|
||||||
// handler DEBUG
|
// handler DEBUG
|
||||||
UC_REGISTRY_BINDER(DebugCb, uavcan::protocol::debug::LogMessage);
|
UC_REGISTRY_BINDER(DebugCb, uavcan::protocol::debug::LogMessage);
|
||||||
@ -418,15 +423,25 @@ void AP_UAVCAN::init(uint8_t driver_index, bool enable_filters)
|
|||||||
act_out_array[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(2));
|
act_out_array[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(2));
|
||||||
act_out_array[driver_index]->setPriority(uavcan::TransferPriority::OneLowerThanHighest);
|
act_out_array[driver_index]->setPriority(uavcan::TransferPriority::OneLowerThanHighest);
|
||||||
|
|
||||||
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
himark_enabled = option_is_set(Options::USE_HIMARK_SERVO);
|
||||||
|
if (himark_enabled) {
|
||||||
himark_out[driver_index] = new uavcan::Publisher<com::himark::servo::ServoCmd>(*_node);
|
himark_out[driver_index] = new uavcan::Publisher<com::himark::servo::ServoCmd>(*_node);
|
||||||
himark_out[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(2));
|
himark_out[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(2));
|
||||||
himark_out[driver_index]->setPriority(uavcan::TransferPriority::OneLowerThanHighest);
|
himark_out[driver_index]->setPriority(uavcan::TransferPriority::OneLowerThanHighest);
|
||||||
|
|
||||||
|
himark_servoinfo_listener[driver_index] = new uavcan::Subscriber<com::himark::servo::ServoInfo, HimarkServoInfoCb>(*_node);
|
||||||
|
if (himark_servoinfo_listener[driver_index]) {
|
||||||
|
himark_servoinfo_listener[driver_index]->start(HimarkServoInfoCb(this, &handle_himark_servoinfo));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif // AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
|
||||||
esc_raw[driver_index] = new uavcan::Publisher<uavcan::equipment::esc::RawCommand>(*_node);
|
esc_raw[driver_index] = new uavcan::Publisher<uavcan::equipment::esc::RawCommand>(*_node);
|
||||||
esc_raw[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(2));
|
esc_raw[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(2));
|
||||||
esc_raw[driver_index]->setPriority(uavcan::TransferPriority::OneLowerThanHighest);
|
esc_raw[driver_index]->setPriority(uavcan::TransferPriority::OneLowerThanHighest);
|
||||||
|
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
hobbywing.enabled = option_is_set(Options::USE_HOBBYWING_ESC);
|
hobbywing.enabled = option_is_set(Options::USE_HOBBYWING_ESC);
|
||||||
if (hobbywing.enabled) {
|
if (hobbywing.enabled) {
|
||||||
esc_hobbywing_GetEscID[driver_index] = new uavcan::Publisher<com::hobbywing::esc::GetEscID>(*_node);
|
esc_hobbywing_GetEscID[driver_index] = new uavcan::Publisher<com::hobbywing::esc::GetEscID>(*_node);
|
||||||
@ -452,7 +467,7 @@ void AP_UAVCAN::init(uint8_t driver_index, bool enable_filters)
|
|||||||
hobbywing_Status2_listener[driver_index]->start(HobbywingStatus2Cb(this, &handle_hobbywing_StatusMsg2));
|
hobbywing_Status2_listener[driver_index]->start(HobbywingStatus2Cb(this, &handle_hobbywing_StatusMsg2));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif // AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#endif // AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
|
|
||||||
rgb_led[driver_index] = new uavcan::Publisher<uavcan::equipment::indication::LightsCommand>(*_node);
|
rgb_led[driver_index] = new uavcan::Publisher<uavcan::equipment::indication::LightsCommand>(*_node);
|
||||||
rgb_led[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(20));
|
rgb_led[driver_index]->setTxTimeout(uavcan::MonotonicDuration::fromMSec(20));
|
||||||
@ -527,11 +542,6 @@ void AP_UAVCAN::init(uint8_t driver_index, bool enable_filters)
|
|||||||
esc_status_listener[driver_index]->start(ESCStatusCb(this, &handle_ESC_status));
|
esc_status_listener[driver_index]->start(ESCStatusCb(this, &handle_ESC_status));
|
||||||
}
|
}
|
||||||
|
|
||||||
himark_servoinfo_listener[driver_index] = new uavcan::Subscriber<com::himark::servo::ServoInfo, HimarkServoInfoCb>(*_node);
|
|
||||||
if (himark_servoinfo_listener[driver_index]) {
|
|
||||||
himark_servoinfo_listener[driver_index]->start(HimarkServoInfoCb(this, &handle_himark_servoinfo));
|
|
||||||
}
|
|
||||||
|
|
||||||
debug_listener[driver_index] = new uavcan::Subscriber<uavcan::protocol::debug::LogMessage, DebugCb>(*_node);
|
debug_listener[driver_index] = new uavcan::Subscriber<uavcan::protocol::debug::LogMessage, DebugCb>(*_node);
|
||||||
if (debug_listener[driver_index]) {
|
if (debug_listener[driver_index]) {
|
||||||
debug_listener[driver_index]->start(DebugCb(this, &handle_debug));
|
debug_listener[driver_index]->start(DebugCb(this, &handle_debug));
|
||||||
@ -585,9 +595,12 @@ void AP_UAVCAN::loop(void)
|
|||||||
const uint32_t servo_period_us = 1000000UL / unsigned(_servo_rate_hz.get());
|
const uint32_t servo_period_us = 1000000UL / unsigned(_servo_rate_hz.get());
|
||||||
if (now - _SRV_last_send_us >= servo_period_us) {
|
if (now - _SRV_last_send_us >= servo_period_us) {
|
||||||
_SRV_last_send_us = now;
|
_SRV_last_send_us = now;
|
||||||
if (option_is_set(Options::USE_HIMARK_SERVO)) {
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
if (himark_enabled) {
|
||||||
SRV_send_himark();
|
SRV_send_himark();
|
||||||
} else {
|
} else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
SRV_send_actuator();
|
SRV_send_actuator();
|
||||||
}
|
}
|
||||||
sent_servos = true;
|
sent_servos = true;
|
||||||
@ -599,7 +612,7 @@ void AP_UAVCAN::loop(void)
|
|||||||
|
|
||||||
// if we have any ESC's in bitmask
|
// if we have any ESC's in bitmask
|
||||||
if (_esc_bm > 0 && !sent_servos) {
|
if (_esc_bm > 0 && !sent_servos) {
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
if (hobbywing.enabled) {
|
if (hobbywing.enabled) {
|
||||||
SRV_send_esc_hobbywing();
|
SRV_send_esc_hobbywing();
|
||||||
} else
|
} else
|
||||||
@ -635,7 +648,7 @@ void AP_UAVCAN::loop(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
logging();
|
logging();
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
hobbywing_ESC_update();
|
hobbywing_ESC_update();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -700,6 +713,7 @@ void AP_UAVCAN::SRV_send_actuator(void)
|
|||||||
} while (repeat_send);
|
} while (repeat_send);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
/*
|
/*
|
||||||
Himark servo output. This uses com.himark.servo.ServoCmd packets
|
Himark servo output. This uses com.himark.servo.ServoCmd packets
|
||||||
*/
|
*/
|
||||||
@ -727,6 +741,8 @@ void AP_UAVCAN::SRV_send_himark(void)
|
|||||||
}
|
}
|
||||||
himark_out[_driver_index]->broadcast(msg);
|
himark_out[_driver_index]->broadcast(msg);
|
||||||
}
|
}
|
||||||
|
#endif // AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
|
||||||
|
|
||||||
void AP_UAVCAN::SRV_send_esc(void)
|
void AP_UAVCAN::SRV_send_esc(void)
|
||||||
{
|
{
|
||||||
@ -778,7 +794,7 @@ void AP_UAVCAN::SRV_send_esc(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
/*
|
/*
|
||||||
send HobbyWing version of ESC RawCommand
|
send HobbyWing version of ESC RawCommand
|
||||||
*/
|
*/
|
||||||
@ -830,7 +846,7 @@ void AP_UAVCAN::SRV_send_esc_hobbywing(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif // AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#endif // AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
|
|
||||||
void AP_UAVCAN::SRV_push_servos()
|
void AP_UAVCAN::SRV_push_servos()
|
||||||
{
|
{
|
||||||
@ -1363,6 +1379,7 @@ void AP_UAVCAN::handle_actuator_status(AP_UAVCAN* ap_uavcan, uint8_t node_id, co
|
|||||||
0, 0, 0, 0, 0, 0);
|
0, 0, 0, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
/*
|
/*
|
||||||
handle himark ServoInfo message
|
handle himark ServoInfo message
|
||||||
*/
|
*/
|
||||||
@ -1382,6 +1399,7 @@ void AP_UAVCAN::handle_himark_servoinfo(AP_UAVCAN* ap_uavcan, uint8_t node_id, c
|
|||||||
cb.msg->pcb_temp*0.2-40,
|
cb.msg->pcb_temp*0.2-40,
|
||||||
cb.msg->error_status);
|
cb.msg->error_status);
|
||||||
}
|
}
|
||||||
|
#endif // AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
|
||||||
#if AP_DRONECAN_VOLZ_FEEDBACK_ENABLED
|
#if AP_DRONECAN_VOLZ_FEEDBACK_ENABLED
|
||||||
void AP_UAVCAN::handle_actuator_status_Volz(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ActuatorStatusVolzCb &cb)
|
void AP_UAVCAN::handle_actuator_status_Volz(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ActuatorStatusVolzCb &cb)
|
||||||
@ -1689,7 +1707,7 @@ void AP_UAVCAN::logging(void)
|
|||||||
#endif // HAL_LOGGING_ENABLED
|
#endif // HAL_LOGGING_ENABLED
|
||||||
}
|
}
|
||||||
|
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
/*
|
/*
|
||||||
update ESC node mapping
|
update ESC node mapping
|
||||||
*/
|
*/
|
||||||
@ -1768,6 +1786,6 @@ void AP_UAVCAN::handle_hobbywing_StatusMsg2(AP_UAVCAN* ap_uavcan, uint8_t node_i
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
#endif // AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#endif // AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
|
|
||||||
#endif // HAL_NUM_CAN_IFACES
|
#endif // HAL_NUM_CAN_IFACES
|
||||||
|
@ -48,8 +48,12 @@
|
|||||||
|
|
||||||
#define AP_UAVCAN_MAX_LED_DEVICES 4
|
#define AP_UAVCAN_MAX_LED_DEVICES 4
|
||||||
|
|
||||||
#ifndef AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#ifndef AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
#define AP_DRONECAN_HOBBYWING_ESC_SUPPORT (BOARD_FLASH_SIZE>1024)
|
#define AP_DRONECAN_HOBBYWING_ESC_ENABLED (BOARD_FLASH_SIZE>1024)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
#define AP_DRONECAN_HIMARK_SERVO_ENABLED (BOARD_FLASH_SIZE>1024)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// fwd-declare callback classes
|
// fwd-declare callback classes
|
||||||
@ -57,14 +61,18 @@ class ButtonCb;
|
|||||||
class TrafficReportCb;
|
class TrafficReportCb;
|
||||||
class ActuatorStatusCb;
|
class ActuatorStatusCb;
|
||||||
class ActuatorStatusVolzCb;
|
class ActuatorStatusVolzCb;
|
||||||
class HimarkServoInfoCb;
|
|
||||||
class ESCStatusCb;
|
class ESCStatusCb;
|
||||||
class DebugCb;
|
class DebugCb;
|
||||||
class ParamGetSetCb;
|
class ParamGetSetCb;
|
||||||
class ParamExecuteOpcodeCb;
|
class ParamExecuteOpcodeCb;
|
||||||
class AP_PoolAllocator;
|
class AP_PoolAllocator;
|
||||||
class AP_UAVCAN_DNA_Server;
|
class AP_UAVCAN_DNA_Server;
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
|
||||||
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
class HimarkServoInfoCb;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
class HobbywingESCIDCb;
|
class HobbywingESCIDCb;
|
||||||
class HobbywingStatus1Cb;
|
class HobbywingStatus1Cb;
|
||||||
class HobbywingStatus2Cb;
|
class HobbywingStatus2Cb;
|
||||||
@ -244,7 +252,9 @@ private:
|
|||||||
///// SRV output /////
|
///// SRV output /////
|
||||||
void SRV_send_actuator();
|
void SRV_send_actuator();
|
||||||
void SRV_send_esc();
|
void SRV_send_esc();
|
||||||
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
void SRV_send_himark();
|
void SRV_send_himark();
|
||||||
|
#endif
|
||||||
|
|
||||||
///// LED /////
|
///// LED /////
|
||||||
void led_out_send();
|
void led_out_send();
|
||||||
@ -375,7 +385,7 @@ private:
|
|||||||
// notify vehicle state
|
// notify vehicle state
|
||||||
uint32_t _last_notify_state_ms;
|
uint32_t _last_notify_state_ms;
|
||||||
|
|
||||||
#if AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#if AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
/*
|
/*
|
||||||
Hobbywing ESC support. Note that we need additional meta-data as
|
Hobbywing ESC support. Note that we need additional meta-data as
|
||||||
the status messages do not have an ESC ID in them, so we need a
|
the status messages do not have an ESC ID in them, so we need a
|
||||||
@ -394,14 +404,18 @@ private:
|
|||||||
static void handle_hobbywing_GetEscID(AP_UAVCAN* ap_uavcan, uint8_t node_id, const HobbywingESCIDCb &cb);
|
static void handle_hobbywing_GetEscID(AP_UAVCAN* ap_uavcan, uint8_t node_id, const HobbywingESCIDCb &cb);
|
||||||
static void handle_hobbywing_StatusMsg1(AP_UAVCAN* ap_uavcan, uint8_t node_id, const HobbywingStatus1Cb &cb);
|
static void handle_hobbywing_StatusMsg1(AP_UAVCAN* ap_uavcan, uint8_t node_id, const HobbywingStatus1Cb &cb);
|
||||||
static void handle_hobbywing_StatusMsg2(AP_UAVCAN* ap_uavcan, uint8_t node_id, const HobbywingStatus2Cb &cb);
|
static void handle_hobbywing_StatusMsg2(AP_UAVCAN* ap_uavcan, uint8_t node_id, const HobbywingStatus2Cb &cb);
|
||||||
#endif // AP_DRONECAN_HOBBYWING_ESC_SUPPORT
|
#endif // AP_DRONECAN_HOBBYWING_ESC_ENABLED
|
||||||
|
|
||||||
|
#if AP_DRONECAN_HIMARK_SERVO_ENABLED
|
||||||
|
bool himark_enabled;
|
||||||
|
static void handle_himark_servoinfo(AP_UAVCAN* ap_uavcan, uint8_t node_id, const HimarkServoInfoCb &cb);
|
||||||
|
#endif
|
||||||
|
|
||||||
// incoming button handling
|
// incoming button handling
|
||||||
static void handle_button(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ButtonCb &cb);
|
static void handle_button(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ButtonCb &cb);
|
||||||
static void handle_traffic_report(AP_UAVCAN* ap_uavcan, uint8_t node_id, const TrafficReportCb &cb);
|
static void handle_traffic_report(AP_UAVCAN* ap_uavcan, uint8_t node_id, const TrafficReportCb &cb);
|
||||||
static void handle_actuator_status(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ActuatorStatusCb &cb);
|
static void handle_actuator_status(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ActuatorStatusCb &cb);
|
||||||
static void handle_actuator_status_Volz(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ActuatorStatusVolzCb &cb);
|
static void handle_actuator_status_Volz(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ActuatorStatusVolzCb &cb);
|
||||||
static void handle_himark_servoinfo(AP_UAVCAN* ap_uavcan, uint8_t node_id, const HimarkServoInfoCb &cb);
|
|
||||||
static void handle_ESC_status(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ESCStatusCb &cb);
|
static void handle_ESC_status(AP_UAVCAN* ap_uavcan, uint8_t node_id, const ESCStatusCb &cb);
|
||||||
static bool is_esc_data_index_valid(const uint8_t index);
|
static bool is_esc_data_index_valid(const uint8_t index);
|
||||||
static void handle_debug(AP_UAVCAN* ap_uavcan, uint8_t node_id, const DebugCb &cb);
|
static void handle_debug(AP_UAVCAN* ap_uavcan, uint8_t node_id, const DebugCb &cb);
|
||||||
|
Loading…
Reference in New Issue
Block a user