ArterySW 发表于 2020-9-5 17:02

SC0028_AT32F4xx_SPI使用DMA进行主机发送从机接收

本帖最后由 ArterySW 于 2020-9-7 09:59 编辑

SC0028_AT32F4xx_SPI使用DMA进行主机发送从机接收


示例目的演示AT32F4xx SPI使用DMA进行主机发送数据从机接收数据通信。
支持型号列表:AT32F403xxAT32F403AxxAT32F407xxAT32F413xxAT32F415xxAT32F421xx
主要使用外设: SPI
1 快速使用方法1.1 硬件资源1)    AT-START-F403A V1.0开发板(其他型号请使用对应的开发板)2)    SPI1:PA4,PA5,PA7       SPI2:PB12, PB13,PB14
1.2 软件资源1)    SourceCode       SPI_DMA_MA_TX&SLA_RX源程序       注:所有project都是基于keil5而建立,若用户需要在其他编译环境上使用,请参考AT32F4xx_StdPeriph_Lib_V1.x.x\Project\xxx\Templates中各种编译环境(例如IAR6/7,keil 4/5)进行简单修改即可。1.3 示例使用1)    打开 SPI_DMA_MA_TX&SLA_RX 源程序,编译后下载到实验板2)    如果用AT-START-F403A V1.0 开发板,请选择 AT32F403A 项目工程3)    连线方式       PB12 < ---- > PA4       PB13 < ---- > PA5       PB14 < ---- > PA74)    通信成功且数据无误,LED2会点亮。

chenjun89 发表于 2020-9-7 21:04

谢谢楼主。

勇者无惧你和我 发表于 2020-9-9 11:09

/**
* @brief配置嵌套向量中断控制器NVIC
* @param无
* @retval 无
*/
static void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;

/* 嵌套向量中断控制器组选择 */
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);

/* 配置USART为中断源 */
NVIC_InitStructure.NVIC_IRQChannel = DEBUG_USART_IRQ;
/* 抢断优先级*/
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;
/* 子优先级 */
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
/* 使能中断 */
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
/* 初始化配置NVIC */
NVIC_Init(&NVIC_InitStructure);
}

/**
* @briefUSART GPIO 配置,工作参数配置
* @param无
* @retval 无
*/
void USART_Config(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;

        // 打开串口GPIO的时钟
        DEBUG_USART_GPIO_APBxClkCmd(DEBUG_USART_GPIO_CLK, ENABLE);
       
        // 打开串口外设的时钟
        DEBUG_USART_APBxClkCmd(DEBUG_USART_CLK, ENABLE);

        // 将USART Tx的GPIO配置为推挽复用模式
        GPIO_InitStructure.GPIO_Pin = DEBUG_USART_TX_GPIO_PIN;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(DEBUG_USART_TX_GPIO_PORT, &GPIO_InitStructure);

// 将USART Rx的GPIO配置为浮空输入模式
        GPIO_InitStructure.GPIO_Pin = DEBUG_USART_RX_GPIO_PIN;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
        GPIO_Init(DEBUG_USART_RX_GPIO_PORT, &GPIO_InitStructure);
       
        // 配置串口的工作参数
        // 配置波特率
        USART_InitStructure.USART_BaudRate = DEBUG_USART_BAUDRATE;
        // 配置 针数据字长
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;
        // 配置停止位
        USART_InitStructure.USART_StopBits = USART_StopBits_1;
        // 配置校验位
        USART_InitStructure.USART_Parity = USART_Parity_No ;
        // 配置硬件流控制
        USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
        // 配置工作模式,收发一起
        USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
        // 完成串口的初始化配置
        USART_Init(DEBUG_USARTx, &USART_InitStructure);
       
        // 串口中断优先级配置
        NVIC_Configuration();
       
        // 使能串口接收中断
        USART_ITConfig(DEBUG_USARTx, USART_IT_RXNE, ENABLE);       
       
        // 使能串口
        USART_Cmd(DEBUG_USARTx, ENABLE);               

// 清除发送完成标志
        //USART_ClearFlag(USART1, USART_FLAG_TC);   
}

/*****************发送一个字符 **********************/
void Usart_SendByte( USART_TypeDef * pUSARTx, uint8_t ch)
{
        /* 发送一个字节数据到USART */
        USART_SendData(pUSARTx,ch);
               
        /* 等待发送数据寄存器为空 */
        while (USART_GetFlagStatus(pUSARTx, USART_FLAG_TXE) == RESET);       
}

/*****************发送字符串 **********************/
void Usart_SendString( USART_TypeDef * pUSARTx, char *str)
{
        unsigned int k=0;
do
{
      Usart_SendByte( pUSARTx, *(str + k) );
      k++;
} while(*(str + k)!='\0');

/* 等待发送完成 */
while(USART_GetFlagStatus(pUSARTx,USART_FLAG_TC)==RESET)
{}
}

真爱吴迪迪 发表于 2020-9-13 09:00

DMA确实是一个很好的选泽,现在好多东西都在用dma进行传输。
页: [1]
查看完整版本: SC0028_AT32F4xx_SPI使用DMA进行主机发送从机接收