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

2019-07-20 01:57发布

本帖最后由 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 ");
                        //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("进入中断 ");
        }
}

求指导!

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
4条回答
HXYDJ
1楼-- · 2019-07-20 05:35
重新定义串口输出要修改这个函数
//重定义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
zel602
2楼-- · 2019-07-20 08:44
HXYDJ 发表于 2018-10-30 14:52
重新定义串口输出要修改这个函数
//重定义fputc函数
int fputc(int ch, FILE *f)

谢谢解答,我把串口号都改成USART1了,可是还是无法通过printf串口输出,不知道为什么。。。
13780387317wna
3楼-- · 2019-07-20 08:57
 精彩回答 2  元偷偷看……
bg8wj
4楼-- · 2019-07-20 10:22
 精彩回答 2  元偷偷看……

一周热门 更多>