3043|3

530

帖子

4

TA的资源

一粒金砂(高级)

楼主
 

【基于KW41Z的智能电力监测仪的设计】第三贴:串口调试过程中的小感悟 [复制链接]

本帖最后由 传媒学子 于 2017-6-18 17:32 编辑

本次就串口调试中出现的一个小问题进行描述,以供大家出现问题时参考。

问题描述:
我开始在Kinetis DesignStudio 环境中调试串口程序,没有问题,有串口助手调试一切正常。然后,我寻思着现在KDS可能不会再更新了,就想用MCUXpresso IDE v10.0来进行编译。当我安装好SDK后,打开hello world DEMO后,就下载进去,一切都没有问题,而后控制台出现了可以调试的图标。 进行调试,一切良好,然而,让我尝试用串口读取时,串口不显示字符串,只能显示字符。
于是我就思考为什么? 记得之前学习C语言时,隐隐约约记得控制台调试或者串口调试,程序是demo应该没有问题,而且KDS中运行就正常,因此,我觉得问题可能出现在编译过程中。于是我就又重新加载了一次demo,终于发现了问题所在。
其实,就是printf()函数的编译问题,到底是编译输出到串口,还是输出到控制台。个人建议输出在串口,因为控制台输出感觉卡卡的。下面分析以下代码:
程序主程序代码:

  1. #include "fsl_device_registers.h"
  2. #include "fsl_debug_console.h"
  3. #include "board.h"

  4. #include "pin_mux.h"
  5. #include <stdbool.h>
  6. #include "clock_config.h"

  7. int main(void)
  8. {
  9.     char ch;

  10.     /* Init board hardware. */
  11.     BOARD_InitPins();
  12.     BOARD_BootClockRUN();
  13.     BOARD_InitDebugConsole();

  14.     PRINTF("hello world.\r\n");

  15.     while (1)
  16.     {
  17.         ch = GETCHAR();
  18.         PUTCHAR(ch);
  19.     }
  20. }
复制代码

就printf() 和 putchar()的函数定义,是在 utilities下的,打开即可看到他们的函数定义:
  1. /*! [url=home.php?mod=space&uid=159083]@brief[/url] Definition to select sdk or toolchain printf, scanf. */
  2. #ifndef SDK_DEBUGCONSOLE
  3. #define SDK_DEBUGCONSOLE 1U
  4. #endif

  5. #if defined(SDK_DEBUGCONSOLE) && !(SDK_DEBUGCONSOLE)
  6. #include <stdio.h>
  7. #endif

  8. /*! @brief Definition to printf the float number. */
  9. #ifndef PRINTF_FLOAT_ENABLE
  10. #define PRINTF_FLOAT_ENABLE 0U
  11. #endif /* PRINTF_FLOAT_ENABLE */

  12. /*! @brief Definition to scanf the float number. */
  13. #ifndef SCANF_FLOAT_ENABLE
  14. #define SCANF_FLOAT_ENABLE 0U
  15. #endif /* SCANF_FLOAT_ENABLE */

  16. /*! @brief Definition to support advanced format specifier for printf. */
  17. #ifndef PRINTF_ADVANCED_ENABLE
  18. #define PRINTF_ADVANCED_ENABLE 0U
  19. #endif /* PRINTF_ADVANCED_ENABLE */

  20. /*! @brief Definition to support advanced format specifier for scanf. */
  21. #ifndef SCANF_ADVANCED_ENABLE
  22. #define SCANF_ADVANCED_ENABLE 0U
  23. #endif /* SCANF_ADVANCED_ENABLE */

  24. #if SDK_DEBUGCONSOLE /* Select printf, scanf, putchar, getchar of SDK version. */
  25. #define PRINTF DbgConsole_Printf
  26. #define SCANF DbgConsole_Scanf
  27. #define PUTCHAR DbgConsole_Putchar
  28. #define GETCHAR DbgConsole_Getchar
  29. #else /* Select printf, scanf, putchar, getchar of toolchain. */
  30. #define PRINTF printf
  31. #define SCANF scanf
  32. #define PUTCHAR putchar
  33. #define GETCHAR getchar
  34. #endif /* SDK_DEBUGCONSOLE */
复制代码

不难看出,上述定义了控制台输出和串口输出,就printf的编译,可以在导入sdk project时做如下设置参考如下设置:

/********************************************************************************
设置控制台输出:



/********************************************************************************
设置串口输出: 将redirect printf/scanf to UART 打上勾



亦可在编译设置中,将上述按照自己的需求进行设置。


此帖出自NXP MCU论坛

最新回复

是的,他现在在折腾硬件,没什么关系  详情 回复 发表于 2017-6-30 12:06
点赞 关注
 

回复
举报

2700

帖子

0

TA的资源

五彩晶圆(初级)

沙发
 
MARK 关注
此帖出自NXP MCU论坛

点评

nmg
智能电力监测仪好像对你胃口,你俩可以讨论讨论。  详情 回复 发表于 2017-6-30 10:10
 
个人签名作为一个水军,就是尽量的多回帖,因为懂的技术少,所以回帖水分大,见谅!
EEWORLD开发板置换群:309018200,——电工们免费装β的天堂,商家勿入!加群暗号:喵
 
 

回复

5260

帖子

239

TA的资源

管理员

板凳
 

智能电力监测仪好像对你胃口,你俩可以讨论讨论。
此帖出自NXP MCU论坛
加EE小助手好友,
入技术交流群
EE服务号
精彩活动e手掌握
EE订阅号
热门资讯e网打尽
聚焦汽车电子软硬件开发
认真关注技术本身

点评

是的,他现在在折腾硬件,没什么关系  详情 回复 发表于 2017-6-30 12:06
 
 
 

回复

2700

帖子

0

TA的资源

五彩晶圆(初级)

4
 
nmg 发表于 2017-6-30 10:10
智能电力监测仪好像对你胃口,你俩可以讨论讨论。

是的,他现在在折腾硬件,没什么关系
此帖出自NXP MCU论坛
 
个人签名作为一个水军,就是尽量的多回帖,因为懂的技术少,所以回帖水分大,见谅!
EEWORLD开发板置换群:309018200,——电工们免费装β的天堂,商家勿入!加群暗号:喵
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表