mirror of
https://github.com/opentx/opentx.git
synced 2025-07-24 16:55:20 +03:00
Horus:
* Fixed peripheral frequency. * Enabled external module driver: None and PPM protocols working. PPM timing and polarity verified.
This commit is contained in:
parent
0b163ba067
commit
77d892a5de
7 changed files with 195 additions and 117 deletions
|
@ -450,6 +450,40 @@ int cliDisplay(const char ** argv)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
else if (!strcmp(argv[1], "tim")) {
|
||||||
|
int timerNumber;
|
||||||
|
if (toInt(argv, 2, &timerNumber) > 0) {
|
||||||
|
TIM_TypeDef * tim = TIM1;
|
||||||
|
switch (timerNumber) {
|
||||||
|
case 1:
|
||||||
|
tim = TIM1;
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
tim = TIM2;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
serialPrint("TIM%d", timerNumber);
|
||||||
|
serialPrint(" CR1 0x%x", tim->CR1);
|
||||||
|
serialPrint(" CR2 0x%x", tim->CR2);
|
||||||
|
serialPrint(" DIER 0x%x", tim->DIER);
|
||||||
|
serialPrint(" SR 0x%x", tim->SR);
|
||||||
|
serialPrint(" EGR 0x%x", tim->EGR);
|
||||||
|
serialPrint(" CCMR1 0x%x", tim->CCMR1);
|
||||||
|
serialPrint(" CCMR2 0x%x", tim->CCMR2);
|
||||||
|
|
||||||
|
serialPrint(" CNT 0x%x", tim->CNT);
|
||||||
|
serialPrint(" ARR 0x%x", tim->ARR);
|
||||||
|
serialPrint(" PSC 0x%x", tim->PSC);
|
||||||
|
|
||||||
|
serialPrint(" CCER 0x%x", tim->CCER);
|
||||||
|
serialPrint(" CCR1 0x%x", tim->CCR1);
|
||||||
|
serialPrint(" CCR2 0x%x", tim->CCR2);
|
||||||
|
serialPrint(" CCR3 0x%x", tim->CCR3);
|
||||||
|
serialPrint(" CCR4 0x%x", tim->CCR4);
|
||||||
|
}
|
||||||
|
}
|
||||||
else if (toLongLongInt(argv, 1, &address) > 0) {
|
else if (toLongLongInt(argv, 1, &address) > 0) {
|
||||||
int size = 256;
|
int size = 256;
|
||||||
if (toInt(argv, 2, &size) >= 0) {
|
if (toInt(argv, 2, &size) >= 0) {
|
||||||
|
|
|
@ -54,6 +54,7 @@ uint8_t serial2TracesEnabled();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define TRACE_PING(x) do { debugPrintf(x); } while(0)
|
||||||
#define TRACE(...) do { debugPrintf(__VA_ARGS__); debugPrintf("\r\n"); } while(0)
|
#define TRACE(...) do { debugPrintf(__VA_ARGS__); debugPrintf("\r\n"); } while(0)
|
||||||
#define DUMP(data, size) dump(data, size)
|
#define DUMP(data, size) dump(data, size)
|
||||||
#define TRACE_DEBUG(...) debugPrintf("-D- " __VA_ARGS__)
|
#define TRACE_DEBUG(...) debugPrintf("-D- " __VA_ARGS__)
|
||||||
|
|
|
@ -111,9 +111,32 @@ extern "C" void TIM8_TRG_COM_TIM14_IRQHandler()
|
||||||
|
|
||||||
void boardInit()
|
void boardInit()
|
||||||
{
|
{
|
||||||
RCC_AHB1PeriphClockCmd(PWR_RCC_AHB1Periph | LED_RCC_AHB1Periph | LCD_RCC_AHB1Periph | AUDIO_RCC_AHB1Periph | KEYS_RCC_AHB1Periph_GPIO | ADC_RCC_AHB1Periph | SERIAL_RCC_AHB1Periph | TELEMETRY_RCC_AHB1Periph | AUDIO_RCC_AHB1Periph | HAPTIC_RCC_AHB1Periph | INTMODULE_RCC_AHB1Periph | EXTMODULE_RCC_AHB1Periph, ENABLE);
|
RCC_AHB1PeriphClockCmd(PWR_RCC_AHB1Periph |
|
||||||
RCC_APB1PeriphClockCmd(INTERRUPT_5MS_APB1Periph | TIMER_2MHz_APB1Periph | AUDIO_RCC_APB1Periph | SERIAL_RCC_APB1Periph | TELEMETRY_RCC_APB1Periph | AUDIO_RCC_APB1Periph, ENABLE);
|
LED_RCC_AHB1Periph |
|
||||||
RCC_APB2PeriphClockCmd(LCD_RCC_APB2Periph | ADC_RCC_APB2Periph | HAPTIC_RCC_APB2Periph | INTMODULE_RCC_APB2Periph | EXTMODULE_RCC_APB2Periph, ENABLE);
|
LCD_RCC_AHB1Periph |
|
||||||
|
AUDIO_RCC_AHB1Periph |
|
||||||
|
KEYS_RCC_AHB1Periph_GPIO |
|
||||||
|
ADC_RCC_AHB1Periph |
|
||||||
|
SERIAL_RCC_AHB1Periph |
|
||||||
|
TELEMETRY_RCC_AHB1Periph |
|
||||||
|
AUDIO_RCC_AHB1Periph |
|
||||||
|
HAPTIC_RCC_AHB1Periph |
|
||||||
|
INTMODULE_RCC_AHB1Periph |
|
||||||
|
EXTMODULE_RCC_AHB1Periph,
|
||||||
|
ENABLE);
|
||||||
|
RCC_APB1PeriphClockCmd(INTERRUPT_5MS_APB1Periph |
|
||||||
|
TIMER_2MHz_APB1Periph |
|
||||||
|
AUDIO_RCC_APB1Periph |
|
||||||
|
SERIAL_RCC_APB1Periph |
|
||||||
|
TELEMETRY_RCC_APB1Periph |
|
||||||
|
AUDIO_RCC_APB1Periph |
|
||||||
|
EXTMODULE_RCC_APB1Periph,
|
||||||
|
ENABLE);
|
||||||
|
RCC_APB2PeriphClockCmd(LCD_RCC_APB2Periph |
|
||||||
|
ADC_RCC_APB2Periph |
|
||||||
|
HAPTIC_RCC_APB2Periph |
|
||||||
|
INTMODULE_RCC_APB2Periph |
|
||||||
|
EXTMODULE_RCC_APB2Periph, ENABLE);
|
||||||
|
|
||||||
pwrInit();
|
pwrInit();
|
||||||
delaysInit();
|
delaysInit();
|
||||||
|
|
|
@ -65,8 +65,9 @@ extern "C" {
|
||||||
#define BOOTLOADER_SIZE 0x8000
|
#define BOOTLOADER_SIZE 0x8000
|
||||||
#define FIRMWARE_ADDRESS 0x08000000
|
#define FIRMWARE_ADDRESS 0x08000000
|
||||||
|
|
||||||
#define PERI1_FREQUENCY 45000000
|
// HSI is at 168Mhz (over-drive is not enabled!)
|
||||||
#define PERI2_FREQUENCY 90000000
|
#define PERI1_FREQUENCY 42000000
|
||||||
|
#define PERI2_FREQUENCY 84000000
|
||||||
#define TIMER_MULT_APB1 2
|
#define TIMER_MULT_APB1 2
|
||||||
#define TIMER_MULT_APB2 2
|
#define TIMER_MULT_APB2 2
|
||||||
|
|
||||||
|
|
|
@ -282,6 +282,7 @@
|
||||||
#define INTMODULE_DMA_CHANNEL DMA_Channel_4
|
#define INTMODULE_DMA_CHANNEL DMA_Channel_4
|
||||||
#define INTMODULE_TIMER TIM1
|
#define INTMODULE_TIMER TIM1
|
||||||
#define INTMODULE_TIMER_IRQn TIM1_CC_IRQn
|
#define INTMODULE_TIMER_IRQn TIM1_CC_IRQn
|
||||||
|
#define INTMODULE_TIMER_FREQ (PERI2_FREQUENCY * TIMER_MULT_APB2)
|
||||||
|
|
||||||
// External Module
|
// External Module
|
||||||
#define EXTMODULE_RCC_AHB1Periph (RCC_AHB1Periph_GPIOA | RCC_AHB1Periph_GPIOB)
|
#define EXTMODULE_RCC_AHB1Periph (RCC_AHB1Periph_GPIOA | RCC_AHB1Periph_GPIOB)
|
||||||
|
@ -295,7 +296,8 @@
|
||||||
#define EXTMODULE_TIMER TIM2
|
#define EXTMODULE_TIMER TIM2
|
||||||
#define EXTMODULE_PPM_GPIO_AF GPIO_AF_TIM2
|
#define EXTMODULE_PPM_GPIO_AF GPIO_AF_TIM2
|
||||||
#define EXTMODULE_PPM_GPIO_PinSource GPIO_PinSource15
|
#define EXTMODULE_PPM_GPIO_PinSource GPIO_PinSource15
|
||||||
// #define EXTMODULE_TIMER_IRQn TIM2_CC_IRQn
|
#define EXTMODULE_TIMER_IRQn TIM2_IRQn
|
||||||
|
#define EXTMODULE_TIMER_FREQ (PERI1_FREQUENCY * TIMER_MULT_APB1)
|
||||||
|
|
||||||
// Trainer Port
|
// Trainer Port
|
||||||
#define TRAINER_RCC_AHB1Periph (RCC_AHB1Periph_GPIOB | RCC_AHB1Periph_GPIOC)
|
#define TRAINER_RCC_AHB1Periph (RCC_AHB1Periph_GPIOB | RCC_AHB1Periph_GPIOC)
|
||||||
|
|
|
@ -89,12 +89,9 @@ void disable_ppm(uint32_t port)
|
||||||
|
|
||||||
void set_external_ppm_parameters(uint32_t idleTime, uint32_t delay, uint32_t positive)
|
void set_external_ppm_parameters(uint32_t idleTime, uint32_t delay, uint32_t positive)
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
EXTMODULE_TIMER->CCR2 = idleTime;
|
EXTMODULE_TIMER->CCR2 = idleTime;
|
||||||
EXTMODULE_TIMER->CCR1 = delay;
|
EXTMODULE_TIMER->CCR1 = delay;
|
||||||
// we are using complementary output so logic has to be reversed here
|
EXTMODULE_TIMER->CCER = TIM_CCER_CC1E | (positive ? 0 : TIM_CCER_CC1P);
|
||||||
EXTMODULE_TIMER->CCER = TIM_CCER_CC1NE | (positive ? 0 : TIM_CCER_CC1NP);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void init_no_pulses(uint32_t port)
|
void init_no_pulses(uint32_t port)
|
||||||
|
@ -143,7 +140,7 @@ static void intmoduleNoneStart()
|
||||||
INTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
INTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
INTMODULE_TIMER->ARR = 36000 ; // 18mS
|
INTMODULE_TIMER->ARR = 36000 ; // 18mS
|
||||||
INTMODULE_TIMER->CCR2 = 32000 ; // Update time
|
INTMODULE_TIMER->CCR2 = 32000 ; // Update time
|
||||||
INTMODULE_TIMER->PSC = (PERI2_FREQUENCY * TIMER_MULT_APB2) / 2000000 - 1 ; // 0.5uS from 30MHz
|
INTMODULE_TIMER->PSC = INTMODULE_TIMER_FREQ / 2000000 - 1 ; // 0.5uS (2Mhz)
|
||||||
|
|
||||||
INTMODULE_TIMER->CCER = TIM_CCER_CC3E ;
|
INTMODULE_TIMER->CCER = TIM_CCER_CC3E ;
|
||||||
|
|
||||||
|
@ -212,11 +209,11 @@ extern "C" void TIM1_CC_IRQHandler()
|
||||||
|
|
||||||
static void extmoduleNoneStart()
|
static void extmoduleNoneStart()
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
||||||
EXTERNAL_MODULE_OFF();
|
EXTERNAL_MODULE_OFF();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GPIO_PinAFConfig(EXTMODULE_PPM_GPIO, EXTMODULE_PPM_GPIO_PinSource, 0); // TODO : check if needed
|
||||||
GPIO_InitTypeDef GPIO_InitStructure;
|
GPIO_InitTypeDef GPIO_InitStructure;
|
||||||
GPIO_InitStructure.GPIO_Pin = EXTMODULE_PPM_GPIO_PIN;
|
GPIO_InitStructure.GPIO_Pin = EXTMODULE_PPM_GPIO_PIN;
|
||||||
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT ;
|
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT ;
|
||||||
|
@ -226,35 +223,39 @@ static void extmoduleNoneStart()
|
||||||
GPIO_Init(EXTMODULE_PPM_GPIO, &GPIO_InitStructure);
|
GPIO_Init(EXTMODULE_PPM_GPIO, &GPIO_InitStructure);
|
||||||
GPIO_SetBits(EXTMODULE_PPM_GPIO, EXTMODULE_PPM_GPIO_PIN) ; // Set high
|
GPIO_SetBits(EXTMODULE_PPM_GPIO, EXTMODULE_PPM_GPIO_PIN) ; // Set high
|
||||||
|
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
TIM_DeInit(EXTMODULE_TIMER);
|
||||||
EXTMODULE_TIMER->ARR = 36000 ; // 18mS
|
|
||||||
EXTMODULE_TIMER->CCR2 = 32000 ; // Update time
|
|
||||||
EXTMODULE_TIMER->PSC = (PERI2_FREQUENCY * TIMER_MULT_APB2) / 2000000 - 1 ; // 0.5uS from 30MHz
|
|
||||||
|
|
||||||
EXTMODULE_TIMER->CCMR2 = 0 ;
|
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
|
||||||
EXTMODULE_TIMER->EGR = 1 ; // Restart
|
TIM_TimeBaseStructure.TIM_Prescaler = EXTMODULE_TIMER_FREQ / 2000000 - 1; // 0.5uS (2Mhz)
|
||||||
|
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
|
||||||
|
TIM_TimeBaseStructure.TIM_Period = 36000; // 18mS
|
||||||
|
TIM_TimeBaseStructure.TIM_ClockDivision = 0;
|
||||||
|
TIM_TimeBaseStructure.TIM_RepetitionCounter = 0;
|
||||||
|
TIM_TimeBaseInit(EXTMODULE_TIMER, &TIM_TimeBaseStructure);
|
||||||
|
|
||||||
EXTMODULE_TIMER->CCMR2 = TIM_CCMR2_OC3M_1 | TIM_CCMR2_OC3M_0 ; // Toggle CC1 o/p
|
// set CC2 compare to fire slightly before the Update
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
TIM_SetCompare2(EXTMODULE_TIMER, 32000); // 16ms
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_CC2IE ; // Enable this interrupt
|
|
||||||
EXTMODULE_TIMER->CR1 |= TIM_CR1_CEN ;
|
// enable CC2 interrupt
|
||||||
|
TIM_ClearFlag(EXTMODULE_TIMER, TIM_FLAG_CC2);
|
||||||
|
TIM_ITConfig(EXTMODULE_TIMER, TIM_IT_CC2, ENABLE);
|
||||||
|
|
||||||
|
// start timer
|
||||||
|
TIM_Cmd(EXTMODULE_TIMER, ENABLE);
|
||||||
|
|
||||||
|
// enable interrupt and set it's priority
|
||||||
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void extmoduleNoneStop()
|
static void extmoduleNoneStop()
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ;
|
TIM_DeInit(EXTMODULE_TIMER);
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void extmoduleCrossfireStart()
|
static void extmoduleCrossfireStart()
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
EXTERNAL_MODULE_ON();
|
EXTERNAL_MODULE_ON();
|
||||||
|
|
||||||
GPIO_InitTypeDef GPIO_InitStructure;
|
GPIO_InitTypeDef GPIO_InitStructure;
|
||||||
|
@ -269,7 +270,7 @@ static void extmoduleCrossfireStart()
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
EXTMODULE_TIMER->ARR = 5000 ; // 2.5mS
|
EXTMODULE_TIMER->ARR = 5000 ; // 2.5mS
|
||||||
EXTMODULE_TIMER->CCR2 = 32000 ; // Update time
|
EXTMODULE_TIMER->CCR2 = 32000 ; // Update time
|
||||||
EXTMODULE_TIMER->PSC = (PERI2_FREQUENCY * TIMER_MULT_APB2) / 2000000 - 1 ; // 0.5uS from 30MHz
|
EXTMODULE_TIMER->PSC = EXTMODULE_TIMER_FREQ / 2000000 - 1 ; // 0.5uS (2Mhz)
|
||||||
|
|
||||||
EXTMODULE_TIMER->CCMR2 = 0 ;
|
EXTMODULE_TIMER->CCMR2 = 0 ;
|
||||||
EXTMODULE_TIMER->EGR = 1 ; // Restart
|
EXTMODULE_TIMER->EGR = 1 ; // Restart
|
||||||
|
@ -280,12 +281,10 @@ static void extmoduleCrossfireStart()
|
||||||
EXTMODULE_TIMER->CR1 |= TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 |= TIM_CR1_CEN ;
|
||||||
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void extmoduleCrossfireStop()
|
static void extmoduleCrossfireStop()
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ;
|
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ;
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
|
@ -293,7 +292,6 @@ static void extmoduleCrossfireStop()
|
||||||
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
||||||
EXTERNAL_MODULE_OFF();
|
EXTERNAL_MODULE_OFF();
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void intmodulePxxStart()
|
void intmodulePxxStart()
|
||||||
|
@ -373,7 +371,7 @@ void intmodulePxxStart()
|
||||||
INTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
INTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
INTMODULE_TIMER->ARR = 18000 ; // 9mS
|
INTMODULE_TIMER->ARR = 18000 ; // 9mS
|
||||||
INTMODULE_TIMER->CCR2 = 15000 ; // Update time
|
INTMODULE_TIMER->CCR2 = 15000 ; // Update time
|
||||||
INTMODULE_TIMER->PSC = (PERI2_FREQUENCY * TIMER_MULT_APB2) / 2000000 - 1 ; // 0.5uS from 30MHz
|
INTMODULE_TIMER->PSC = INTMODULE_TIMER_FREQ / 2000000 - 1 ; // 0.5uS (2Mhz)
|
||||||
INTMODULE_TIMER->CCER = TIM_CCER_CC3E ;
|
INTMODULE_TIMER->CCER = TIM_CCER_CC3E ;
|
||||||
INTMODULE_TIMER->CCER = TIM_CCER_CC3E ;
|
INTMODULE_TIMER->CCER = TIM_CCER_CC3E ;
|
||||||
|
|
||||||
|
@ -390,13 +388,11 @@ void intmodulePxxStart()
|
||||||
|
|
||||||
static void intmodulePxxStop()
|
static void intmodulePxxStop()
|
||||||
{
|
{
|
||||||
|
|
||||||
INTERNAL_MODULE_OFF();
|
INTERNAL_MODULE_OFF();
|
||||||
}
|
}
|
||||||
|
|
||||||
void extmodulePxxStart()
|
void extmodulePxxStart()
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
EXTERNAL_MODULE_ON();
|
EXTERNAL_MODULE_ON();
|
||||||
|
|
||||||
setupPulsesPXX(EXTERNAL_MODULE);
|
setupPulsesPXX(EXTERNAL_MODULE);
|
||||||
|
@ -413,7 +409,7 @@ void extmodulePxxStart()
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
EXTMODULE_TIMER->ARR = 18000 ; // 9mS
|
EXTMODULE_TIMER->ARR = 18000 ; // 9mS
|
||||||
EXTMODULE_TIMER->CCR2 = 15000 ; // Update time
|
EXTMODULE_TIMER->CCR2 = 15000 ; // Update time
|
||||||
EXTMODULE_TIMER->PSC = (PERI2_FREQUENCY * TIMER_MULT_APB2) / 2000000 - 1 ; // 0.5uS from 30MHz
|
EXTMODULE_TIMER->PSC = EXTMODULE_TIMER_FREQ / 2000000 - 1 ; // 0.5uS (2Mhz)
|
||||||
EXTMODULE_TIMER->CCER = TIM_CCER_CC1NE ;
|
EXTMODULE_TIMER->CCER = TIM_CCER_CC1NE ;
|
||||||
EXTMODULE_TIMER->CR2 = TIM_CR2_OIS1 ; // O/P idle high
|
EXTMODULE_TIMER->CR2 = TIM_CR2_OIS1 ; // O/P idle high
|
||||||
EXTMODULE_TIMER->BDTR = TIM_BDTR_MOE ; // Enable outputs
|
EXTMODULE_TIMER->BDTR = TIM_BDTR_MOE ; // Enable outputs
|
||||||
|
@ -424,16 +420,16 @@ void extmodulePxxStart()
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_CC1DE ; // Enable DMA on CC1 match
|
EXTMODULE_TIMER->DIER |= TIM_DIER_CC1DE ; // Enable DMA on CC1 match
|
||||||
EXTMODULE_TIMER->DCR = 13;
|
EXTMODULE_TIMER->DCR = 13;
|
||||||
|
|
||||||
// Enable the DMA channel here, DMA2 stream 2, channel 7
|
// Enable the DMA channel here, DMA1 stream 5, channel 3 (TIM2_CH1)
|
||||||
DMA2_Stream2->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
DMA1_Stream5->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
||||||
DMA2->LIFCR = DMA_LIFCR_CTCIF2 | DMA_LIFCR_CHTIF2 | DMA_LIFCR_CTEIF2 | DMA_LIFCR_CDMEIF2 | DMA_LIFCR_CFEIF2 ; // Write ones to clear bits
|
DMA1->HIFCR = DMA_HIFCR_CTCIF5 | DMA_HIFCR_CHTIF5 | DMA_HIFCR_CTEIF5 | DMA_HIFCR_CDMEIF5 | DMA_HIFCR_CFEIF5 ; // Write ones to clear bits
|
||||||
DMA2_Stream2->CR = DMA_SxCR_CHSEL_0 | DMA_SxCR_CHSEL_1 | DMA_SxCR_CHSEL_2 | DMA_SxCR_PL_0 | DMA_SxCR_MSIZE_0
|
DMA1_Stream5->CR = DMA_SxCR_CHSEL_0 | DMA_SxCR_CHSEL_1 | DMA_SxCR_PL_0 | DMA_SxCR_MSIZE_0
|
||||||
| DMA_SxCR_PSIZE_0 | DMA_SxCR_MINC | DMA_SxCR_DIR_0 | DMA_SxCR_PFCTRL ;
|
| DMA_SxCR_PSIZE_0 | DMA_SxCR_MINC | DMA_SxCR_DIR_0 | DMA_SxCR_PFCTRL ;
|
||||||
DMA2_Stream2->PAR = CONVERT_PTR_UINT(&EXTMODULE_TIMER->DMAR);
|
DMA1_Stream5->PAR = CONVERT_PTR_UINT(&EXTMODULE_TIMER->DMAR);
|
||||||
DMA2_Stream2->M0AR = CONVERT_PTR_UINT(&modulePulsesData[EXTERNAL_MODULE].pxx.pulses[1]);
|
DMA1_Stream5->M0AR = CONVERT_PTR_UINT(&modulePulsesData[EXTERNAL_MODULE].pxx.pulses[1]);
|
||||||
// DMA2_Stream2->FCR = 0x05 ; //DMA_SxFCR_DMDIS | DMA_SxFCR_FTH_0 ;
|
// DMA1_Stream5->FCR = 0x05 ; //DMA_SxFCR_DMDIS | DMA_SxFCR_FTH_0 ;
|
||||||
// DMA2_Stream2->NDTR = 100 ;
|
// DMA1_Stream5->NDTR = 100 ;
|
||||||
DMA2_Stream2->CR |= DMA_SxCR_EN ; // Enable DMA
|
DMA1_Stream5->CR |= DMA_SxCR_EN ; // Enable DMA
|
||||||
|
|
||||||
EXTMODULE_TIMER->CCMR1 = TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_0 ; // Toggle CC1 o/p
|
EXTMODULE_TIMER->CCMR1 = TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_0 ; // Toggle CC1 o/p
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
||||||
|
@ -441,27 +437,22 @@ void extmodulePxxStart()
|
||||||
EXTMODULE_TIMER->CR1 |= TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 |= TIM_CR1_CEN ;
|
||||||
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn);
|
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn);
|
||||||
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void extmodulePxxStop()
|
static void extmodulePxxStop()
|
||||||
{
|
{
|
||||||
#if 0
|
DMA1_Stream5->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
||||||
DMA2_Stream2->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
|
||||||
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ;
|
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ;
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
||||||
EXTERNAL_MODULE_OFF();
|
EXTERNAL_MODULE_OFF();
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(DSM2)
|
#if defined(DSM2)
|
||||||
static void extmoduleDsm2Start()
|
static void extmoduleDsm2Start()
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
|
|
||||||
EXTERNAL_MODULE_ON();
|
EXTERNAL_MODULE_ON();
|
||||||
|
|
||||||
setupPulsesDSM2(EXTERNAL_MODULE);
|
setupPulsesDSM2(EXTERNAL_MODULE);
|
||||||
|
@ -478,7 +469,7 @@ static void extmoduleDsm2Start()
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
EXTMODULE_TIMER->ARR = 44000 ; // 22mS
|
EXTMODULE_TIMER->ARR = 44000 ; // 22mS
|
||||||
EXTMODULE_TIMER->CCR2 = 40000 ; // Update time
|
EXTMODULE_TIMER->CCR2 = 40000 ; // Update time
|
||||||
EXTMODULE_TIMER->PSC = (PERI2_FREQUENCY * TIMER_MULT_APB2) / 2000000 - 1 ; // 0.5uS from 30MHz
|
EXTMODULE_TIMER->PSC = EXTMODULE_TIMER_FREQ / 2000000 - 1 ; // 0.5uS (2Mhz)
|
||||||
EXTMODULE_TIMER->CCER = TIM_CCER_CC1NE | TIM_CCER_CC1NP ;
|
EXTMODULE_TIMER->CCER = TIM_CCER_CC1NE | TIM_CCER_CC1NP ;
|
||||||
EXTMODULE_TIMER->CR2 = TIM_CR2_OIS1 ; // O/P idle high
|
EXTMODULE_TIMER->CR2 = TIM_CR2_OIS1 ; // O/P idle high
|
||||||
EXTMODULE_TIMER->BDTR = TIM_BDTR_MOE ; // Enable outputs
|
EXTMODULE_TIMER->BDTR = TIM_BDTR_MOE ; // Enable outputs
|
||||||
|
@ -489,16 +480,16 @@ static void extmoduleDsm2Start()
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_CC1DE ; // Enable DMA on CC1 match
|
EXTMODULE_TIMER->DIER |= TIM_DIER_CC1DE ; // Enable DMA on CC1 match
|
||||||
EXTMODULE_TIMER->DCR = 13 ; // DMA to CC1
|
EXTMODULE_TIMER->DCR = 13 ; // DMA to CC1
|
||||||
|
|
||||||
// Enable the DMA channel here, DMA2 stream 2, channel 7
|
// Enable the DMA channel here, DMA1 stream 5, channel 3 (TIM2_CH1)
|
||||||
DMA2_Stream2->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
DMA1_Stream5->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
||||||
DMA2->LIFCR = DMA_LIFCR_CTCIF2 | DMA_LIFCR_CHTIF2 | DMA_LIFCR_CTEIF2 | DMA_LIFCR_CDMEIF2 | DMA_LIFCR_CFEIF2 ; // Write ones to clear bits
|
DMA1->HIFCR = DMA_HIFCR_CTCIF5 | DMA_HIFCR_CHTIF5 | DMA_HIFCR_CTEIF5 | DMA_HIFCR_CDMEIF5 | DMA_HIFCR_CFEIF5 ; // Write ones to clear bits
|
||||||
DMA2_Stream2->CR = DMA_SxCR_CHSEL_0 | DMA_SxCR_CHSEL_1 | DMA_SxCR_CHSEL_2 | DMA_SxCR_PL_0 | DMA_SxCR_MSIZE_0
|
DMA1_Stream5->CR = DMA_SxCR_CHSEL_0 | DMA_SxCR_CHSEL_1 | DMA_SxCR_PL_0 | DMA_SxCR_MSIZE_0
|
||||||
| DMA_SxCR_PSIZE_0 | DMA_SxCR_MINC | DMA_SxCR_DIR_0 | DMA_SxCR_PFCTRL ;
|
| DMA_SxCR_PSIZE_0 | DMA_SxCR_MINC | DMA_SxCR_DIR_0 | DMA_SxCR_PFCTRL ;
|
||||||
DMA2_Stream2->PAR = CONVERT_PTR_UINT(&EXTMODULE_TIMER->DMAR);
|
DMA1_Stream5->PAR = CONVERT_PTR_UINT(&EXTMODULE_TIMER->DMAR);
|
||||||
DMA2_Stream2->M0AR = CONVERT_PTR_UINT(&modulePulsesData[EXTERNAL_MODULE].dsm2.pulses[1]);
|
DMA1_Stream5->M0AR = CONVERT_PTR_UINT(&modulePulsesData[EXTERNAL_MODULE].dsm2.pulses[1]);
|
||||||
// DMA2_Stream2->FCR = 0x05 ; //DMA_SxFCR_DMDIS | DMA_SxFCR_FTH_0 ;
|
// DMA1_Stream5->FCR = 0x05 ; //DMA_SxFCR_DMDIS | DMA_SxFCR_FTH_0 ;
|
||||||
// DMA2_Stream2->NDTR = 100 ;
|
// DMA1_Stream5->NDTR = 100 ;
|
||||||
DMA2_Stream2->CR |= DMA_SxCR_EN ; // Enable DMA
|
DMA1_Stream5->CR |= DMA_SxCR_EN ; // Enable DMA
|
||||||
|
|
||||||
EXTMODULE_TIMER->CCMR1 = TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_0 ; // Toggle CC1 o/p
|
EXTMODULE_TIMER->CCMR1 = TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_0 ; // Toggle CC1 o/p
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
||||||
|
@ -506,32 +497,45 @@ static void extmoduleDsm2Start()
|
||||||
EXTMODULE_TIMER->CR1 |= TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 |= TIM_CR1_CEN ;
|
||||||
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void extmoduleDsm2Stop()
|
static void extmoduleDsm2Stop()
|
||||||
{
|
{
|
||||||
#if 0
|
DMA1_Stream5->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
||||||
DMA2_Stream2->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
|
||||||
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ;
|
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ;
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
||||||
EXTERNAL_MODULE_OFF();
|
EXTERNAL_MODULE_OFF();
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void extmodulePpmStart()
|
static void extmodulePpmStart()
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
EXTERNAL_MODULE_ON();
|
EXTERNAL_MODULE_ON();
|
||||||
|
|
||||||
configure_pins( EXTMODULE_PPM_GPIO_PIN, PIN_PERIPHERAL | PIN_PORTA | PIN_PER_3 | PIN_OS25 | PIN_PUSHPULL ) ;
|
GPIO_PinAFConfig(EXTMODULE_PPM_GPIO, EXTMODULE_PPM_GPIO_PinSource, EXTMODULE_PPM_GPIO_AF);
|
||||||
|
GPIO_InitTypeDef GPIO_InitStructure;
|
||||||
|
GPIO_InitStructure.GPIO_Pin = EXTMODULE_PPM_GPIO_PIN;
|
||||||
|
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
|
||||||
|
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
|
||||||
|
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
|
||||||
|
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
|
||||||
|
GPIO_Init(EXTMODULE_PPM_GPIO, &GPIO_InitStructure);
|
||||||
|
|
||||||
// Timer1
|
// PPM generation principle:
|
||||||
modulePulsesData[EXTERNAL_MODULE].ppm.ptr = modulePulsesData[EXTERNAL_MODULE].ppm.pulses;
|
//
|
||||||
|
// Hardware timer in PWM mode is used for PPM generation
|
||||||
|
// Output is OFF if CNT<CCR1(delay) and ON if bigger
|
||||||
|
// CCR1 register defines duration of pulse length and is constant
|
||||||
|
// AAR register defines duration of each pulse, it is
|
||||||
|
// updated after every pulse in Update interrupt handler.
|
||||||
|
// CCR2 register defines duration of no pulses (time between two pulse trains)
|
||||||
|
// it is calculated every round to have PPM period constant.
|
||||||
|
// CC2 interrupt is then used to setup new PPM values for the
|
||||||
|
// next PPM pulses train.
|
||||||
|
// stop timer
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
|
|
||||||
// setupPulsesPPM() is also configuring registers,
|
// setupPulsesPPM() is also configuring registers,
|
||||||
|
@ -539,83 +543,90 @@ static void extmodulePpmStart()
|
||||||
setupPulsesPPM(EXTERNAL_MODULE) ;
|
setupPulsesPPM(EXTERNAL_MODULE) ;
|
||||||
|
|
||||||
EXTMODULE_TIMER->ARR = *modulePulsesData[EXTERNAL_MODULE].ppm.ptr++ ;
|
EXTMODULE_TIMER->ARR = *modulePulsesData[EXTERNAL_MODULE].ppm.ptr++ ;
|
||||||
EXTMODULE_TIMER->PSC = (PERI2_FREQUENCY * TIMER_MULT_APB2) / 2000000 - 1 ; // 0.5uS from 30MHz
|
EXTMODULE_TIMER->PSC = EXTMODULE_TIMER_FREQ / 2000000 - 1 ; // 0.5uS (2Mhz)
|
||||||
|
|
||||||
|
// CH1 PWM mode 1, CH1 out is OFF if CNT<CCR1(delay) and ON if bigger (up to AAR,which is pulse length)
|
||||||
EXTMODULE_TIMER->CCMR1 = TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC2PE; // PWM mode 1
|
EXTMODULE_TIMER->CCMR1 = TIM_CCMR1_OC1M_1 | TIM_CCMR1_OC1M_2 | TIM_CCMR1_OC2PE; // PWM mode 1
|
||||||
EXTMODULE_TIMER->BDTR = TIM_BDTR_MOE ;
|
|
||||||
|
// Reloads register vales now
|
||||||
EXTMODULE_TIMER->EGR = 1 ;
|
EXTMODULE_TIMER->EGR = 1 ;
|
||||||
|
|
||||||
|
// Update DMA request enabled. WHY?????
|
||||||
EXTMODULE_TIMER->DIER = TIM_DIER_UDE ;
|
EXTMODULE_TIMER->DIER = TIM_DIER_UDE ;
|
||||||
|
|
||||||
|
// clear interrupt flags and enable Update and
|
||||||
|
// CC2 interrupts (this one is enabled now to trigger pulse setup)
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_UIF ; // Clear flag
|
EXTMODULE_TIMER->SR &= ~TIM_SR_UIF ; // Clear flag
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_CC2IE ;
|
EXTMODULE_TIMER->DIER |= TIM_DIER_CC2IE ;
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_UIE ;
|
EXTMODULE_TIMER->DIER |= TIM_DIER_UIE ;
|
||||||
|
|
||||||
EXTMODULE_TIMER->CR1 = TIM_CR1_CEN ;
|
// enable timer and global interrupts
|
||||||
|
EXTMODULE_TIMER->CR1 |= TIM_CR1_CEN ;
|
||||||
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_EnableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
NVIC_SetPriority(EXTMODULE_TIMER_IRQn, 7);
|
||||||
NVIC_EnableIRQ(TIM8_UP_TIM13_IRQn) ;
|
|
||||||
NVIC_SetPriority(TIM8_UP_TIM13_IRQn, 7);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void extmodulePpmStop()
|
static void extmodulePpmStop()
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
NVIC_DisableIRQ(EXTMODULE_TIMER_IRQn) ;
|
||||||
NVIC_DisableIRQ(TIM8_UP_TIM13_IRQn) ;
|
|
||||||
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE & ~TIM_DIER_UIE ;
|
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE & ~TIM_DIER_UIE ;
|
||||||
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
EXTMODULE_TIMER->CR1 &= ~TIM_CR1_CEN ;
|
||||||
|
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF & ~TIM_SR_UIF; // Clear all flags
|
||||||
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
if (!IS_TRAINER_EXTERNAL_MODULE()) {
|
||||||
EXTERNAL_MODULE_OFF();
|
EXTERNAL_MODULE_OFF();
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
extern "C" void TIM2_IRQHandler()
|
||||||
extern "C" void TIM8_CC_IRQHandler()
|
|
||||||
{
|
{
|
||||||
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ; // stop this interrupt
|
//determine if its CC or UP interrupt
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
uint16_t sr = EXTMODULE_TIMER->SR;
|
||||||
|
uint16_t dier = EXTMODULE_TIMER->DIER;
|
||||||
|
|
||||||
setupPulses(EXTERNAL_MODULE) ;
|
if (sr & TIM_SR_CC2IF && dier & TIM_DIER_CC2IE) { // Capture/Compare 2 interrupt enabled and fired
|
||||||
|
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear flag
|
||||||
|
|
||||||
if (s_current_protocol[EXTERNAL_MODULE] == PROTO_PXX) {
|
setupPulses(EXTERNAL_MODULE);
|
||||||
DMA2_Stream2->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
|
||||||
DMA2->LIFCR = DMA_LIFCR_CTCIF2 | DMA_LIFCR_CHTIF2 | DMA_LIFCR_CTEIF2 | DMA_LIFCR_CDMEIF2 | DMA_LIFCR_CFEIF2 ; // Write ones to clear bits
|
if (s_current_protocol[EXTERNAL_MODULE] == PROTO_PXX) {
|
||||||
DMA2_Stream2->M0AR = CONVERT_PTR_UINT(&modulePulsesData[EXTERNAL_MODULE].pxx.pulses[1]);
|
DMA1_Stream5->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
||||||
DMA2_Stream2->CR |= DMA_SxCR_EN ; // Enable DMA
|
DMA1->HIFCR = DMA_HIFCR_CTCIF5 | DMA_HIFCR_CHTIF5 | DMA_HIFCR_CTEIF5 | DMA_HIFCR_CDMEIF5 | DMA_HIFCR_CFEIF5 ; // Write ones to clear bits
|
||||||
EXTMODULE_TIMER->CCR1 = modulePulsesData[EXTERNAL_MODULE].pxx.pulses[0];
|
DMA1_Stream5->M0AR = CONVERT_PTR_UINT(&modulePulsesData[EXTERNAL_MODULE].pxx.pulses[1]);
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_CC2IE ; // Enable this interrupt
|
DMA1_Stream5->CR |= DMA_SxCR_EN ; // Enable DMA
|
||||||
}
|
EXTMODULE_TIMER->CCR1 = modulePulsesData[EXTERNAL_MODULE].pxx.pulses[0];
|
||||||
|
}
|
||||||
#if defined(DSM2)
|
#if defined(DSM2)
|
||||||
else if (s_current_protocol[EXTERNAL_MODULE] >= PROTO_DSM2_LP45 && s_current_protocol[EXTERNAL_MODULE] <= PROTO_DSM2_DSMX) {
|
else if (s_current_protocol[EXTERNAL_MODULE] >= PROTO_DSM2_LP45 && s_current_protocol[EXTERNAL_MODULE] <= PROTO_DSM2_DSMX) {
|
||||||
DMA2_Stream2->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
DMA1_Stream5->CR &= ~DMA_SxCR_EN ; // Disable DMA
|
||||||
DMA2->LIFCR = DMA_LIFCR_CTCIF2 | DMA_LIFCR_CHTIF2 | DMA_LIFCR_CTEIF2 | DMA_LIFCR_CDMEIF2 | DMA_LIFCR_CFEIF2 ; // Write ones to clear bits
|
DMA1->HIFCR = DMA_HIFCR_CTCIF5 | DMA_HIFCR_CHTIF5 | DMA_HIFCR_CTEIF5 | DMA_HIFCR_CDMEIF5 | DMA_HIFCR_CFEIF5 ; // Write ones to clear bits
|
||||||
DMA2_Stream2->M0AR = CONVERT_PTR_UINT(&modulePulsesData[EXTERNAL_MODULE].dsm2.pulses[1]);
|
DMA1_Stream5->M0AR = CONVERT_PTR_UINT(&modulePulsesData[EXTERNAL_MODULE].dsm2.pulses[1]);
|
||||||
DMA2_Stream2->CR |= DMA_SxCR_EN ; // Enable DMA
|
DMA1_Stream5->CR |= DMA_SxCR_EN ; // Enable DMA
|
||||||
EXTMODULE_TIMER->CCR1 = modulePulsesData[EXTERNAL_MODULE].dsm2.pulses[0];
|
EXTMODULE_TIMER->CCR1 = modulePulsesData[EXTERNAL_MODULE].dsm2.pulses[0];
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_CC2IE ; // Enable this interrupt
|
}
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
else if (s_current_protocol[EXTERNAL_MODULE] == PROTO_PPM) {
|
else if (s_current_protocol[EXTERNAL_MODULE] == PROTO_PPM) {
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_UDE ;
|
// Stop CC2 interrupt, the pulse train period ended
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_UIF ; // Clear this flag
|
// the new PPM values were set, we begin new pulse train
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_UIE ; // Enable this interrupt
|
// generation with Update interrupt
|
||||||
|
EXTMODULE_TIMER->DIER &= ~TIM_DIER_CC2IE ; // stop CC2 interrupt
|
||||||
|
EXTMODULE_TIMER->DIER |= TIM_DIER_UDE ;
|
||||||
|
EXTMODULE_TIMER->SR &= ~TIM_SR_UIF ; // Clear Update interrupt flag
|
||||||
|
EXTMODULE_TIMER->DIER |= TIM_DIER_UIE ; // Enable Update interrupt
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_CC2IE ; // Enable this interrupt
|
if (sr & TIM_SR_UIF && dier & TIM_DIER_UIE) { // Update interrupt enabled and fired
|
||||||
|
EXTMODULE_TIMER->SR &= ~TIM_SR_UIF ; // Clear flag
|
||||||
|
if (s_current_protocol[EXTERNAL_MODULE] == PROTO_PPM) {
|
||||||
|
EXTMODULE_TIMER->ARR = *modulePulsesData[EXTERNAL_MODULE].ppm.ptr++ ;
|
||||||
|
if (*modulePulsesData[EXTERNAL_MODULE].ppm.ptr == 0) {
|
||||||
|
// we reached the end of PPM pulses
|
||||||
|
// enable CC2 interrupt (which comes before Update in any case)
|
||||||
|
// to start new PPM cycle and setup pulses
|
||||||
|
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear CC1 flag
|
||||||
|
EXTMODULE_TIMER->DIER |= TIM_DIER_CC2IE ; // Enable CC1 interrupt
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" void TIM8_UP_TIM13_IRQHandler()
|
|
||||||
{
|
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_UIF ; // Clear flag
|
|
||||||
|
|
||||||
EXTMODULE_TIMER->ARR = *modulePulsesData[EXTERNAL_MODULE].ppm.ptr++ ;
|
|
||||||
if (*modulePulsesData[EXTERNAL_MODULE].ppm.ptr == 0) {
|
|
||||||
EXTMODULE_TIMER->SR &= ~TIM_SR_CC2IF ; // Clear this flag
|
|
||||||
EXTMODULE_TIMER->DIER |= TIM_DIER_CC2IE ; // Enable this interrupt
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
|
@ -403,6 +403,12 @@ extern OS_MutexID audioMutex;
|
||||||
|
|
||||||
#if defined(CPUSTM32)
|
#if defined(CPUSTM32)
|
||||||
inline void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct) { }
|
inline void GPIO_Init(GPIO_TypeDef* GPIOx, GPIO_InitTypeDef* GPIO_InitStruct) { }
|
||||||
|
#define TIM_DeInit(...)
|
||||||
|
#define TIM_TimeBaseInit(...)
|
||||||
|
#define TIM_SetCompare2(...)
|
||||||
|
#define TIM_ClearFlag(...)
|
||||||
|
#define TIM_Cmd(...)
|
||||||
|
#define TIM_ITConfig(...)
|
||||||
#define GPIO_SetBits(GPIOx, pin) GPIOx->BSRRL |= pin
|
#define GPIO_SetBits(GPIOx, pin) GPIOx->BSRRL |= pin
|
||||||
#define GPIO_ResetBits(GPIOx, pin) GPIOx->BSRRL &= ~pin
|
#define GPIO_ResetBits(GPIOx, pin) GPIOx->BSRRL &= ~pin
|
||||||
#define GPIO_ReadInputDataBit(GPIOx, pin) (GPIOx->BSRRL & pin)
|
#define GPIO_ReadInputDataBit(GPIOx, pin) (GPIOx->BSRRL & pin)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue