datasheet

STM32初学笔记4之USART

2016-10-10来源: eefocus关键字:STM32  USART
=========================== 文件分割线 ===============================

/**
 ** 文件名称:BSP_ALIENTEK.H
 ** 功能描述:ALIENTEK开发板板级支持包声明
 ** 硬件平台:STM32F103RBT6 Development Board
 ** 编译环境:Keil uversion4 IDE
 ** 版本信息:v0.2
 ** 编写作者:唐华明
 ** 编写时间:2011.11.26
 ** 附加说明:无
 ** 修改记录:2011-11-26  将DS0Off() GPIO_SetBits(GPIOD, GPIO_Pin_8)修改为
 **                       DS0Off() GPIO_SetBits(GPIOA, GPIO_Pin_8)
 **           2011-11-27  增加串口1配置函数和输入输出函数声明。
 **/
#ifndef _BSP_ALIENTEK_H
#define _BSP_ALIENTEK_H
#include
/*
*****************************************************************************
模块名称:LED模块      
模块组成:DS0       DS1 
对应引脚:GPIOA8   GPIOD2 
*****************************************************************************
*/
#define DS0On()  GPIO_ResetBits(GPIOA, GPIO_Pin_8) //Turn on DS0
#define DS1On()  GPIO_ResetBits(GPIOD, GPIO_Pin_2) //Turn on DS1
#define DS0Off() GPIO_SetBits(GPIOA, GPIO_Pin_8)    //Turn off DS0
#define DS1Off() GPIO_SetBits(GPIOD, GPIO_Pin_2)    //Turn off DS1
#define DS0Sft() GPIOA->ODR ^= 0x0100;              //Shift DS0 status  0001 0000 0000
#define DS1Sft() GPIOD->ODR ^= 0x0004;              //Shift DS1 status  0000 0000 0100

/*用户函数声明*/
void BSP_Init(void);
void GPIO_Configuration(void);
void RCC_Configuration(void);
void NVIC_Configuration(void);
void InitLCD(void);
void USART1_Configuration(uint32_t baudrate);
int fputc(int ch, FILE *F);  //fputc函数重定向
int fgetc(FILE *f);       //fgetc函数重定向
#endif

=========================== 文件分割线 ===============================

/**
 ** 文件名称:BSP_ALIENTEK.C
 ** 功能描述:ALIENTEK开发板板级支持包函数定义
 ** 硬件平台:STM32F103RBT6 Development Board
 ** 编译环境:Keil uversion4 IDE
 ** 版本信息:v0.2
 ** 编写作者:唐华明
 ** 编写时间:2011.11.26
 ** 附加说明:无
 ** 修改记录:2011-11-27 增加按键外部中断配置语句
 **           2011-11-27 增加串口配置,其使用需要单独调用一个串口配置函数。
 **/
#include "stm32f10x.h"
#include "bsp_alientek.h"
/**
 ** 函数名称:void BSP_Init(void)
 ** 功能描述:板级支持包的初始化
 ** 输入参数:无
 ** 返回值  :无
 ** 版本信息:v0.0
 ** 编写作者:唐华明
 ** 编写时间:2011.11.26
 ** 附加说明:无
 ** 修改记录:无
 **/
void BSP_Init(void)
{
 RCC_Configuration();
 NVIC_Configuration();
 GPIO_Configuration();
 USART1_Configuration(115200); 
 InitLCD();
}
/**
 ** 函数名称:void GPIO_Configuration(void)
 ** 功能描述:通用IO口配置函数
 ** 输入参数:无
 ** 返回值  :无
 ** 版本信息:v0.2
 ** 编写作者:唐华明
 ** 编写时间:2011.11.26
 ** 附加说明:无
 ** 修改记录:2011-11-27 增加按键IO口配置和外部中断线的配置
 **           2011-11-27 增加USART1的引脚配置
 **/
void GPIO_Configuration(void)
{
 GPIO_InitTypeDef GPIO_InitStructure;
 EXTI_InitTypeDef EXTI_InitStructure;
 
 /* Configure IO connected to PA8 and PD2 *********************/ 
 GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_2;
   GPIO_InitStructure.GPIO_Mode  = GPIO_Mode_Out_PP;
   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_10MHz;
   GPIO_Init(GPIOD, &GPIO_InitStructure);

 GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_8;
 GPIO_Init(GPIOA, &GPIO_InitStructure);
 /* Configure KEY IO connected to PA13 and PA15 ***************/
 GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_13 | GPIO_Pin_15;
   GPIO_InitStructure.GPIO_Mode  = GPIO_Mode_IPU;      //上拉输入
   //当GPIO口设为输入模式使,输出驱动电路与端口断开,此时输出速度
 //配置无意义,不用配置。
   GPIO_Init(GPIOA, &GPIO_InitStructure);
 /* Configure PA13 and PA15 as EXTI Line *********************/
 GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource13);
 GPIO_EXTILineConfig(GPIO_PortSourceGPIOA, GPIO_PinSource15);
 EXTI_ClearITPendingBit(EXTI_Line13);
 EXTI_ClearITPendingBit(EXTI_Line15);
 EXTI_InitStructure.EXTI_Line = EXTI_Line13 | EXTI_Line15;
 EXTI_InitStructure.EXTI_Trigger = EXTI_Trigger_Falling;
 EXTI_InitStructure.EXTI_Mode = EXTI_Mode_Interrupt;
 EXTI_InitStructure.EXTI_LineCmd = ENABLE;
 EXTI_Init(&EXTI_InitStructure); 
 /*Configure USART1(PA9 and PA10) ***************************/
 //define USART1 Tx(PA9) as AF_PP
 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_2MHz;
 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
 GPIO_Init(GPIOA, &GPIO_InitStructure);
 //define USART Rx(PA10) as IN_FLOATING
 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
 GPIO_Init(GPIOA, &GPIO_InitStructure);
}
/**
 ** 函数名称:void RCC_Configuration(void)
 ** 功能描述:系统时钟配置函数
 ** 输入参数:无
 ** 返回值  :无
 ** 版本信息:v0.1
 ** 编写作者:唐华明
 ** 编写时间:2011.11.26
 ** 附加说明:无
 ** 修改记录:2011-11-27 开启串口1的时钟
 **/
void RCC_Configuration(void)
{
 SystemInit();

 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOD, ENABLE);
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE); 
// RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA 
//                          |RCC_APB2Periph_GPIOB  | RCC_APB2Periph_GPIOC
//                          |RCC_APB2Periph_GPIOD  | RCC_APB2Periph_GPIOE
//        |RCC_APB2Periph_ADC1   | RCC_APB2Periph_AFIO 
//                          |RCC_APB2Periph_SPI1, ENABLE );
//    RCC_APB2PeriphClockCmd(RCC_APB2Periph_ALL ,ENABLE );
//    RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4 | RCC_APB1Periph_USART3
//                        |RCC_APB1Periph_TIM2, ENABLE );
// RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);
}
/**
 ** 函数名称:void NVIC_Configuration(void)
 ** 功能描述:嵌入向量中断控制器配置函数
 ** 输入参数:无
 ** 返回值  :无
 ** 版本信息:v0.1
 ** 编写作者:唐华明
 ** 编写时间:2011.11.24
 ** 附加说明:无
 ** 修改记录:2011-11-27 增加按键外部中断的中断向量配置。
 **/
void NVIC_Configuration(void)
{
 NVIC_InitTypeDef NVIC_InitStructure;
   /* Configure the NVIC Preemption Priority Bits ********/  
   NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
 /* Configure the EXTI_Line15_10 ***********************/
 NVIC_InitStructure.NVIC_IRQChannel = EXTI15_10_IRQn;
 NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
 NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
 NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
 NVIC_Init(&NVIC_InitStructure);

 /*Set the Vector Table ********************************/
 #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
}
/**
 ** 函数名称:void InitLCD(void)
 ** 功能描述:金牛开发板上的LCD的初始化设置。
 ** 输入参数:无
 ** 返回值  :无
 ** 版本信息:v0.0
 ** 编写作者:唐华明
 ** 编写时间:2011.11.24
 ** 附加说明:初始化状态可以根据用户的需要做修改。
 ** 修改记录:无
 **/
void InitLCD(void) 
{
   /* LCD Module init */
//   GLCD_init();
//   GLCD_clear(White);
//   GLCD_setTextColor(Blue);
//   GLCD_displayStringLn(Line1, "     GoldBull");
//   GLCD_setTextColor(Red);
//   GLCD_displayStringLn(Line2, "   GPIO example");
}

/**
 ** 函数名称:void USART1_Configuration(uint_32 baudrate)
 ** 功能描述:串口1的配置函数
 ** 输入参数:baudrate:待配置的波特率
 ** 返回值  :无
 ** 版本信息:v0.0
 ** 编写作者:唐华明
 ** 编写时间:2011.11.27
 ** 附加说明:无
 ** 修改记录:无
 **/
void USART1_Configuration(uint32_t baudrate)
{
 USART_InitTypeDef USART_InitStructure;
 /*Configure the structure of USART_InitTypeDef ********************************/
    USART_InitStructure.USART_BaudRate = 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_Mode = USART_Mode_Tx | USART_Mode_Rx;
 USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
 /*Initial USART1 *************************************************************/
 USART_Init(USART1, &USART_InitStructure);
 /*Enable USART1 **************************************************************/
 USART_Cmd(USART1, ENABLE);
 /*Configure the interrupt of USART1 ******************************************/
 USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
 USART_ITConfig(USART1, USART_IT_TXE, ENABLE);
}

/**
 ** 函数名称:int fputc(int ch, FILE *F)
 ** 功能描述:将C库函数printf重定向到串口
 ** 输入参数:
 ** 返回值  :
 ** 版本信息:v0.0
 ** 编写作者:唐华明
 ** 编写时间:2011-11-27
 ** 附加说明:无
 ** 修改记录:无
 **/
int fputc(int ch, FILE *F)
{
 /* 写入一个字符到串口 */
 USART_SendData(USART1, (uint8_t)ch);
 /* 等待发送完成 */
 while (USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET)
 {}
 return ch;
}
/**
 ** 函数名称:int fgetc(FILE *F)
 ** 功能描述:将C库函数scanf重定向到串口
 ** 输入参数:
 ** 返回值  :
 ** 版本信息:v0.0
 ** 编写作者:唐华明
 ** 编写时间:2011-11-27
 ** 附加说明:该功能还不能实现。
 ** 修改记录:无
 **/
int fgetc(FILE *f)
{
 /* 等待接收一个字符完成 */
 while (USART_GetFlagStatus(USART1, USART_FLAG_RXNE) == RESET)
 {}
 /* 从串口读取一个字符并返回 */
 return (USART_ReceiveData(USART1));
}

=========================== 文件分割线 ===============================

/******************************************************************************/
/*                 STM32F10x Peripherals Interrupt Handlers                   */
/*  Add here the Interrupt Handler for the used peripheral(s) (PPP), for the  */
/*  available peripheral interrupt handler's name please refer to the startup */
/*  file (startup_stm32f10x_xx.s).                                            */
/******************************************************************************/
void EXTI15_10_IRQHandler(void)
{
 if (EXTI_GetITStatus(EXTI_Line13) != RESET)
 {
  EXTI_ClearITPendingBit(EXTI_Line13);
  DS0Sft();
  printf("%d  KEY0 is pressed once!\r\n", count++);
 }
 if (EXTI_GetITStatus(EXTI_Line15) != RESET)
 {
  EXTI_ClearITPendingBit(EXTI_Line15);
  DS1Sft();
  printf("%d  KEY1 is pressed once!\r\n", count++);
 }
}

=========================== 文件分割线 ===============================

/**
  * @brief  Main program.
  * @param  None
  * @retval None
  */
int main(void)
{
// unsigned char temp=0;
   /*!< At this stage the microcontroller clock setting is already configured, 
       this is done through SystemInit() function which is called from startup
       file (startup_stm32f10x_xx.s) before to branch to application main.
       To reconfigure the default setting of SystemInit() function, refer to
       system_stm32f10x.c file
     */     
 BSP_Init();
   /* Add your application code here
     */

 printf("This is a test for USART1 and EXTI use.\r\n");
   /* Infinite loop */
   while (1)
   {
  printf("Please input a charactor\r\n");
  delay_ms(1000);
//  scanf("%c", &temp);//not success!
//  delay_ms(1000);
//  printf("You had entered a charactor:%c\r\n", temp);
 }
}

=========================== 文件分割线 ===============================

关键字:STM32  USART

编辑:什么鱼 引用地址:http://www.eeworld.com.cn/mcu/article_2016101030293.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:STM32初学笔记5之ADC(上)
下一篇:STM32初学笔记3之外部中断

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

STM32堆栈设置

1.堆和栈大小 定义大小在startup_stm32f2xx.sStack_Size      EQU     0x00000400                AREA    STACK, NOINIT, READWRITE, ALIGN=3Stack_Mem      
发表于 2019-04-16
STM32堆栈设置

STM32堆和栈(Heap & Stack)的资料理解

源起:在移植cjson的过程中,解析json包的时候发现动态内存分配不足而导致解析失败,为解决这一问题,而深入了解stm32的堆和栈。stm32的存储器结构。Flash,SRAM寄存器和输入输出端口被组织在同一个4GB的线性地址空间内。可访问的存储器空间被分成8个主要块,每个块为512MB。FLASH存储下载的程序。SRAM是存储运行程序中的数据。而SRAM一般分这几个部分:静态存储区:内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。它主要存放静态数据、全局数据和常量。栈区:在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率
发表于 2019-04-16
STM32堆和栈(Heap & Stack)的资料理解

STM32定义堆栈地址到ram区顶部

本设置针对stm32f103rbt6的设置,该芯片RAM大小为20kB,故RAM区地址范围为0x20000000—0x20005000,芯片信息如下图所示;第一步:设置.sct文件;;*************************************************************; *** Scatter-Loading Description Filegenerated by uVision ***; *************************************************************LR_IROM1 0x08000000 0x00020000  
发表于 2019-04-16
STM32定义堆栈地址到ram区顶部

STM32之程序如何防止堆栈溢出

近日为某个项目写了个草稿程序,即非正式程序,后来发现老是进入hardfaulthandler,原来是堆栈溢出,后仔细查看发现函数调用纵深太深,最多的时候可保持7个函数在堆栈中调用。因此有心得如下:一、函数调用不要纵深太深,即以下模式:main(){   fun1();}fun1(){  fun2();}fun2(){   fun3();}fun3(){  fun4();}fun4(){  fun5();}fun5(){  fun6();}fun6(){   fun7();}这样子main函数要调用fun1函数完成某个功能,则要一直调到
发表于 2019-04-16

stm32之堆栈

stm32中的堆栈设置keil编译完成时存储情况当编译成功时,会出现: BUILD://Program Size: Code=340 RO-data=252 RW-data=0 ZI-data=1632Code:程序代码部分RO-data: 程序定义的常量const tempRW-data:已初始化的全局变量ZI-data:未初始化的全局变量片中的:flash=Code+RO-data+RW-dataRAM=RW-data+ZI-data通过上面的BUILD可以看出,这个程序已经用了1600多的RAM,为什么会出用到这么多的RAM呢?在startup_stm32f10x_md.s文件中存在:St
发表于 2019-04-16

说说STM32的堆栈与内存

1.概念这里所说的堆栈,是针对单片机所说的“堆”与“栈”,指的是内存中一片特殊用途的区域。而不是数据结构中的堆栈(虽然其实规则一样)。这里所说的内存,是指RAM,RAM包括SRAM,DRAM等。而不是什么手机内存卡之类。这里所说的flash,指的是用作为ROM的存储器,保存代码与常量数据。而不是动画制作。。。栈的生长方向:指的是入栈方向,从高地址向低地址生长叫做向下生长,或逆向生长;反过来就叫向上生长,或正向生长。STM32的栈是向下生长。2.内存中的堆栈安排确切地说,是keil mdk根据STM32的特性,对stm32的RAM甚至flash进行部署。编译工程后,在生成的.map文件里可以看到具体的安排。双击工程界面的工程根目录
发表于 2019-04-16
说说STM32的堆栈与内存

小广播

何立民专栏

单片机及嵌入式宝典

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

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2019 EEWORLD.com.cn, Inc. All rights reserved