Тактирование с TIM8.
Это не коммерческий проект, попробовать. И не работает. Если в обработчике прерывания раскомментировать строку
//Parallel_Data_Buffer[i] = GPIOB->IDR;
буфер заполняется. А вот DMA в буфер ничего не пишет. Чувствую, что накосячил, но чтение мануала и апнот не помогло.
Код
#define DMA_STREAM DMA2_Stream1
#define DMA_CHANNEL DMA_Channel_7
#define BUFFER_SIZE 127
void dma_init(void)
{
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_DMA2, ENABLE);
/* GPIOA and GPIOD clock enable */
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE);
/* GPIO Configuration ------------------------------------------------------*/
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_3
| GPIO_Pin_4 | GPIO_Pin_5
| GPIO_Pin_6 | GPIO_Pin_7
| GPIO_Pin_8 | GPIO_Pin_9
| GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOB, &GPIO_InitStructure);
DMA_Cmd(DMA_STREAM, DISABLE);
DMA_DeInit(DMA_STREAM);
/* DMA Channel5 Configuration ----------------------------------------------*/
/* Configure DMA Stream */
DMA_InitStructure.DMA_Channel = DMA_CHANNEL;
DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&GPIOB->IDR;
DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t) Parallel_Data_Buffer[0];
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralToMemory;
DMA_InitStructure.DMA_BufferSize = (uint32_t)BUFFER_SIZE;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord; //_Word;
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord; //_Word;
DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; // DMA_Mode_Circular;
DMA_InitStructure.DMA_Priority = DMA_Priority_High;
DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;
DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_Full;
DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;
DMA_Init(DMA_STREAM, &DMA_InitStructure);
/* Enable DMA Stream Transfer Complete interrupt */
DMA_ITConfig(DMA_STREAM, DMA_IT_TC, ENABLE);
/* DMA Stream enable */
DMA_Cmd(DMA_STREAM, ENABLE);
}
//------------------------------------------------------------
void TIM8_UP_TIM13_IRQHandler(void)
{
if(TIM_GetITStatus(TIM8,TIM_IT_Update)!=RESET)
{
TIM8->SR = (uint16_t)~TIM_IT_Update;
}
GPIOA->BSRRH = GPIO_Pin_2; // Тактируем АЦП
__NOP();
GPIOA->BSRRL = GPIO_Pin_2;
//Parallel_Data_Buffer[i] = GPIOB->IDR;
if(i < 127) i++;
else i = 0;
}
#define DMA_CHANNEL DMA_Channel_7
#define BUFFER_SIZE 127
void dma_init(void)
{
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_DMA2, ENABLE);
/* GPIOA and GPIOD clock enable */
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE);
/* GPIO Configuration ------------------------------------------------------*/
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_3
| GPIO_Pin_4 | GPIO_Pin_5
| GPIO_Pin_6 | GPIO_Pin_7
| GPIO_Pin_8 | GPIO_Pin_9
| GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOB, &GPIO_InitStructure);
DMA_Cmd(DMA_STREAM, DISABLE);
DMA_DeInit(DMA_STREAM);
/* DMA Channel5 Configuration ----------------------------------------------*/
/* Configure DMA Stream */
DMA_InitStructure.DMA_Channel = DMA_CHANNEL;
DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&GPIOB->IDR;
DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t) Parallel_Data_Buffer[0];
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralToMemory;
DMA_InitStructure.DMA_BufferSize = (uint32_t)BUFFER_SIZE;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord; //_Word;
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord; //_Word;
DMA_InitStructure.DMA_Mode = DMA_Mode_Normal; // DMA_Mode_Circular;
DMA_InitStructure.DMA_Priority = DMA_Priority_High;
DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;
DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_Full;
DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;
DMA_Init(DMA_STREAM, &DMA_InitStructure);
/* Enable DMA Stream Transfer Complete interrupt */
DMA_ITConfig(DMA_STREAM, DMA_IT_TC, ENABLE);
/* DMA Stream enable */
DMA_Cmd(DMA_STREAM, ENABLE);
}
//------------------------------------------------------------
void TIM8_UP_TIM13_IRQHandler(void)
{
if(TIM_GetITStatus(TIM8,TIM_IT_Update)!=RESET)
{
TIM8->SR = (uint16_t)~TIM_IT_Update;
}
GPIOA->BSRRH = GPIO_Pin_2; // Тактируем АЦП
__NOP();
GPIOA->BSRRL = GPIO_Pin_2;
//Parallel_Data_Buffer[i] = GPIOB->IDR;
if(i < 127) i++;
else i = 0;
}