OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6104|回复: 3

STM32串口应用问题(关于LED灯)

[复制链接]

1

主题

1

帖子

0

精华

新手入门

积分
25
金钱
25
注册时间
2012-11-3
在线时间
0 小时
发表于 2012-11-3 18:01:12 | 显示全部楼层 |阅读模式

 我要做一个通过串口控制LED灯状态的程序,用stm32的串口,通过串口调试助手发送数据使得一个led灯分别以该数据为时间间隔闪烁(如发送1000,则LED灯以delay(1000)为间隔闪烁),我把我的程序放上来,原子哥和各位大神帮我看看是哪里的问题。

 


#include "stm32f10x.h"

 static int time;
/***********************************************************************

  外设时钟使能


************************************************************************/
void RCC_Configuration(void)

   /*  使能外设时钟 */
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 |
         RCC_APB2Periph_GPIOA  | RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOC |
         RCC_APB2Periph_GPIOD  | RCC_APB2Periph_GPIOE|RCC_APB2Periph_AFIO, ENABLE);
 
 RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);
}


/*******************************************************************************
      
        全部用到的引脚将在在配置

*******************************************************************************/
void GPIO_Configuration(void)
{
 GPIO_InitTypeDef GPIO_InitStructure;
              //发送接收端口
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;  //TXD
    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; //RXD
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
    GPIO_Init(GPIOA, &GPIO_InitStructure); 

 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
 GPIO_Init(GPIOD, &GPIO_InitStructure);//初始化外设GPIO


}


/*******************************************************************************

        全部中断在此配置

*******************************************************************************/
void NVIC_Configuration(void)//中断设置
{
   NVIC_InitTypeDef NVIC_InitStructure;//定义结构体
    /* Configure the NVIC Preemption Priority Bits */ 
    NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);//串口一分到1组

    /* Enable the USART1 Interrupt */
    NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;  //通道设置为串口1中断
    NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; //中断响应优先级0
    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;   //打开中断
    NVIC_Init(&NVIC_InitStructure);        //初始化

}


void USART1_Init(unsigned int baud)//////USART1 初始化 baud 波特率
{
    USART_InitTypeDef USART_InitStructure;

    USART_InitStructure.USART_BaudRate = baud; //该成员设置了USART传输的波特率
    USART_InitStructure.USART_WordLength = USART_WordLength_8b;//提示了在一个帧中传输或者接收到的数据位数(8位)
    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;//指定了使能或者失能发送和接收模式(TX发送RX接收)

    USART_Init(USART1, &USART_InitStructure); //初始化外设 USARTx 寄存器

    USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//使能或者失能指定的USART中断
 //(参数选择 USART外设,参数USART_IT 使能或者失能USART的中断 )若接收数据寄存器满,则产生中断

    USART_Cmd(USART1, ENABLE); //使能或者失能USART外设,使能 USART1, 配置完毕

    USART_ClearFlag(USART1, USART_FLAG_TC);     // 清标志,解决第1个字节无法正确发送出去的问题
}


/*******************************************************************************

        初始化时钟晶振 72MHZ

*******************************************************************************/
void SysClock_Init(void)
{
 ErrorStatus HSEStartUpStatus;    
 RCC_DeInit();
 RCC_HSEConfig(RCC_HSE_ON);
 HSEStartUpStatus = RCC_WaitForHSEStartUp();
 if(HSEStartUpStatus == SUCCESS){
     FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
  FLASH_SetLatency(FLASH_Latency_2);
     RCC_HCLKConfig(RCC_SYSCLK_Div1);   
     RCC_PCLK2Config(RCC_HCLK_Div1);  
     RCC_PCLK1Config(RCC_HCLK_Div2); 
     RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9); 
     RCC_PLLCmd(ENABLE); 
     while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET){
      ;
  } 
     RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); 
     while(RCC_GetSYSCLKSource() != 0x08){
      ;
  }
 }
}

void USART1_SendByte(unsigned char temp)//从 USART1 发送一个字节???????????
{
    USART_SendData(USART1, temp);  //通过外设USARTx 发送单个数据(USARTx :x 可以是1 ,2 或者3 ,来选择 USART外设,Data: 待发送的数据 )
    while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);//检查指定的USART标志位设置与否
}

void USART1_Printf(char *pch)//从 USART1 发送字符串????????????????????????
{
    while(*pch != '\0')
 {
        USART1_SendByte(*(unsigned char *)pch);
        pch++;
    }
}


/******************************************
*
*             延时程序 ms
*
 ****************************************/
 void delay(unsigned int xml)
  {
    int i,j;
    for (i=xml;i>0;i--)
    for (j=110;j>0;j--);
   }
/*******************************************************

  MAIN 函数

*******************************************************/
int main(void)
{
  
     SysClock_Init();     // 初始化系统时钟 72MHZ
  RCC_Configuration();   // 使能外设
    GPIO_Configuration();    // 配置引脚
  NVIC_Configuration();  // 配置中断
  USART1_Init(9600);   // 配置串口1,波特率9600
 while(1)
 {
 GPIO_ResetBits(GPIOD,GPIO_Pin_2);
     delay(time);
      GPIO_SetBits(GPIOD,GPIO_Pin_2);
      delay(time);
 }
}

中断服务程序

extern void USART1_SendByte(unsigned char temp);  // 声明外部函数
void USART1_IRQHandler(void)
{
   static int time;
    if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)// 接收中断
 {
  USART1_SendByte(USART_ReceiveData(USART1));
  time=USART_ReceiveData(USART1);
    } 
}

 

 

 

 

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2012-11-3 18:55:16 | 显示全部楼层
直接用我们的usmart即可非常方便实现你要的功能!
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

20

主题

118

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
304
金钱
304
注册时间
2014-3-23
在线时间
22 小时
发表于 2014-8-6 15:12:58 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
原子哥给一个呗我弄半天都糊涂了,用的mini开发板控制LED的亮灭;我是这么写的不过不对啊if(USART_RX_STA&0x80)
{    
len=USART_RX_STA&0x3f;//得到此次接收到的数据长度
printf("\r\n您发送的消息为:\r\n");
for(t=0;t<len;t++)
{
USART1->DR=USART_RX_BUF[t];
while((USART1->SR&0X40)==0);//等待发送结束
}
if(USART_RX_BUF[]=='1')
{
LED0=0;
LED1=1;
delay_ms(300);  //延时300ms
LED0=1;
LED1=0;
delay_ms(300); //延时300ms
}
else
{
LED0=0;
LED1=0;
}
printf("\n\n");//插入换行
USART_RX_STA=0;
回复 支持 反对

使用道具 举报

11

主题

64

帖子

0

精华

初级会员

Rank: 2

积分
90
金钱
90
注册时间
2014-8-4
在线时间
14 小时
发表于 2014-8-6 20:48:53 | 显示全部楼层
回复【3楼】张仁良:
---------------------------------
请问你发送是以十六进制发送的吗
如果不是请以十六进制方式发送试试
生命不息,学习不止
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-4 06:40

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表