mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 18:08:30 -04:00
HAL_ChibiOS: use software signal reader for RCInput if available
This commit is contained in:
parent
6be4c710c3
commit
eeea2c9961
@ -25,13 +25,14 @@
|
||||
extern AP_IOMCU iomcu;
|
||||
#endif
|
||||
|
||||
|
||||
using namespace ChibiOS;
|
||||
extern const AP_HAL::HAL& hal;
|
||||
void RCInput::init()
|
||||
{
|
||||
#if HAL_USE_EICU == TRUE
|
||||
ppm_init(1000000, false);
|
||||
#if HAL_USE_ICU == TRUE
|
||||
//attach timer channel on which the signal will be received
|
||||
sig_reader.attach_capture_timer(&RCIN_ICU_TIMER, RCIN_ICU_CHANNEL, STM32_RCIN_DMA_STREAM, STM32_RCIN_DMA_CHANNEL);
|
||||
rcin_prot.init();
|
||||
#endif
|
||||
chMtxObjectInit(&rcin_mutex);
|
||||
_init = true;
|
||||
@ -166,12 +167,27 @@ void RCInput::_timer_tick(void)
|
||||
if (!_init) {
|
||||
return;
|
||||
}
|
||||
#if HAL_USE_EICU == TRUE
|
||||
if (ppm_available()) {
|
||||
#if HAL_USE_ICU == TRUE
|
||||
uint32_t width_s0, width_s1;
|
||||
|
||||
while(sig_reader.read(width_s0, width_s1)) {
|
||||
rcin_prot.process_pulse(width_s0, width_s1);
|
||||
}
|
||||
|
||||
if (rcin_prot.new_input()) {
|
||||
chMtxLock(&rcin_mutex);
|
||||
_num_channels = ppm_read_bulk(_rc_values, RC_INPUT_MAX_CHANNELS);
|
||||
_rcin_timestamp_last_signal = AP_HAL::micros();
|
||||
_num_channels = rcin_prot.num_channels();
|
||||
for (uint8_t i=0; i<_num_channels; i++) {
|
||||
_rc_values[i] = rcin_prot.read(i);
|
||||
}
|
||||
chMtxUnlock(&rcin_mutex);
|
||||
//TODO: adjust bounce buffer size appropriately per protocol type
|
||||
if (rcin_prot.protocol_detected() == AP_RCProtocol::SBUS || rcin_prot.protocol_detected() == AP_RCProtocol::DSM) {
|
||||
sig_reader.set_bounce_buf_size(128); //increase the buffer size if it isn't
|
||||
} else {
|
||||
sig_reader.set_bounce_buf_size(16);
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
|
@ -17,10 +17,16 @@
|
||||
#pragma once
|
||||
|
||||
#include "AP_HAL_ChibiOS.h"
|
||||
#include "SoftSigReader.h"
|
||||
|
||||
#ifdef HAL_RCINPUT_WITH_AP_RADIO
|
||||
#include <AP_Radio/AP_Radio.h>
|
||||
#endif
|
||||
|
||||
#if HAL_USE_ICU == TRUE
|
||||
#include <AP_RCProtocol/AP_RCProtocol.h>
|
||||
#endif
|
||||
|
||||
#ifndef RC_INPUT_MAX_CHANNELS
|
||||
#define RC_INPUT_MAX_CHANNELS 18
|
||||
#endif
|
||||
@ -62,6 +68,12 @@ private:
|
||||
AP_Radio *radio;
|
||||
uint32_t last_radio_us;
|
||||
#endif
|
||||
|
||||
#ifdef HAL_USE_ICU
|
||||
ChibiOS::SoftSigReader sig_reader;
|
||||
AP_RCProtocol rcin_prot;
|
||||
#endif
|
||||
|
||||
#if HAL_WITH_IO_MCU
|
||||
uint32_t last_iomcu_us;
|
||||
#endif
|
||||
|
Loading…
Reference in New Issue
Block a user