OpenEdv-开源电子网

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

串口4可以使用printf函数改成串口1就不行,求解答

[复制链接]

1

主题

2

帖子

0

精华

新手入门

积分
5
金钱
5
注册时间
2018-10-21
在线时间
2 小时
发表于 2018-10-30 11:35:10 | 显示全部楼层 |阅读模式
5金钱
本帖最后由 zel602 于 2018-10-30 11:38 编辑

RT,主板是stm32F4,串口4配置成printf可以输出,改成串口1配置printf函数串口调试助手上无输出,使用串口例程中串口1配置printf有输出,程序如下:
主函数串口部分程序如下:
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);        // 设置系统中断优先级分组2
        delay_init(168);                                                                // 延时初始化         
        uart1_init(115200);                                                                // 串口1初始化波特率为38400
    uart2_init(921600);                                                               
    uart3_init(9600);                                                               
    //uart4_init(921600);                                                               
    uart6_init(9600);                                                               
    delay_ms(10);
    TIM3_Int_Init(50-1,8400-1);                     // 定时器3初始化,单位:0.1ms;100*0.1=10ms        
    TIM2_Int_Init(2000-1,8400-1);                        // 系统运行时钟周期设置
                while(1)
                {
                         printf("串口调试打印!hhaha\r\n");
                        //DSP_MatMult();
                        delay_ms(500);
                }


串口函数部分:
#include "sys.h"
#include "usart.h"        
         
//如果使用ucos,则包括下面的头文件即可.
#if SYSTEM_SUPPORT_UCOS
#include "includes.h"                                        //ucos 使用         
#endif         

//加入以下代码,支持printf函数,而不需要选择use MicroLIB         
#if 1
#pragma import(__use_no_semihosting)            
//标准库需要的支持函数                 
struct __FILE
{
        int handle;
};

FILE __stdout;      
//定义_sys_exit()以避免使用半主机模式   
void _sys_exit(int x)
{
        x = x;
}


//************************串口变量初始化************************************//
//#if EN_USART2_RX                                                   //如果使能了接收           
u8 USART1_RX_BUF[USART1_REC_LEN];                     //接收缓冲,最大USART_REC_LEN个字节.
u16 USART1_RX_STA=0;                                               //接收状态标记

//#if EN_USART2_RX                                                   //如果使能了接收           
u8 USART2_RX_BUF[USART2_RX_LEN];                     //接收缓冲,最大USART2_RX_LEN个字节.
u16 USART2_RX_STA=0;                                               //接收状态标记

//#if EN_USART3_RX                                                   //如果使能了接收           
u8 USART3_RX_BUF[USART3_REC_LEN];                     //接收缓冲,最大USART_REC_LEN个字节.
u16 USART3_RX_STA=0;                                               //接收状态标记
const u8 GPS_HEAD[3][5]={{71,78,82,77,67},{71,80,71,83,86},{71,76,71,83,86}};//GNRMC;GPGSV;GLGSV
u8 GPS_FrameCnt[4]={0};                                                        //接收帧数
u16 GPS_FrameInd[9][2]={0};                                                //接收帧位置指示:帧头;帧尾
        
//#if EN_USART6_RX                                                   // 如果使能了接收           
u8 USART6_RX_BUF[USART6_RX_LEN];                     // 接收缓冲,最大USART_REC_LEN个字节.
u16 USART6_RX_STA=0;                                               // 接收状态标记        


//重定义fputc函数
int fputc(int ch, FILE *f)
{         
        while((USART1->SR&0X40)==0);//循环发送,直到发送完毕   
        USART1->DR = (u8) ch;  
        while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);        
        return ch;
}
#endif

char USART4_SendChar(char dat){                 
        while((UART4->SR&0X40)==0);//循环发送,直到发送完毕   
        UART4->DR = (u8) dat;  
        while(USART_GetFlagStatus(UART4,USART_FLAG_TC)!=SET);        
        return dat;
}

char USART2_Send(char dat){                 
        while((USART2->SR&0X40)==0);//循环发送,直到发送完毕   
        USART2->DR = (u8) dat;  
        while(USART_GetFlagStatus(USART2,USART_FLAG_TC)!=SET);        
        return dat;
}

//************************串口1中断函数************************************//
void USART1_IRQHandler(void)                        //串口1中断服务程序
{
        u8 Res;
        if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) {               
                Res =USART_ReceiveData(USART1);                                        //读取接收到的数据
        }
}


// 串口4中断服务程序:与上位机通信
void UART4_IRQHandler(void)                        
{
        u8 Res;
        if(USART_GetITStatus(UART4, USART_IT_RXNE) != RESET){               
                Res =USART_ReceiveData(UART4);                                
//                printf("进入中断\r\n");
        }
}

求指导!

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

使用道具 举报

1

主题

882

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3071
金钱
3071
注册时间
2018-2-7
在线时间
285 小时
发表于 2018-10-30 14:52:51 | 显示全部楼层
重新定义串口输出要修改这个函数
//重定义fputc函数
int fputc(int ch, FILE *f)
{         
        while((USART1->SR&0X40)==0);//循环发送,直到发送完毕   
        USART1->DR = (u8) ch;  
        while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!=SET);        
        return ch;
}
#endif
回复

使用道具 举报

1

主题

2

帖子

0

精华

新手入门

积分
5
金钱
5
注册时间
2018-10-21
在线时间
2 小时
 楼主| 发表于 2018-10-30 16:10:59 | 显示全部楼层
HXYDJ 发表于 2018-10-30 14:52
重新定义串口输出要修改这个函数
//重定义fputc函数
int fputc(int ch, FILE *f)

谢谢解答,我把串口号都改成USART1了,可是还是无法通过printf串口输出,不知道为什么。。。
回复

使用道具 举报

2

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
63
金钱
63
注册时间
2019-5-8
在线时间
20 小时
发表于 2019-5-9 17:24:31 来自手机 | 显示全部楼层
我也是  请问后来怎么解决的
回复

使用道具 举报

18

主题

190

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1068
金钱
1068
注册时间
2012-6-18
在线时间
158 小时
发表于 2019-5-13 02:07:54 | 显示全部楼层
串口初始化函数查找去,多半是初始化错误。
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-11 07:19

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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