этот вопрос поднимался, всё падало на каких-то callback.
Вроде у вас даже f405?
dma в кольце
/* DMA Peripheral to Memory */
/* Clear DBM bit */
DMA1_Stream1->CR &= (uint32_t)(~DMA_SxCR_DBM);
/* Configure DMA Stream data length */
DMA1_Stream1->NDTR = sizeof(buff->data);
/* Configure DMA Stream source address */
DMA1_Stream1->PAR = (uint32_t)&USART3->DR;
/* Configure DMA Stream destination address */
DMA1_Stream1->M0AR = (uint32_t)&buff->data;
/* Enable dma Transfer error/Direct mode error */
DMA1_Stream1->CR |= ((uint32_t)DMA_SxCR_TEIE) | ((uint32_t)DMA_SxCR_DMEIE);
/* Enable the Peripheral */
DMA1_Stream1->CR |= DMA_SxCR_EN;
/* clear ore flag sequence below */
USART3->SR;
USART3->DR;
/* DMA Enable Receiver */
USART3->CR3 |= USART_CR3_DMAR;
думаю понадобятся вот эти прерывания
USART3->CR1 |= USART_CR1_IDLEIE;
USART3->CR1 |= USART_CR1_PEIE;
USART3->CR3 |= USART_CR3_EIE;
USART3->CR1 |= UART_IT_TC;
разрешить в nvic uart
в irq
{
// idle?
(void)USART3->SR;
(void)USART3->DR;
тут можно проверить \r\n
//
}
элемент в хвосте
&buff->data[RING_BUFF_LEN - DMA1_Stream1->NDTR];
Не, у меня l452, но одна фигня, спасибо!
да было бы за что, надеюсь всё получится у вас. idle, как писали выше и на таймере сможете сделать. Как вариант, действительно по байту принимать и вставлять в свой кольцевой буфер.
и семафорами обмазать
О боже, это зачем?) 😢 Слава богу, мы без ртос
И стрелками
на самом деле так сделать вполне неплохо сработал idle, семафорим, задача просыпается и парсит, а всё остальное время спит.
насоветуют тебе сейчас всякого)
Ага, а сверху семафор, который красно/желто/зелёный 🗿🗿🗿
Обсуждают сегодня