N32G031固件库开发(二)UASRT----中断接收

通用同步异步收发器 ----USART

2.1

        通用同步异步收发器(USART)是一种全双工串行数据交换接口,支持同步或异步通信。可灵活配置,以便于与多种外部设备进行全双工数据交换。USART 接口发送与接收波特率可配置,也支持通过 DMA 进行连续通信。USART 还支持多处理器通信、LIN 模式、同步模式、单线半双工通信、智能卡异步协议、IrDA SIR ENDEC 功能、以及硬件流控制功能。

2.2 主要特性

 支持全双工通信
 支持单线半双工通信
 波特率可配置,最高波特率可达 3Mbit/s
 支持 8bit 或 9bit 数据帧
 支持 1bit 或 2bit 停止位
 支持硬件生成校验位及校验位检查 
 支持硬件流控: RTS、CTS
 支持 DMA 收发
 支持多处理器通信:如果地址不匹配,则进入静默模式, 可通过空闲总线检测或地址标识唤醒
 支持同步模式,允许用户在主模式下控制双向同步串行通信
 支持智能卡异步协议,符合 ISO7816-3 标准
 支持串行红外协议(IrDA SIR)编码与解码,提供正常与低功耗两种运行模式
 支持 LIN 模式
 支持多钟错误检测:数据溢出错误、帧错误、噪声错误、检验错误
 支持多个中断请求:发送数据寄存器为空、CTS 标志、发送完成、数据已接收、数据溢出、总线空闲、
检验错误、LIN 模式断开帧检测、以及多缓冲区通信中的噪声标志/溢出错误/帧错误

2.3 串口中断接收函数配置

void uart_init(unsigned long bound)
{
	USART_InitType USART_InitStructure;
    GPIO_InitType GPIO_InitStructure;
	RCC_ClocksType RCC_ClocksStatus;
	NVIC_InitType NVIC_InitStructure;
    
    /* System Clocks Configuration */
    /* Enable GPIO clock */
    GPIO_APBxClkCmd(USARTx_GPIO_CLK, ENABLE);
	
    /* Enable USART1 Clock */
    USART_APBxClkCmd(USARTx_CLK, ENABLE);

    /* Initialize GPIO_InitStructure */
    GPIO_InitStruct(&GPIO_InitStructure);    

    /* Configure USART1 Tx as alternate function push-pull */
    GPIO_InitStructure.Pin            = USARTx_TxPin;
    GPIO_InitStructure.GPIO_Mode      = GPIO_MODE_AF_PP;
    GPIO_InitStructure.GPIO_Alternate = USARTx_Tx_GPIO_AF;
    GPIO_InitPeripheral(USARTx_GPIO, &GPIO_InitStructure);   

    /* Configure USART1 Rx as alternate function push-pull */
    GPIO_InitStructure.Pin            = USARTx_RxPin;
    GPIO_InitStructure.GPIO_Alternate = USARTx_Rx_GPIO_AF;
    GPIO_InitPeripheral(USARTx_GPIO, &GPIO_InitStructure); 

    RCC_GetClocksFreqValue(&RCC_ClocksStatus);

    /* USART1 and USARTz configuration ------------------------------------*/
    USART_InitStructure.BaudRate            = bound;
    USART_InitStructure.WordLength          = USART_WL_8B;
    USART_InitStructure.StopBits            = USART_STPB_1;
    USART_InitStructure.Parity              = USART_PE_NO;
    USART_InitStructure.HardwareFlowControl = USART_HFCTRL_NONE;
    USART_InitStructure.Mode                = USART_MODE_RX | USART_MODE_TX;
		
    /* Enable the USART1 Interrupt */
    NVIC_InitStructure.NVIC_IRQChannel                   = USART1_IRQn;
    NVIC_InitStructure.NVIC_IRQChannelPriority           = 1;
    NVIC_InitStructure.NVIC_IRQChannelCmd                = ENABLE;
    NVIC_Init(&NVIC_InitStructure);
		
	/* Enable USARTz Receive and Transmit interrupts */
     USART_ConfigInt(USARTx, USART_INT_RXDNE, ENABLE);
    // USART_ConfigInt(USARTx, USART_INT_TXDE, ENABLE);
		

    /* Configure USARTx */
    USART_Init(USARTx, &USART_InitStructure);
    /* Enable the USARTx */
    USART_Enable(USARTx, ENABLE);
}
#ifndef __USART_H
#define __USART_H
#include "n32g031.h"
#include <stdarg.h>
#include "stdio.h"

#define _USART1_COM_

#ifdef _USART1_COM_
#define USARTx              USART1
#define USARTx_CLK          RCC_APB2_PERIPH_USART1
#define USARTx_GPIO         GPIOA
#define USARTx_GPIO_CLK     RCC_APB2_PERIPH_GPIOA
#define USARTx_RxPin        GPIO_PIN_10
#define USARTx_TxPin        GPIO_PIN_9
#define USARTx_Rx_GPIO_AF   GPIO_AF4_USART1
#define USARTx_Tx_GPIO_AF   GPIO_AF4_USART1
#define GPIO_APBxClkCmd     RCC_EnableAPB2PeriphClk
#define USART_APBxClkCmd    RCC_EnableAPB2PeriphClk

void uart_init(unsigned long bound);
void USART1_IRQHandler(void);
#endif

#endif
void USART1_IRQHandler(void)
{
	 static u8 res;
	 if (USART_GetIntStatus(USARTx, USART_INT_RXDNE) != RESET)
    {
		res =USART_ReceiveData(USARTx);		
		printf("fengji:%d \r\n",res);

    }
}

程序编译下载后用串口助手打印出来效果如下

 

### 固件库开发环境搭建 在Keil开发环境中使用N32G031微控制器的固件库进行开发,首先需要获取并配置适用于该微控制器的固件库。通常,厂商会提供完整的固件库和示例工程,开发者可以直接基于这些模板进行开发。例如,类似AT32A423微控制器的模板工程结构,N32G0322G031固件库也可能包含针对不同IDE(如Keil_v5)的模板工程,开发者可以从官方固件库的`project`目录中找到对应的工程模板[^1]。 ### 固件库的结构与使用 N32G031固件库通常包含以下内容: - **启动文件**:用于初始化微控制器的堆栈、中断向量表以及调用`SystemInit`和`main`函数。 - **系统初始化文件**:提供系统时钟配置、外设初始化等基础功能。 - **外设驱动文件**:为GPIO、USART、SPI、I2C、ADC等外设提供封装好的函数接口。 - **示例工程**:提供基于Keil、IAR等IDE的完整示例,开发者可以直接打开并运行这些工程作为开发起点。 例如,以下是一个基于固件库的GPIO初始化代码片段: ```c #include "n32g031.h" void LED_Init(void) { // 使能GPIOA时钟 RCC->AHBENR |= RCC_AHBENR_GPIOAEN; // 配置PA5为推挽输出模式 GPIOA->MODER &= ~(GPIO_MODER_MODER5); GPIOA->MODER |= GPIO_MODER_MODER5_0; GPIOA->OTYPER &= ~GPIO_OTYPER_OT_5; GPIOA->OSPEEDR &= ~GPIO_OSPEEDER_OSPEEDR5; GPIOA->PUPDR &= ~GPIO_PUPDR_PUPDR5; } int main(void) { LED_Init(); while (1) { // 点亮LED GPIOA->ODR |= GPIO_ODR_ODR5; for (volatile int i = 0; i < 100000; i++); // 延迟 // 关闭LED GPIOA->ODR &= ~GPIO_ODR_ODR5; for (volatile int i = 0; i < 100000; i++); } } ``` ### 工程配置与调试 在Keil中打开N32G031固件库提供的模板工程时,应确保工程已正确配置目标设备型号、编译器选项和链接脚本。Keil的工程配置界面允许开发者选择目标芯片、设置编译优化级别、配置调试接口(如SWD)以及指定启动文件路径。例如,Keil_v5的工程文件通常以`.uvprojx`为扩展名,可以直接双击打开并进行编译和调试。 调试过程中,开发者可以使用Keil的调试功能查看寄存器状态、内存内容以及外设配置情况,确保固件库中的驱动函数正常运行。此外,Keil支持断点设置和单步执行,有助于快速定位和修复代码中的逻辑错误或外设配置问题。 ###
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

疯狂造机人~~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值