当前位置:首页 > 单片机 > 单片机
[导读]TM32笔记之八:来跟PC打个招呼,基本串口通讯a) 目的:在基础实验成功的基础上,对串口的调试方法进行实践。硬件代码顺利完成之后,对日后调试需要用到的printf重定义进行调试,固定在自己的库函数中。b) 初始化函数

TM32笔记之八:来跟PC打个招呼,基本串口通讯


a) 目的:在基础实验成功的基础上,对串口的调试方法进行实践。硬件代码顺利完成之后,对日后调试需要用到的printf重定义进行调试,固定在自己的库函数中。


b) 初始化函数定义:


void USART_Configuration(void); //定义串口初始化函数


c) 初始化函数调用:


void UART_Configuration(void); //串口初始化函数调用


初始化代码:


void USART_Configuration(void) //串口初始化函数


{


//串口参数初始化


USART_InitTypeDef USART_InitStructure; //串口设置恢复默认参数


//初始化参数设置


USART_InitStructure.USART_BaudRate = 9600; //波特率9600


USART_InitStructure.USART_WordLength = USART_WordLength_8b; //字长8位


USART_InitStructure.USART_StopBits = USART_StopBits_1; //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;//打开Rx接收和Tx发送功能


USART_Init(USART1, &USART_InitStructure); //初始化


USART_Cmd(USART1, ENABLE); //启动串口


}


RCC中打开相应串口


RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 , ENABLE);


GPIO里面设定相应串口管脚模式


//串口1的管脚初始化


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //管脚9


GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出


GPIO_Init(GPIOA, &GPIO_InitStructure); //TX初始化


GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //管脚10


GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入


GPIO_Init(GPIOA, &GPIO_InitStructure); //RX初始化


d) 简单应用:


发送一位字符


USART_SendData(USART1, 数据); //发送一位数据


while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET){} //等待发送完毕


接收一位字符


while(USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET){} //等待接收完毕


变量= (USART_ReceiveData(USART1)); //接受一个字节


发送一个字符串


先定义字符串:char rx_data[250];


然后在需要发送的地方添加如下代码


int i; //定义循环变量


while(rx_data!='') //循环逐字输出,到结束字''


{USART_SendData(USART1, rx_data); //发送字符


while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET){} //等待字符发送完毕


i++;}


e) USART注意事项:


发动和接受都需要配合标志等待。


只能对一个字节操作,对字符串等大量数据操作需要写函数


使用串口所需设置:RCC初始化里面打开RCC_APB2PeriphClockCmd


(RCC_APB2Periph_USARTx);GPIO里面管脚设定:串口RX(50Hz,IN_FLOATING);串口TX(50Hz,AF_PP);


f) printf函数重定义(不必理解,调试通过以备后用)


(1) 需要c标准函数:


#i nclude "stdio.h"


(2) 粘贴函数定义代码


#define PUTCHAR_PROTOTYPE int __io_putchar(int ch) //定义为putchar应用


(3) RCC中打开相应串口


(4) GPIO里面设定相应串口管脚模式


(6) 增加为putchar函数。


int putchar(int c) //putchar函数


{


if (c == 'n'){putchar('r');} //将printf的n变成r


USART_SendData(USART1, c); //发送字符


while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET){} //等待发送结束


return c; //返回值


}


(8) 通过,试验成功。printf使用变量输出:%c字符,%d整数,%f浮点数,%s字符串,/n或/r为换行。注意:只能用于main.c中。


3、 NVIC串口中断的应用


a) 目的:利用前面调通的硬件基础,和几个函数的代码,进行串口的中断输入练习。因为在实际应用中,不使用中断进行的输入是效率非常低的,这种用法很少见,大部分串口的输入都离不开中断。


b) 初始化函数定义及函数调用:不用添加和调用初始化函数,在指定调试地址的时候已经调用过,在那个NVIC_Configuration里面添加相应开中断代码就行了。


c) 过程:


i. 在串口初始化中USART_Cmd之前加入中断设置:


USART_ITConfig(USART1, USART_IT_TXE, ENABLE);//TXE发送中断,TC传输完成中断,RXNE接收中断,PE奇偶错误中断,可以是多个。


ii. RCC、GPIO里面打开串口相应的基本时钟、管脚设置


iii. NVIC里面加入串口中断打开代码:


NVIC_InitTypeDef NVIC_InitStructure;//中断默认参数


NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQChannel;//通道设置为串口1中断


NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; //中断占先等级0


NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; //中断响应优先级0


NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //打开中断


NVIC_Init(&NVIC_InitStructure); //初始化


iv. 在stm32f10x_it.c文件中找到void USART1_IRQHandler函数,在其中添入执行代码。一般最少三个步骤:先使用if语句判断是发生那个中断,然后清除中断标志位,最后给字符串赋值,或做其他事情。


void USART1_IRQHandler(void) //串口1中断


{


char RX_dat; //定义字符变量


if (USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //判断发生接收中断


{USART_ClearITPendingBit(USART1, USART_IT_RXNE); //清除中断标志


GPIO_WriteBit(GPIOB, GPIO_Pin_10, (BitAction)0x01); //开始传输


RX_dat=USART_ReceiveData(USART1) & 0x7F; //接收数据,整理除去前两位


USART_SendData(USART1, RX_dat); //发送数据


while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET){}//等待发送结束


}


}


d) 中断注意事项:


可以随时在程序中使用USART_ITConfig(USART1, USART_IT_TXE, DISABLE);来关闭中断响应。


NVIC_InitTypeDef NVIC_InitStructure定义一定要加在NVIC初始化模块的第一句。


全局变量与函数的定义:在任意.c文件中定义的变量或函数,在其它.c文件中使用extern+定义代码再次定义就可以直接调用了。


STM32笔记之九:打断它来为我办事,EXIT (外部I/O中断)应用


a) 目的:跟串口输入类似,不使用中断进行的IO输入效率也很低,而且可以通过EXTI插入按钮事件,本节联系EXTI中断。


b) 初始化函数定义:


void EXTI_Configuration(void); //定义IO中断初始化函数


c) 初始化函数调用:


EXTI_Configuration();//IO中断初始化函数调用简单应用:


d) 初始化函数:


void EXTI_Configuration(void)


{ EXTI_InitTypeDef EXTI_InitStructure; //EXTI初始化结构定义


EXTI_ClearITPendingBit(EXTI_LINE_KEY_BUTTON);//清除中断标志


GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource3);//管脚选择


GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource4);


GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource5);


GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource6);


EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;//事件选择


EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;//触发模式


EX

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭