你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

F103求助USART3无法工作,MDK仿真能够输出,但板子不能打印

[复制链接]
luokanx 提问时间:2016-12-28 17:13 /
代码如下:那位大神指点一下啊~


#include "stm32f10x.h"
#include "stdio.h"

void delay(__IO u32 nCount);

int main(void)
{
        /* USART1 config 115200 8-N-1 */
USART3_Config();

printf("\r\n  STM32f103 USART1 test");
       
//USART3_Config();

        while(1)
        {
printf("\r\n TM32f103 USART3 test \r\n");
       
//        for (;;) {
//}
}


       
        }


       
void delay(__IO u32 nCount)
{
        for (; nCount != 0; nCount--);
}




void USART3_Config(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;
       
        /* config USART3 clock */
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3 | RCC_APB2Periph_GPIOB, ENABLE);
       

       
        /* USART3 GPIO config */
        /* Configure USART3 Tx (PB.10) as alternate function push-pull */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOB, &GPIO_InitStructure);   
        /* Configure USART3 Rx (PB.11) as input floating */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
        GPIO_Init(GPIOB, &GPIO_InitStructure);
       
/* USART3 mode config */
USART_InitStructure.USART_BaudRate = 115200;
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(USART3, &USART_InitStructure);
       

       
        /* ʹÄÜ´®¿Ú3½ÓÊÕÖÐ¶Ï */
        USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);
       
        USART_Cmd(USART3, ENABLE);
}



//ÅäÖÃUSART3½ÓÊÕÖжÏ
void NVIC_Configuration(void)
{
        NVIC_InitTypeDef NVIC_InitStructure;
        /* Configure the NVIC Preemption Priority Bits */  
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_3);
       
        /* Enable the USARTy Interrupt */
        NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn;         
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
        NVIC_Init(&NVIC_InitStructure);
}




void NVIC_Init(NVIC_InitTypeDef* NVIC_InitStruct)
{
  uint32_t tmppriority = 0x00, tmppre = 0x00, tmpsub = 0x0F;

  /* Check the parameters */
  assert_param(IS_FUNCTIONAL_STATE(NVIC_InitStruct->NVIC_IRQChannelCmd));
  assert_param(IS_NVIC_PREEMPTION_PRIORITY(NVIC_InitStruct->NVIC_IRQChannelPreemptionPriority));  
  assert_param(IS_NVIC_SUB_PRIORITY(NVIC_InitStruct->NVIC_IRQChannelSubPriority));

  if (NVIC_InitStruct->NVIC_IRQChannelCmd != DISABLE)
  {
    /* Compute the Corresponding IRQ Priority --------------------------------*/   
    tmppriority = (0x700 - ((SCB->AIRCR) & (uint32_t)0x700))>> 0x08;
    tmppre = (0x4 - tmppriority);
    tmpsub = tmpsub >> tmppriority;

    tmppriority = (uint32_t)NVIC_InitStruct->NVIC_IRQChannelPreemptionPriority << tmppre;
    tmppriority |=  NVIC_InitStruct->NVIC_IRQChannelSubPriority & tmpsub;
    tmppriority = tmppriority << 0x04;

    NVIC->IP[NVIC_InitStruct->NVIC_IRQChannel] = tmppriority;

    /* Enable the Selected IRQ Channels --------------------------------------*/
    NVIC->ISER[NVIC_InitStruct->NVIC_IRQChannel >> 0x05] =
      (uint32_t)0x01 << (NVIC_InitStruct->NVIC_IRQChannel & (uint8_t)0x1F);
  }
  else
  {
    /* Disable the Selected IRQ Channels -------------------------------------*/
    NVIC->ICER[NVIC_InitStruct->NVIC_IRQChannel >> 0x05] =
      (uint32_t)0x01 << (NVIC_InitStruct->NVIC_IRQChannel & (uint8_t)0x1F);
  }
}




#define AIRCR_VECTKEY_MASK    ((uint32_t)0x05FA0000)


void NVIC_PriorityGroupConfig(uint32_t NVIC_PriorityGroup)
{
  /* Check the parameters */
  assert_param(IS_NVIC_PRIORITY_GROUP(NVIC_PriorityGroup));

  /* Set the PRIGROUP[10:8] bits according to NVIC_PriorityGroup value */
  SCB->AIRCR = AIRCR_VECTKEY_MASK | NVIC_PriorityGroup;
}


/// Öض¨Ïòc¿âº¯Êýprintfµ½USART3
int fputc(int ch, FILE *f)
{
                /* ·¢ËÍÒ»¸ö×Ö½ÚÊý¾Ýµ½USART3 */
                USART_SendData(USART3, (uint8_t) ch);
               
                /* µÈ´ý·¢ËÍÍê±Ï */
                while (USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);               
       
                return (ch);
}

/// Öض¨Ïòc¿âº¯Êýscanfµ½USART3
int fgetc(FILE *f)
{
                /* µÈ´ý´®¿Ú1ÊäÈëÊý¾Ý */
                while (USART_GetFlagStatus(USART3, USART_FLAG_RXNE) == RESET);

                return (int)USART_ReceiveData(USART3);
}
/*********************************************END OF FILE**********************/






收藏 1 评论18 发布时间:2016-12-28 17:13

举报

18个回答
luokanx 回答时间:2016-12-29 14:48:52
原来是在GPIO Config()里面没有开启总线时钟,里面加上这句就可以了。
RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOB, ENABLE);

评分

参与人数 1ST金币 +2 收起 理由
zero99 + 2 结贴奖励

查看全部评分

andypanfan 回答时间:2016-12-30 09:05:26
  1. #ifndef __USART3_H
  2. #define __USART3_H

  3. #include "sys.h"
  4. #include "delay.h"
  5. #include "string.h"
  6. #include <stdlib.h>
  7. #include "time3.h"

  8. #define  TX3_buf_size        30
  9. #define  RX3_buf_size        30

  10. extern u8 USART3_RX_CNT;

  11. extern u8 USART3_RX_BUF[RX3_buf_size];
  12. extern u8 USART3_TX_BUF[TX3_buf_size];

  13. void usart3_init(u32 bound);
  14. void usart3_Send_Data(u8 *buf,u8 len);
  15. void clear_usart3_receive_buf(void);

  16. #endif


  17. #include "usart3.h"

  18. //#if 1
  19. //#pragma import(__use_no_semihosting)                              
  20. //struct __FILE
  21. //{
  22. //        int handle;

  23. //};

  24. //FILE __stdout;         
  25. //_sys_exit(int x)
  26. //{
  27. //        x = x;
  28. //}  
  29. //int fputc(int ch, FILE *f)
  30. //{      
  31. //        while((USART3->SR&0X40)==0);
  32. //    USART3->DR = (u8) ch;      
  33. //        return ch;
  34. //}
  35. //#endif

  36. u8 usart3_receive_data_flag=0;                                                                                                           
  37. u8 USART3_RX_CNT=0;                                                                                                                                     

  38. u8 USART3_RX_BUF[RX3_buf_size]={0};                                                                                                  
  39. u8 USART3_TX_BUF[TX3_buf_size]={0};                                                                                                  

  40. void usart3_init(u32 bound)
  41. {
  42.     GPIO_InitTypeDef GPIO_InitStructure;
  43.         USART_InitTypeDef USART_InitStructure;
  44.         NVIC_InitTypeDef NVIC_InitStructure;
  45.    
  46.         RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);                                                       
  47.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_AFIO, ENABLE);

  48.         USART_DeInit(USART3);
  49.    
  50.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;                                                                                 //USART3_TX   PB10
  51.     GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  52.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;                                                                        //复用推挽输出
  53.     GPIO_Init(GPIOB, &GPIO_InitStructure);
  54.     GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;                                                                                //USART3_RX          PB11
  55.     GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;                                                        //浮空输入
  56.         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  57.     GPIO_Init(GPIOB, &GPIO_InitStructure);
  58.     NVIC_InitStructure.NVIC_IRQChannel = USART3_IRQn;                                                                //Usart3 NVIC 配置
  59.         NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;                                                //抢占优先级3
  60.         NVIC_InitStructure.NVIC_IRQChannelSubPriority = 2;                                                                //子优先级3
  61.         NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                                                                        //IRQ通道使能
  62.         NVIC_Init(&NVIC_InitStructure);
  63.         USART_InitStructure.USART_BaudRate = bound;                                                                                //一般设置为9600;
  64.         USART_InitStructure.USART_WordLength = USART_WordLength_8b;                                                //字长为8位数据格式
  65.         USART_InitStructure.USART_StopBits = USART_StopBits_1;                                                        //一个停止位
  66.         USART_InitStructure.USART_Parity = USART_Parity_No;                                                                //无奇偶校验位
  67.         USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; //无硬件数据流控制
  68.         USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;                                        //收发模式
  69.     USART_Init(USART3, &USART_InitStructure);                                                                                 //初始化串口
  70.     USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);                                                                        //开启中断
  71.     USART_Cmd(USART3, ENABLE);
  72. }

  73. void USART3_IRQHandler(void)                                                                                                //串口1中断服务程序
  74. {
  75.         unsigned char usart3_rece_dat=0;
  76.    
  77.         if(USART_GetITStatus(USART3, USART_IT_RXNE)==SET)                                                             //接收中断
  78.         {
  79.             usart3_rece_dat=USART_ReceiveData(USART3);
  80.                 if(USART3_RX_CNT<sizeof(USART3_RX_BUF))                                                                        //最多接收30个字节的数据
  81.                 {
  82.                         USART3_RX_BUF[USART3_RX_CNT]=usart3_rece_dat;                                                        //记录接收到的值
  83.                         USART3_RX_CNT++;                                                                                                                //接收数据增加1
  84.                 }                                                                                                                                        //USART_ReceiveData(USART1);
  85.    }
  86. }

  87. void usart3_Send_Data(u8 *buf,u8 len)
  88. {                                                                                               
  89.     u8 t;
  90.           for(t=0;t<len;t++)                                                                                                                                //循环发送数据
  91.         {                  
  92.                 while(USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);          
  93.                 USART_SendData(USART3,buf[t]);
  94.         }         
  95.         while(USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);                          
  96. }

  97. void clear_usart3_receive_buf(void)
  98. {
  99.         memset(USART3_RX_BUF,0,sizeof(USART3_RX_BUF));
  100.         USART3_RX_CNT=0;
  101. }

  102. 这是我以前测试过的代码  你看看!!!
复制代码

评分

参与人数 1ST金币 +2 收起 理由
zero99 + 2

查看全部评分

luokanx 回答时间:2016-12-29 11:37:58
重新整理了一下。

#include "stm32f10x.h"
#include "stdio.h"
#include "misc.h"
#include "led.h"

void delay(__IO u32 nCount);
void GPIO_Config(void);
void USART3_Config(void);


int main(void)
{
       
        RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3 | RCC_APB2Periph_GPIOB,ENABLE);
        GPIO_Config();
        USART3_Config();
       
        while(1)
        {
               
                printf("adsfsfsfsfs");
               
        }
       
//        return (1);
       
        }


void delay(__IO u32 nCount)

{
        for (; nCount != 0; nCount--);
}


void GPIO_Config(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
/* Configure USART3 Tx (PB.10) as alternate function push-pull */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOB, &GPIO_InitStructure);   
        /* Configure USART3 Rx (PB.11) as input floating */
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
        GPIO_Init(GPIOB, &GPIO_InitStructure);
}
void USART3_Config(void)
{
        USART_InitTypeDef USART_InitStructure;
        //* USART3 mode config */
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(USART3, &USART_InitStructure);
       
        USART_ITConfig(USART3, USART_IT_RXNE, ENABLE);
       
        USART_Cmd(USART3, ENABLE);

}


int fputc(int ch, FILE *f)
{
               
                USART_SendData(USART3, (uint8_t) ch);
               
               
                while (USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET);               
       
                return (ch);
}


int fgetc(FILE *f)
{
               
                while (USART_GetFlagStatus(USART3, USART_FLAG_RXNE) == RESET);

                return (int)USART_ReceiveData(USART3);
}
海迹天涯 回答时间:2016-12-28 17:53:26
无能为力帮你顶个帖子吧
luokanx 回答时间:2016-12-28 20:05:40
:'(:'(:'(:'(:'(大神呢
五哥1 回答时间:2016-12-29 02:37:18
你把那些乱码处理下,没法看
黑皮男 回答时间:2016-12-29 09:01:51
没有把复用功能映射到IO口吧,有一个GPIO_PinAFConfig函数就是这个功能,可以试试

评分

参与人数 1ST金币 +2 收起 理由
zero99 + 2

查看全部评分

andypanfan 回答时间:2016-12-29 09:11:29
你这个代码  哎  :(:(:(
luokanx 回答时间:2016-12-29 11:34:41
黑皮男 发表于 2016-12-29 09:01
没有把复用功能映射到IO口吧,有一个GPIO_PinAFConfig函数就是这个功能,可以试试 ...

我用的是LQFP48脚封装的,不需要开吧!等会我开了试试。
luokanx 回答时间:2016-12-29 11:41:54
如上所述,仿真的时候能够通过,也有打印消息输出,但连上芯片,芯片都没有打印输出。还发现了一个问题,就是仿真的时候如果波特率设置为115200在MDK仿真里面显示的是115384,如果设置为9600,仿真显示结果正常。为什么啊?求指点。
luokanx 回答时间:2016-12-29 11:43:27
五哥1 发表于 2016-12-29 02:37
你把那些乱码处理下,没法看

重新整理了一下,在9楼,10楼有进一步的描述,麻烦帮我看一下呗。
luokanx 回答时间:2016-12-29 11:43:48

重新整理了一下,在9楼,10楼有进一步的描述,麻烦帮我看一下呗。
endsoing 回答时间:2016-12-29 12:06:25
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
抢占优先级设为最高级是否合适,高低一些试试。

评分

参与人数 1ST金币 +2 收起 理由
zero99 + 2

查看全部评分

any012 回答时间:2016-12-29 12:29:42
确定单片机是否工作?比如用IO口先控制个LED亮灭。

晕了,我也是瞎说,既然能下载程序,那么单片机应该是正常工作的...
luokanx 回答时间:2016-12-29 13:45:49
程序没有错,是硬件连接上的问题。能用了。
12下一页

所属标签

相似问题

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版