当前位置:首页 > 单片机 > 单片机
[导读]功能:PC端发送一个特定的字符:0x0d0x0a,单片机则返回一句话,如图:>_1、复用功能I/O和调试配置(AFIO)为了优化外设数目,可以把一些复用功能重新映射到其他引脚上。设置复用重映射和调试I/O配置寄存器(AFIO_MAPR)

功能:PC端发送一个特定的字符:0x0d0x0a,单片机则返回一句话,如图:

>_

1、复用功能I/O和调试配置(AFIO)

为了优化外设数目,可以把一些复用功能重新映射到其他引脚上。设置复用重映射和调试I/O配置寄存器(AFIO_MAPR)(参见0节)实现引脚的重新映射。这时,复用功能不再映射到它们的原始分配上。

2、嵌套向量中断控制器(NVIC)

l43个可屏蔽中断通道(不包含16个Cortex-M3的中断线);

l16个可编程的优先等级;

l低延迟的异常和中断处理;

l电源管理控制;

l系统控制寄存器的实现;

l嵌套向量中断控制器(NVIC)和处理器核的接口紧密相连,可以实现低延迟的中断处理和有效处理地处理晚到的中断。

PS:

  a、SysTick:系统嘀嗒校准值固定到9000,当系统嘀嗒时钟设定为9兆赫,产生1ms时基。

  b、中断和异常向量:【中断向量表】

3、USART通用同步异步收发器(USART)

它支持同步单向通信和半双工单线通信

任何USART双向通信至少需要两个脚:接收数据输入(RX)和发送数据输出(TX)。

a、RX:接收数据串行输。通过过采样技术来区别数据和噪音,从而恢复数据。

b、TX:发送数据输出。当发送器被禁止时,输出引脚恢复到它的I/O端口配置。当发送器被激活,并且没东西发送时,TX引脚处于高电平。

>_

a、USART设置,这个要看固件库!首先用结构体把参数配置好,然后调用初始化函数;接着使能接收中断和发送缓冲中断;最后使能USART1。

1 void USART_Config(USART_TypeDef* USARTx){

2 USART_InitStructure.USART_BaudRate = 19200; //速率19200bps

3 USART_InitStructure.USART_WordLength = USART_WordLength_8b; //数据位8位

4 USART_InitStructure.USART_StopBits = USART_StopBits_1; //停止位1位

5 USART_InitStructure.USART_Parity = USART_Parity_No; //无校验位

6 USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; //无硬件流控

7 USART_InitStructure.USART_Mode = USART_Mode_Rx " USART_Mode_Tx; //收发模式

8 /* Configure USART1 */

9 USART_Init(USARTx, &USART_InitStructure); //配置串口参数函数

10 /* Enable USART1 Receive and Transmit interrupts */

11 USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); //使能接收中断

12 USART_ITConfig(USART1, USART_IT_TXE, ENABLE); //使能发送缓冲空中断

13 /* Enable the USART1 */

14 USART_Cmd(USART1, ENABLE);

15 }


b、配置系统时钟72MHz+外设时钟使能。注意这里有复用,所以要使能复用时钟。


1 void RCC_Configuration(void){

2 SystemInit();

3 RCC_APB2PeriphClockCmd( RCC_APB2Periph_USART1 |RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB |RCC_APB2Periph_AFIO , ENABLE);

4 }

c、 LED的GPIO口配置和复用的A9,A10用于数据收发



1 void GPIO_Configuration(void){

2 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5; //LED1控制--PB5

3 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽输出

4 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;

5 GPIO_Init(GPIOB, &GPIO_InitStructure);

6

7 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //USART1 TX

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

9 GPIO_Init(GPIOA, &GPIO_InitStructure); //A端口

10

11 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; //USART1 RX

12 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //复用开漏输入

13 GPIO_Init(GPIOA, &GPIO_InitStructure); //A端口

14 }


d、中断向量初始化,看固件库!



1 void NVIC_Configuration(void){

2 /* 结构声明*/

3 NVIC_InitTypeDef NVIC_InitStructure;

4

5 /* Configure the NVIC Preemption Priority Bits */

6 /* Configure one bit for preemption priority */

7 /* 优先级组 说明了抢占优先级所用的位数,和子优先级所用的位数 在这里是1, 7 */

8 NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);

9 NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; //设置串口1中断

10 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; //抢占优先级 0

11 NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; //子优先级为0

12 NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //使能

13 NVIC_Init(&NVIC_InitStructure);

14 }


e、Main函数:rec_f为有效帧标志位


1 int main(void){

2 uint8_t a=0;//LED高低电压控制

3 RCC_Configuration(); //系统时钟设置

4 NVIC_Configuration(); //中断源配置

5 GPIO_Configuration(); //端口初始化

6 USART_Config(USART1); //串口1初始化

7

8 while (1){

9 if(rec_f==1){ //判断是否收到一帧有效数据

10 rec_f=0;

11 for(i=0;i

12 {

13 USART_SendChar(USART1,TxBuffer1[i]);

14 Delay(0x0000ff00);

15 }

16 if(a==0){GPIO_SetBits(GPIOB, GPIO_Pin_5);a=1;} //LED1 明暗闪烁

17 else{GPIO_ResetBits(GPIOB, GPIO_Pin_5);a=0;}

18 }

19 }

20 }


这里发送函数封装为:


1 void USART_SendChar(USART_TypeDef* USARTx,uint8_t data){

2 USART_SendData(USARTx,data);

3 while(USART_GetFlagStatus(USARTx,USART_FLAG_TC)==RESET);

4 }

接收函数在中断函数中,当上位机发送数据给单片机时,单片机将进入该中断服务程序,进行数据接收,这里上位机发送的数据必须以0x0d和0x0a结尾,如果不是以这两个结尾说明不是有效帧,则不处理:



1 void USART1_IRQHandler(void) //串口1 中断服务程序

2 {

3 unsigned int i;

4 if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) //判断读寄存器是否非空

5 {

6 RxBuffer1[RxCounter1++] = USART_ReceiveData(USART1); //将读寄存器的数据缓存到接收缓冲区里

7 if(RxBuffer1[RxCounter1-2]==0x0d&&RxBuffer1[RxCounter1-1]==0x0a)//判断结束标志是否是0x0d 0x0a

8 {

9 for(i=0; i< RxCounter1; i++) TxBuffer1[i] = RxBuffer1[i]; //将接收缓冲器的数据转到发送缓冲区,准备转发

10 rec_f=1; //接收成功标志

11 TxBuffer1[RxCounter1]=0; //发送缓冲区结束符

12 TxCounter1=RxCounter1;

13 RxCounter1=0;

14 }

15 }

16 if(USART_GetITStatus(USART1, USART_IT_TXE) != RESET) //这段是为了避免STM32 USART 第一个字节发不出去的BUG

17 {

18 USART_ITConfig(USART1, USART_IT_TXE, DISABLE); //禁止发缓冲器空中断,

19 }

20 }


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

  UART   UART是一种通用串行数据总线,用于异步通信。该总线双向通信,可以实现全双工传输和接收。在嵌入式设计中,UART用于主机与辅助设备通信,如汽车音响与外接AP之间的通信,

关键字: uart usart

void InitUart(void) { GPIO_InitTypeDef GPIO_InitStructure; #if 1// (USART_USED == USART1) RCC_AHBPeriph...

关键字: stm32f30x usart 串口 初始化顺序

五、ATMEGA16的USART与PC机串行通信五—(02)、PC机发送字符给单片机,然后用液晶显示发送的字符~~~这章节也是相对挺简单的~~直接上图片吧~~基本上就这么点吧~~然后就是程序了,这里我只是粘贴一下重要的程...

关键字: atmega16 avr单片机 usart 串行通信

终于,我忍不住想吐槽一下翻译STM 32函数库手册的同学了,中间省略了好多东西而且是很重要的东西。。。。。。我的内心几乎是奔溃的!!!现在就来仔细说说关于STM 32 函数库3.5 中关于USART串口通信的坑:在一些教...

关键字: STM32 usart

五、ATMEGA16的USART与PC机串行通信五—(03)、PC机发送控制指令控制单片机工作~(这个控制还是比较简单的~~,不过个人认为还是有水平的~)还是先上图片~~,然后程序,程序师模块化的,我尽量贴全点~~然后就...

关键字: atmega16 avr单片机 usart 串行通信

一、简单demo通过232串口,与上位机进行通信。首先保证单片机232串口与电脑的串口接口相连,当然电脑是USB接口,其实USB接口的实质也是串口。我们实现上位机发送一个16进制的数据,单片机接受到数据后显示,并且2倍发

关键字: STM32 usart 串口通信

#include "stm32f10x_lib.h"#include"stdio.h"#define USART1_DR_Base0x40013804#define SENDBUF...

关键字: STM32 usart

Xmega128的串口非常强大,最多能支持8个串口。串口又有四种模式:1、异步2、同步3、IRDA红外模式4、SPI主模式今天我们就使用CVAVR代码向导生成简单串口测试程序,实现每1s打印“HELLO WORLD”字符...

关键字: usart xmega128 串口

//------------------------------------------------------------------------------//ATMEGA16与PC机的通信实验1//PC机发送一个字...

关键字: atmega16 avr单片机 usart 串行通信

前言串口对于处理器来说算是一种标配,也是在软件开发中必不可少的,那就是使用串口来调试信息(打印出相应的信息)。STM32F0系列的芯片,串口根据型号不同,数量也不同,从1个到8个不等。今天主要总结串口简单且常用

关键字: stm32f0xx usart 收发配置
关闭
关闭