STM32之USART配置

发布者:psi33最新更新时间:2016-12-23 来源: eefocus关键字:STM32  USART配置 手机看文章 扫描二维码
随时随地手机看文章

//USART

void UART2_Configuration(void)
{
    GPIO_InitTypeDef GPIO_InitStructure;
    USART_InitTypeDef USART_InitStructure;
    USART_ClockInitTypeDef USART_ClockInitStructure; 

    RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);

    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
    GPIO_Init(GPIOA, &GPIO_InitStructure);
    
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
    GPIO_Init(GPIOA, &GPIO_InitStructure);




 
    USART_InitStructure.USART_BaudRate = 9600;
    USART_InitStructure.USART_WordLength = USART_WordLength_8b;
                                         //USART_WordLength_8b; //8 位数据
                                         //USART_WordLength_9b; //9 位数据
    USART_InitStructure.USART_StopBits = USART_StopBits_1;
                                       //USART_StopBits_1  ;//在帧结尾传输 1 个停止位
                                       //USART_StopBits_0.5;//在帧结尾传输 0.5 个停止位
                                       //USART_StopBits_2  ;//在帧结尾传输 2 个停止位
                                       //USART_StopBits_1.5;//在帧结尾传输 1.5 个停止位
    USART_InitStructure.USART_Parity = USART_Parity_No;
                                     //USART_Parity_No  ;//奇偶失能
                                     //USART_Parity_Even;//偶模式
                                     //USART_Parity_Odd ;//奇模式
    USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
                                                  //USART_HardwareFlowControl_None;   //硬件流控制失能
                                                  //USART_HardwareFlowControl_RTS;    //发送请求 RTS使能
                                                  //USART_HardwareFlowControl_CTS;    //清除发送 CTS使能

                                                  //USART_HardwareFlowControl_RTS_CTS;//RTS和 CTS使能

                                                  //TIM1_OCIdleState是检测定时器是否空闲,USART_HardwareFlowControl是硬件数据流控制,这个一般是设为无


    USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
                                   //USART_Mode_Tx;//发送使能
                                   //USART_Mode_Rx;//接收使能
    USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;
                                         //USART_Clock_Enable ;//时钟高电平活动
                                         //USART_Clock_Disable;//时钟低电平活动
    USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;
                                        //USART_CPOL_High;//时钟高电平
                                        //USART_CPOL_Low ;//时钟低电平
    USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;
                                        //USART_CPHA_1Edge;//时钟第一个边沿进行数据捕获
                                        //USART_CPHA_2Edge;//时钟第二个边沿进行数据捕获
    USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;
                                           //USART_LastBit_Disable;//最后一位数据的时钟脉冲不从 SCLK输出 
                                           //USART_LastBit_Enable ;//最后一位数据的时钟脉冲从 SCLK输出
    USART_Init(USART2, &USART_InitStructure);//初始化外设 USARTx 寄存器
    USART_Cmd(USART2, ENABLE);
                    //ENABLE-DISABLE//使能或者失能 USART 外设
    USART_ITConfig(USART2,USART_IT_RXNE,ENABLE);//ENABLE-DISABLE//使能或者失能指定的 USART 中断
                        //USART_IT_PE  //奇偶错误中断
                        //USART_IT_TXE //发送中断
                        //USART_IT_TC  //传输完成中断
                        //USART_IT_RXNE//接收中断
                        //USART_IT_IDLE//空闲总线中断
                        //USART_IT_LBD //LIN中断检测中断
                        //USART_IT_CTS //CTS中断
                        //USART_IT_ERR //错误中断
              


    USART_ClockInit(USART2, &USART_ClockInitStructure);

}


void USART3_Putc(unsigned char c)//串口3发送一个字符
{
    USART_SendData(USART3, c);
    while(USART_GetFlagStatus(USART3, USART_FLAG_TXE) == RESET );
}


void USART3_Puts(unsigned char * str)//串口3发送一个字
{
    while(*str)
    {
        USART_SendData(USART3, *str++);
/* 循环,直到传输结束*/
while(USART_GetFlagStatus(USART3, USART_FLAG_TXE) == RESET);
    }
}


//用于查询接收
void USART1_IRQHandler(void)
{
    u8 c;
    if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
    { 
        c=USART1->DR;    
    } 
 
}




















/**********************调试成功例程**************************/


//==================串口1 NVIC初始化==============
void NVIC_Configuration(void)
{
 NVIC_InitTypeDef NVIC_InitStructure;


#ifdef  VECT_TAB_RAM  
  /* Set the Vector Table base location at 0x20000000 */ 
  NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0); 
#else  /* VECT_TAB_FLASH  */
  /* Set the Vector Table base location at 0x08000000 */ 
  NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);   
#endif


   //NVIC_ClearIRQChannelPendingBit(USART1_IRQChannel);


   //设置NVIC优先级分组为Group2:0-3抢占式优先级,0-3的响应式优先级
    NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);


 /* enabling interrupt */ 
  NVIC_InitStructure.NVIC_IRQChannel=USART1_IRQChannel; 
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; 
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; 
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; 
  NVIC_Init(&NVIC_InitStructure); 
}


//==================串口1 RCC初始化==============
void RCC_Configuration(void)
{   
  /* RCC system reset(for debug purpose) */
  RCC_DeInit();


  /* Enable HSE */
  RCC_HSEConfig(RCC_HSE_ON);


  /* Wait till HSE is ready */
  HSEStartUpStatus = RCC_WaitForHSEStartUp();


  if(HSEStartUpStatus == SUCCESS)
  {
    /* Enable Prefetch Buffer */
    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);


    /* Flash 2 wait state */
    FLASH_SetLatency(FLASH_Latency_2);
 
    /* HCLK = SYSCLK */
    RCC_HCLKConfig(RCC_SYSCLK_Div1); 
  
    /* PCLK2 = HCLK */
    RCC_PCLK2Config(RCC_HCLK_Div1); 


    /* PCLK1 = HCLK/2 */
    RCC_PCLK1Config(RCC_HCLK_Div2);


    /* PLLCLK = 8MHz * 9 = 72 MHz */
    RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);


    /* Enable PLL */ 
    RCC_PLLCmd(ENABLE);


    /* Wait till PLL is ready */
    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
    {
    }


    /* Select PLL as system clock source */
    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);


    /* Wait till PLL is used as system clock source */
    while(RCC_GetSYSCLKSource() != 0x08)
    {
    }
  }
  RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
//  RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);
}


//==================串口1初始化GPIO_USART==============
void USART1_Configuration(void)
{
USART_InitTypeDef USART_InitStructure;
GPIO_InitTypeDef GPIO_InitStructure;
 
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; 
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; 
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; 
GPIO_Init(GPIOA, &GPIO_InitStructure); 
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10; 
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; 
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);  
USART_StructInit(&USART_InitStructure);
USART_InitStructure.USART_BaudRate = 9600;
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(USART1,&USART_InitStructure);
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
//USART_ITConfig(USART1, USART_IT_TXE, ENABLE);
/* Enable the USART1 */
USART_Cmd(USART1,ENABLE);
}


//==================串口1中断处理函数==============
void USART1_IRQHandler(void)
{
u16 usarnum;
     
  if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)
  {
     /* Disable USART3 RXNE Interrupt */
     USART_ITConfig(USART1, USART_IT_RXNE, DISABLE);
     usarnum=USART_ReceiveData(USART1);
     USART_SendData(USART2, usarnum);
     while (USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET); 
     USART_ITConfig( USART1,USART_IT_RXNE, ENABLE);
  }
}


//==================串口2中断处理函数==============
void USART2_IRQHandler(void)
{
}


//==================串口3中断处理函数==============
void USART3_IRQHandler(void)
{
}


//==================串口发送处理函数==============
void USART1_Putc(unsigned char c)
{
while(USART_GetFlagStatus(USART1, USART_FLAG_TC)==RESET);
USART_SendData(USART1, c);
while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET );
}


//==================串口发送底层函数==============
void USART_SendData(USART_TypeDef* USARTx, u16 Data)//
{
  /* Check the parameters */
  assert_param(IS_USART_ALL_PERIPH(USARTx));
  assert_param(IS_USART_DATA(Data)); 
    
  /* Transmit Data */
  USARTx->DR = (Data & (u16)0x01FF);
}


//==================串口main==============
int main(void)
{
RCC_Configuration(); //初始化时钟  
NVIC_Configuration();//初始化中断
USART_Configuration();//初始化串口
while (1) ;


关键字:STM32  USART配置 引用地址:STM32之USART配置

上一篇:关于stm32 的 USB 转串口 virtual_Com_Port的例程的一些问题
下一篇:stm32库函数GPIO_Init()解析

推荐阅读最新更新时间:2024-03-16 15:26

STM32读取MPU6050模块的原始数据
在很多应用领域,加速度传感器和陀螺仪传感器都必不可少,MPU6050既简单又经济小巧,很适合做一些要求不高的开发。 1、MPU6050是6轴运动处理组件,包括3轴加速度和3轴陀螺仪 2、MPU6050为IIC接口,简单方便 3、加速度传感器即力传感器,检测上下左右前后都收到多少力的作用,然后计算角度 4、陀螺仪即角速度传感器,若以X为轴心,在1秒的时间里转动的90度,那么X轴上的角速度就是90度/秒 5、3个加速度传感器和3个陀螺仪传感器每轴一个16位ADC,输出数据为2^16,即-32768~+32768 MPU6050为寄存器控制,读取其中寄存器数据即可,若要了解具体寄存器请参看数据手册
[单片机]
学习STM32之SD卡总结
由于自己也在使用SD卡,使用的过程中也遇到了一些问题,下面是在EDN论坛上zxb1717高手的经验,希望可以帮助大家 调试关键点: 1. 上电时要延时足够长的时间给SD卡一个准备过程,在我的程序里是5秒,根据不同的卡设置不同的延时时间。SD卡初始化第一步在发送CMD命令之前,在片选有效的情况下首先要发送至少74个时钟,否则将有可能出现SD卡不能初始化的问题。 2. SD卡发送复位命令CMD0后,要发送版本查询命令CMD8,返回状态一般分两种,若返回0x01表示此SD卡接受CMD8,也就是说此SD卡支持版本2;若返回0x05则表示此SD卡支持版本1。因为不同版本的SD卡操作要求有不一样的地方,所以务必查询SD卡的版本号,否则也
[单片机]
STM32的AFIO时钟何时开启
首先为什么要开启时钟? 答:因为要对寄存器进行读写!而在STM32中对寄存器的读写都是要打开寄存器对应的时钟才可以的【就像人一样,有了跳动的脉搏手臂才能有能量才能进行各种动作】。 然后就什么时候AFIO时钟开启(所有时钟都是这样)就清楚了:当需要对“AFIO时钟管理的寄存器”进行读写时AFIO时钟打开!当然不对“AFIO时钟管理的寄存器”读写时也可以打开AFIO时钟,此时只是白白增加能耗、写无用代码(白白浪费程序存储器空间)而已! 接下来:跟AFIO相关的寄存器有哪些呢? 答:根据《STM32中文参考手册_V10》有:①事件控制寄存器(AFIO_EVCR)、②复用重映射和调试I/O 配置寄存器(AFIO_MAPR)、③外部中断
[单片机]
stm32 定时器响应时间计算
以TIM3_Int_Init(u16 arr,u16 psc)为例:(st的标准库) arr:自动重装载值 psc:时钟预分频系数 arr 有四种计数方式:加1、减1,加减、减加。(可单次可多次) 要计算时间必须知道单片机的时钟源频率 F(由时钟频率的方波来计数) 定时器响应时间(T)计算:T= / F (us)
[单片机]
<font color='red'>stm32</font> 定时器响应时间计算
STM32:GPIO基础与对应管脚操作库函数
USE_STDPERIPH_DRIVER, STM32F10X_HD STM32固件库Libraries\CMSIS\Core\CM3\startup\arm中启动文件的文件名英文缩写意义: cl:互联型产品, stm32f105/107 系列 vl:超值型产品, stm32f100 系列 xl:超高密度(容量) 产品, stm32f101/103 系列 ld:低密度产品, FLASH 小于 64K md:中等密度产品, FLASH=64 or 128 hd:高密度产品, FLASH 大于 128 GPIO_TypeDef * GPIOx; //定义一个 GPIO_TypeDef 型结构体指针 GPIOx GPIOx = G
[单片机]
STM32读取温湿度传感器DHT11和DHT21(AM2301)系列问题
1、DHT11和DHT21传感器 这两种传感器都是奥松公司的产品,具体的传感器说明书在其官网上有(www.aosong.com)。 DHT11 数字温湿度传感器是一款含有已校准数字信号输出的温湿度复合传感器。它应用专用的数 字模块采集技术和温湿度传感技术,确保产品具有枀高的可靠性与卓越的长期稳定性。传感器包括一 个电容式感湿元件和一个 NTC 测温元件,并与一个高性能 8 位单片机相连接。 DHT21(AM2301)湿敏电容数字温湿度模块是一款含有己校准数字信号输出的温湿度复合传感器。它应用专用的数字模块采集技术和温湿度传感技术,确保产品具有极高的可靠性与卓越的长期稳定性。传感器包括一个电容式感湿元件和一个
[单片机]
<font color='red'>STM32</font>读取温湿度传感器DHT11和DHT21(AM2301)系列问题
STM32通信接口(二)IIC--软件模拟
一、概述 IIC 即Inter-Integrated Circuit(集成电路总线),这种总线类型是由飞利浦半导体公司在八十年代初设计出来的一种简单、双向、二线制、同步串行总线,主要是用来连接整体电路(ICS) ,IIC是一种多向控制总线,也就是说多个芯片可以连接到同一总线结构下,同时每个芯片都可以作为实时数据传输的控制源。 IIC是 由数据线SDA和时钟SCL构成的串行总线,可发送和接收数据。在CPU与被控IC之间、IC与IC之间进行双向传送,高速IIC总线一般可达400kbps以上。 二、基本原理 (IIC总线的时序图) IIC总线在传输数据的过程中共有三种类型的信号,分别为:开始信号、结束信
[单片机]
<font color='red'>STM32</font>通信接口(二)IIC--软件模拟
基于STM32的便携式人机界面系统
摘要:设计应用于全站仪测量计算的基于STM32处理器的便携式人机界面系统。采用了处理器IO口模拟总线时序和外挂SPI接口Flash存储字库的方法,将字库存储在外部的SPI接口Flash中,在使用时再从字库中查询调出,有效地减少了内部存储器的消耗。完成了基于ARM最新Cortex—M3处理器汉字显示系统的硬件电路设计和软件程序设计。实现了可以自定义汉字字库的人机界面系统。 关键词:全站仪;ARM微控制器;STM32;TFT液晶;人机界面 在全站仪应用于飞机的测量过程中,常会涉及到计算,以满足不同的应用环境与测量要求,以往的方式是测量后期编辑软件在计算机上实现,现代测量迫切需要一种便携式手持计算系统,来完成实时的测量要求,而这一系
[工业控制]
基于<font color='red'>STM32</font>的便携式人机界面系统
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved