mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 06:38:29 -04:00
AP_KDECAN: apply NFC suggestions from Peter Barker
This commit is contained in:
parent
a443fd97a6
commit
e21063522d
@ -59,15 +59,8 @@ void AP_KDECAN::init()
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
AP_CANManager::Driver_Type protocol = AP_CANManager::Driver_Type_None;
|
|
||||||
|
|
||||||
for (uint8_t i = 0; i < HAL_NUM_CAN_IFACES; i++) {
|
for (uint8_t i = 0; i < HAL_NUM_CAN_IFACES; i++) {
|
||||||
#if HAL_CANMANAGER_ENABLED
|
if (CANSensor::get_driver_type(i) == AP_CANManager::Driver_Type_KDECAN) {
|
||||||
protocol = AP::can().get_driver_type(i);
|
|
||||||
#elif defined(HAL_BUILD_AP_PERIPH)
|
|
||||||
protocol = CANSensor::get_driver_type(i);
|
|
||||||
#endif
|
|
||||||
if (protocol == AP_CANManager::Driver_Type_KDECAN) {
|
|
||||||
_driver = new AP_KDECAN_Driver();
|
_driver = new AP_KDECAN_Driver();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -131,7 +124,7 @@ void AP_KDECAN_Driver::handle_frame(AP_HAL::CANFrame &frame)
|
|||||||
const uint8_t num_poles = _telemetry.num_poles > 0 ? _telemetry.num_poles : DEFAULT_NUM_POLES;
|
const uint8_t num_poles = _telemetry.num_poles > 0 ? _telemetry.num_poles : DEFAULT_NUM_POLES;
|
||||||
update_rpm(idx, uint16_t(uint16_t(frame.data[4] << 8 | frame.data[5]) * 60UL * 2 / num_poles));
|
update_rpm(idx, uint16_t(uint16_t(frame.data[4] << 8 | frame.data[5]) * 60UL * 2 / num_poles));
|
||||||
|
|
||||||
TelemetryData t {
|
const TelemetryData t {
|
||||||
.temperature_cdeg = int16_t(frame.data[6] * 100),
|
.temperature_cdeg = int16_t(frame.data[6] * 100),
|
||||||
.voltage = float(uint16_t(frame.data[0] << 8 | frame.data[1])) * 0.01f,
|
.voltage = float(uint16_t(frame.data[0] << 8 | frame.data[1])) * 0.01f,
|
||||||
.current = float(uint16_t(frame.data[2] << 8 | frame.data[3])) * 0.01f,
|
.current = float(uint16_t(frame.data[2] << 8 | frame.data[3])) * 0.01f,
|
||||||
@ -198,7 +191,7 @@ void AP_KDECAN_Driver::loop()
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint8_t broadcast_esc_info_boot_spam_count = 3;
|
uint8_t broadcast_esc_info_boot_spam_count = 3;
|
||||||
uint32_t broadcast_esc_info_next_interval_ms = 100; // spam a few at boot at 5Hz
|
uint32_t broadcast_esc_info_next_interval_ms = 100; // spam a few at boot at this rate
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
#if AP_KDECAN_USE_EVENTS
|
#if AP_KDECAN_USE_EVENTS
|
||||||
@ -277,11 +270,15 @@ bool AP_KDECAN_Driver::send_packet_uint16(const uint8_t address, const uint8_t d
|
|||||||
bool AP_KDECAN_Driver::send_packet(const uint8_t address, const uint8_t dest_id, const uint32_t timeout_ms, const uint8_t *data, const uint8_t data_len)
|
bool AP_KDECAN_Driver::send_packet(const uint8_t address, const uint8_t dest_id, const uint32_t timeout_ms, const uint8_t *data, const uint8_t data_len)
|
||||||
{
|
{
|
||||||
// broadcast telemetry request frame
|
// broadcast telemetry request frame
|
||||||
frame_id_t id = { { .object_address = address,
|
const frame_id_t id {
|
||||||
.destination_id = dest_id,
|
{
|
||||||
.source_id = AUTOPILOT_NODE_ID,
|
.object_address = address,
|
||||||
.priority = 0,
|
.destination_id = dest_id,
|
||||||
.unused = 0 } };
|
.source_id = AUTOPILOT_NODE_ID,
|
||||||
|
.priority = 0,
|
||||||
|
.unused = 0
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
AP_HAL::CANFrame frame = AP_HAL::CANFrame((id.value | AP_HAL::CANFrame::FlagEFF), data, data_len, false);
|
AP_HAL::CANFrame frame = AP_HAL::CANFrame((id.value | AP_HAL::CANFrame::FlagEFF), data, data_len, false);
|
||||||
|
|
||||||
|
@ -4,6 +4,6 @@
|
|||||||
#include <AP_HAL/AP_HAL_Boards.h>
|
#include <AP_HAL/AP_HAL_Boards.h>
|
||||||
|
|
||||||
#ifndef AP_KDECAN_ENABLED
|
#ifndef AP_KDECAN_ENABLED
|
||||||
#define AP_KDECAN_ENABLED (HAL_MAX_CAN_PROTOCOL_DRIVERS && BOARD_FLASH_SIZE > 1024)
|
#define AP_KDECAN_ENABLED (HAL_MAX_CAN_PROTOCOL_DRIVERS && BOARD_FLASH_SIZE > 1024)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user