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

1、TrueStdio开发工具使用printf函数输出使用-分享

[复制链接]
Y-D 发布时间:2018-7-21 16:19
本帖最后由 Y-D 于 2018-7-24 09:14 编辑
) H3 ]1 \! ]$ t5 s+ ]
/ i1 a0 `* O3 {) Y- S+ _9 c( m, W
TrueStudio开发工具中使用printf函数如果第一次接触可能会找不到方向,现将最近刚刚接触STM32cubemx配置生成TrueStudio工程串口打印的使用过程进行如下说明:
(1)   STM32cubemx创建基本工程打开软件在Pinout选项卡下按照如图选择配置串口1
A、选择系统时钟来源外部晶振
1.png
   B、此处我现在JLINKSWD模式做程序的调试,所以选择如下:
2.png
  C、串口1配置为异步通信模式
3.png
2、配置单片机运行频率按照下图设置为主频72Mhz
4.png
3、在Configuration选项卡下配置串口相关参数
5.png
点开USART1
6.png
就此基本配置完成,现在开始生成TrueStudio工程,打开工程设置设置程序工程保存的路劲、名称、环境支持堆栈大小设置、.c/.h文件独立创建等设置。如下图:
7.png
设置完成,点击如下图标开始生成工程。
8.png
生成工程编译无误
9.png
4、开始编写及设置让你的程序支持printf输出
A、首先我在usart.c中添加如下函数即可让TrueStudio支持printf输出(注意代码必须添加在USER CODEBEGIN xUSER CODE ENDX之间,否则下次设置cube生成会自动丢掉)。
/* USER CODE BEGIN 0 */
#include "stdio.h"
#ifdef__GNUC__
#definePUTCHAR_PROTOTYPE int __io_putchar(int ch)
PUTCHAR_PROTOTYPE
{
  // 注意下面第一个参数是&huart1,因为cubemx配置了串口1自动生成的
  HAL_UART_Transmit(&huart1, (uint8_t*)&ch, 1, HAL_MAX_DELAY);
  return ch;
}
int _write(intfile, char *ptr, int len)
{
      int DataIdx;
      for (DataIdx = 0; DataIdx < len;DataIdx++)
     {
           __io_putchar(*ptr++);
     }
      return len;
}
/* USER CODE END 0 */
就此便可直接通过printf输出数据但是没法输出浮点数,我们可以进行如下设置即可完美支持浮点数的输出。在工程属性下找到C/C++Build --Settings--C Linker--Miscellaneous---Other oprtions 选项空中填写:-u_printf_float即可。到此为止TrueStudio即可支持printf的所有数据类型输出。
程序输出:
11.jpg
效果图如下:
10.jpg

1 [, Y7 ~% l) ?* h. b, t4 A0 ^, Q
高手请绕过。。。。。。。

5 J$ J; i- K$ b3 p& z
收藏 3 评论7 发布时间:2018-7-21 16:19

举报

7个回答
zero99 回答时间:2018-7-23 10:19:43
楼主少了个U
奏奏奏 回答时间:2018-7-23 17:26:32
给楼主加油,马上收藏了。怕下次找不着
Y-D 回答时间:2018-7-24 09:14:48
谢谢,提醒,
steven陈 回答时间:2018-8-4 21:36:34
这个好,有了这个就可以随时输出调试信息了。
zjczm 回答时间:2018-8-22 16:32:02
学习了。感谢分享。
xxx健 回答时间:2018-10-1 01:17:16
本帖最后由 xxx健 于 2018-10-1 09:57 编辑
1 H1 @9 w; W, w8 n: v4 g, q+ p" J$ C1 c, V
感谢分享,但是代码要这样才对:
- r9 N. l# j5 [* q
! A% s  b1 e7 |  W& d& z/ g. I( I7 H/* USER CODE BEGIN 0 */: O7 R% V$ V( g: q% t8 u
#include "stdio.h"% u( T* D2 X% y! w4 @6 P* ~
6 T. Y0 `9 L7 [% o0 K
#ifdef __GNUC__: R" K& `  h% x: Q3 L7 G
#define PUTCHAR_PROTOTYPE int __io_putchar(int ch)
- m5 T4 F& n+ j4 l6 uPUTCHAR_PROTOTYPE3 k8 x; q' w" E) f* ^" `! o
{
5 X( n1 r9 i7 \+ c  // 注意下面第一个参数是&huart1,因为cubemx配置了串口1自动生成的
; J4 o) N; c0 u  HAL_UART_Transmit(&huart1, (uint8_t*)&ch, 1, HAL_MAX_DELAY);
% d" Y" {7 U5 z3 y8 j9 L/ l7 O  return ch;3 c( v- n# }: y! O% T  _# C
}8 G: a& r" R8 m! p2 m* P
#endif
  o% T8 G5 ~6 I8 b, o3 ]2 cint _write(int file, char *ptr, int len)6 ~: e" w# f  V
{
3 ^) A3 Z6 @# m7 ]/ k9 l, k; g      int DataIdx;- \% `2 L- R. U  i
      for (DataIdx = 0; DataIdx < len;DataIdx++)
8 V) V! ]0 G3 K" E0 b, r* l% @     {
6 ~6 Z6 @9 _: |# f( \           __io_putchar(*ptr++);
$ `4 A% }" ^7 Y     }
9 R% J5 i( i8 s0 J      return len;
, h1 K4 t5 E! r/ ?}$ J) E1 o9 A) S( ~4 U. E1 r
/* USER CODE END 0 */0 ]. z& }- P3 C. M- ?) p
我在楼主的代码上加了空格,还有漏了的#endif
# n' M8 W3 y' s, Q6 ^0 |# r9 z& `. p
然后-u_printf_float增加的位置具体是:工程属性->C/C++ build->Settings->Tool Settings->C Linker->Miscellaneous->Other options才对。这样才完整的。  S0 q. |1 m1 c  R
: I' P4 \( W/ X7 u- `& o
% W. B. n% B+ `. G
在Atollic TrueSTUDIO for STM32 9.0.1上测试OK。( \) U# ?8 o3 m& n6 U4 R
5 c) A* {; E, E. @" G9 v

0 D% a# S4 R1 b  L, D0 V: s& V
cjyhero 回答时间:2018-12-19 10:41:15
我在trueSTUDIO 9.1上都添加了,printf任然打印不出日志,直接使用 HAL_UART_Transmit可以输出,求指导
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版