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

【实测教程】STM32L4之串口printf打印实验

[复制链接]
STMCU小助手 发布时间:2023-1-14 18:53
一、开发板平台简介:& ]9 G3 k& e& V" o% E' l" U$ ?. c+ y
1、开发板资源简介

1 E8 a: T% q4 w# R' C(1)开发板主芯片型号:STM32L431RCT6
* A+ @! P9 G# G) g(2)开发板主芯片封装:LQFP-64_10x10x05P: h5 T8 F' s. M
(3)开发板主芯片内核:ARM® Cortex®-M4. T" |9 D3 u- d' e  ^
(4)开发板主芯片主频:80MHz
9 L5 _" Q: g8 }9 m(5)开发板主芯片Flash大小:256KB
+ o* F& J/ L  p8 ~% N9 b( B(6)开发板主芯片RAM大小:64KB) T' f( }) m+ Q& f
' s2 {/ G' ^# ?* q- B( a8 |
bb91345227434ee7a43a34bf3fe366e6.png 6 T0 @! ~- D- Z  [: {" D3 n

' A9 f: o' M% ?
929c0cce04aa4115a8623703982bf3e1.png 0 f2 G$ \7 a) r2 W
9 j! m, c1 ^4 m5 i4 N2 X6 M; @
2、LED灯资源/ [$ {- k' \9 \
(1) STM32L431RCT6开发板共5个LED灯资源,其中一个红色LED为系统指示灯,指示开发板供电系统是否正常,如供电系统正常,红色LED为上电常亮状态,硬件原理图如下图所示:
7 m- ]1 m. l6 o% [: O6 @" ?9 M2 O  _" b9 E
0f177691c5814f16a508bcfa747f87ac.png & o9 R' N& W( o8 \* l6 \: w
7 T: p. S& |6 X! ]' {! X
(2)其他四个LED灯为黄绿色可控LED,高电平点亮、低电平熄灭,计划用LED常亮验证看门狗的作用,硬件原理图如下图所示:
9 }8 V2 G7 L6 C- a  i2 b# j- j" \( p0 T0 \9 ?$ n8 h
e923ad767b8448b7ac37c4ed693724bd.png & ]9 G+ N7 N( R5 X' z: Y$ z: t% l. X

  j9 _/ Y/ W0 D8 I4 r. i​3、串口printf打印工作原理
' X2 e3 ]& L+ A" _ 串口全称为串行通讯接口,即数据在通信线上一次传输一位,按先后一定顺序传输。我们通常所说的单片机串口准确来说应该是串行异步收发传输器(Universal Asynchronous Receiver/Transmitter,UART),使用TTL电平,串口需要RXD、TXD、GND三根线进行通信。
. t. t2 v% Y4 |3 H% P" m
$ l1 `" p( z; X6 ~" w
     (1)我们选用的STM32L431RCT6开发板串口1已通过USB转TLL串口芯片CH340G引出,使用时,只需要用公对公USB线连接电脑即可(注意也得需要安装CH340G驱动),后期验证试验也可使用该串口作为debug串口。
! j; g7 T2 }9 w0 Y' v# D% `1 ~; _  Z8 ?
     (2)开发板上的其他串口已通过排针引出,为TTL电平,通信的时候需要注意选择对应的电平模块,如USB转TTL串口模块等。
, l. W' M% G- l. d

; ^( M8 F! b0 J4 MTTL转CH340串口,硬件原理图如下所示:/ \! {9 ^) m3 I4 g3 P0 {7 C
- k3 H4 G, o3 p
4df1b489cb944c26b55013001061675d.png
7 c# v$ F( ~6 q4 f* K5 G% u; |
3 Y. n4 |) s8 J; \2 ^* `0 b2 w
, R+ w! h2 T6 l/ x* E6 [0 w
  二、串口printf实验过程1 V6 c& d+ c& t. T6 g  c( L4 t
1、新建STM32CubeMX基础工程
& a  n( b6 q$ p# E1 V7 \2 g/ [(1)打开STM32CubeMX,点击“File”-->"New Project"
# ?6 h" |9 [4 }5 `% A; |/ `( Y1 y0 T2 D1 i8 k. }
2399170347904e959c855fefd5877f84.png 0 e" u+ ^5 ~: q- ^( a. s8 V9 I
7 z$ D5 P5 w; v/ O  I" S. v3 B
(2)等待打开主芯片选项界面(大约1分钟时间)。
2 Y( D3 `  e9 A2 U
; f, T$ H- G( H8 g0 F4 X) @7 z
d74d2fdc60c9440483e2b7cf8d928e7f.png
( ]4 H0 q7 o' s+ [! v' I7 ^  A
1 c( i7 m) t  h  s0 L) v0 r(3)昨天搜索框中输入(或选择)所需的主芯片型号(因为我们用的是STM32L431RCT6开发板,所以此处选择STM32L431RC),然后在右下角选择STM32L431RCTx(因为开发板主芯片是STM32L431RCT6),左键双击即可打开新建的项目。
, d% O3 m) |( N
. p1 h, z1 Q% K) s, P8 X: H
7b80345238d74bea82ce70e1a348f7b4.png   _5 R4 V' U( F$ U

% o* h; k0 e& ?& \1 S(4)选择时钟源。
7 w) X3 }$ @9 G$ C% D1 i(1)因为开发板上有8M外部时钟,硬件原理图如下所示,所以此处选择使用外部高速时钟(HSE)。
9 m" D1 G# O; h) Y( K( r3 z# |. P5 ?) N1 u1 U/ Y
3f65707eca104663a3dede6d25dfa961.png % v+ V1 V" Q5 z

0 b& p$ G7 Z" s/ H: p(2)因为我们没有用到外部低速时钟(LSE),此处不做处理,如下图所示。# G2 p! n) e- Z  y6 f3 J( Z9 m1 _; i

, h5 z7 Z' u! W% `
72119b971f62410fa8344f7f9fb9f389.png
1 y1 b3 A6 _7 h0 |

  B' {: l( S' j* F, B# S3 A% R2、配置GPIO控制LED8 P5 q2 z+ I1 {- o. D9 [
(1)查开发板原理图得,LED1、LED2、LED3、LED4的控制引脚分别为:
  k5 z# g" M9 A! t( l5 V- p5 ]8 r- L7 j, Q
LED1——PC0
1 y# ?3 E& f) o+ {' y/ ILED2——PC1
% {9 F) ^3 ^( \8 ^$ fLED3——PC2
9 r% }% \  f6 R, e" ?1 KLED4——PC3
  S: U" p7 X( |8 z: W, P
; a+ M5 k) |4 _3 c: A+ h(2)配置LED的控制引脚为输出,输出频率、输出方式默认即可。' i' h. h( }! H0 @& w* M
5 g$ M9 c( l9 s
鼠标左键点击PC0,选择“GPIO_Output”,表示设置该引脚为输出模式。( }' q& e8 ^( y% m/ K) o0 S
鼠标左键点击PC1,选择“GPIO_Output”,表示设置该引脚为输出模式。
/ J4 ~8 V! o) r- P7 x鼠标左键点击PC2,选择“GPIO_Output”,表示设置该引脚为输出模式。* v, y6 D; S2 h  \. Z
鼠标左键点击PC3,选择“GPIO_Output”,表示设置该引脚为输出模式。) R" f- A# g5 a) ~# C! ?/ `$ Q* z

0 k1 |4 Z* j/ ?1 @  A
492907c1e71149819adbaee4516a2af4.png 1 l& \/ G& z* y' e+ w
6 [. T5 B/ y' a& W5 K* U
c75d3f10ba2e427d9c1a10fad9bf5471.png + Z, i% u" g* w. x! I

% l5 _* I* M9 U! k# U) ^$ F(3)也根据自己的需求配置GPIO的参数,如输出方式、输出频率、上拉下拉等。因为GPIO控制LED的要求比较低,此处采用默认参数即可,不用修改。0 M% Q' Y" D$ H

( c/ i6 N1 w+ E; N2 o
38ff4b80e1c5495ba3076a5158fd91fa.png
6 Z) x7 |, z5 F; y( ^4 H
4 i5 f7 r. y# U, N' h9 @​​3、配置PA9、PA10为串口
9 m6 _4 v  |; R' i查原理图得知,串口1使用STM32L431RCT6引脚为PA9-USART1_TX,PA10-USART1_RX,引脚设置如下:
4 A' M! E! ?3 c* H; I$ G4 y0 |6 @4 b' h7 m/ L3 y
497b8ee0243e446784e64a3c31e8a26f.png
: f: O# N  N6 B4 ^1 Y
! u- v6 X; P) v7 c4 _3 x) V  _! ~ (1)序号1用来设置串口收发引脚的选择。
5 z& R2 ]# ]4 ^: j2 j(2)序号2-3-4-5-6设置串口参数,如波特率115200、8位、NONE无奇偶校验等。4 m2 U4 E5 t, ~
& D2 f' \7 X* o9 y
3、配置项目工程参数7 c1 M6 C$ k5 [
(1)配置时钟树,用于系统内部时钟,以及各个外设时钟等。此处选择外部8M晶振作为主时钟频率,内部最大倍频80MHz。
# t, ?5 E) _9 E1 M) P' ?! ^& p8 N$ Y1 ^
f3ecedd9323f4463b69539906b3c1199.png
0 n* `* g9 W5 Q8 }( R0 h& U
9 N/ d& r. r& j/ Q8 W  Q
(2)完成配置工程。  a9 E  n0 n9 X! C# M
1 ]5 |2 T$ }+ a: |% R; V
备注:需要注意代码生成过程中的继承关系,如图所示:需要保留开发者自己编写的代码时,请根据配置设置,不然生成代码后会删除自己编写的代码(从这个方面也可以看出开发者备份自己的代码是多么的重要。)0 s# H; Z6 [5 \6 _
2 t9 D1 H% A% Z  X# [" l
efdb616174f54925b6eac31109f227b5.png ) C  g; _3 h' N9 Y  E$ `, S/ i! ^8 c
​​% B# I) k: Q8 t8 c
41c3f2716e4e4eda8f62fa3a1d871322.png
/ n8 j1 f) A! g& Z
6 C0 t8 ?0 I: R  [7 L& c# {
(3)生成代码。
& @* \  J! O% b1 U* \* t- j8 {8 _( E$ l$ _, J+ o" C6 Q# P5 }
备注:使用Generate CODE生成工程代码前,请确保文件路径无中文,否则会生成项目失败。4 W! g: ]0 z% M+ Y- V( {5 J

& l: d/ z" Z1 d) H
8eaa7d0babea40ee93f158481a6ee471.png
! r9 D$ x/ J1 o1 O3 b" t) M​​3 E; G7 d( P8 p* f
(4)工程代码生成成功。( i* S# d0 z* H: }  `
" }4 v; A8 b+ e- _( f% h
e8f46d59a1fb4af589feb613fdff17b4.png 3 Z% b" F$ V/ }) e% s" _
; d2 B" j& o4 G$ v- x$ d
三、在KEIL 5中编写代码
+ }) [7 z* R8 n% I( U" l: S1、使用KEIL 5(MDK)打开项目工程文件/ U% M( `# T* s4 E  J  J( p
源码使用说明:使用前必须把项目工程复制到无中文路径的文件夹下使用。
6 g( c% J2 d4 P- M
; K/ o! d( `- a; S+ @& x$ s8 {(1)找到刚才新建工程的存储路径,安装项目名称,打开项目工程.uvprojx。
" w- s% r1 X' n: G- J" X" {, |
2 [% E2 m1 U. Y- D, y" S0 Q
b3dafdc5f39c4af2946ea9b465b779aa.png
7 ~- z! }4 f) L4 P: B
* E& K- }, i- |$ E+ t) I3 ?2、添加串口printf验证程序# j9 J; z9 Q* k( ^! N7 l! d3 b6 |
(1)main.c文件中,初始化LED1、LED2、LED3、LED4默认为点亮,并在while循环中添加控制程序,如下所示:实现每隔500ms后LED1、LED2、LED3、LED4点亮和熄灭之间反转切换,并且串口每隔500ms打印一次。+ [, F! P* [" u) b  i

) B& P% Z5 \+ z- S, y% b备注:自己添加的代码需要在 /* USER CODE BEGIN 3 */和 /* USER CODE END 3 */之间添加,否则STM32CubeMX更新代码时,会造成自己添加的代码丢失。$ B% L5 b/ c* e. Q5 j4 I
' t  W; E5 S2 h
d1194af353cd4b0b88cd9208b1ac7db1.png
" i; x& i4 c: ~; p& c, G6 a) s+ w3 [0 x) F2 ]! Y, H
178a631ceb1b40769861cfa141087495.png * Q' \/ r. ~, g2 B: ]  S( J; V" N3 W. z
  S& R- b+ ?# Z) t. ^
(2)main 函数代码如下所示:
8 g8 O& l, z8 a9 S
  1. /* Private includes ----------------------------------------------------------*/
    # {- a" O8 f! }1 o; C: _+ g# c
  2. /* USER CODE BEGIN Includes */  M* N9 q# X+ Q4 s/ f
  3. #include "stdio.h"                    //添加printf打印函数头文件
    - M5 M" I/ z: D# z; i
  4. /* USER CODE END Includes */
    $ B* `9 l2 W  k2 F# W2 Q9 W; d
  5. ) b: Y* t* g5 [  z  a
  6. 1 k* `: t; J% h! {- b# F4 j

  7. 4 ]/ R! Z2 e( m- ~4 o& {8 ]7 J
  8.   N  _. J" ^1 e
  9. 0 B$ d5 a3 |( |
  10. 9 W1 r# v; Z# e1 Q
  11. * g8 J% h0 A! u- W& _" h7 ~. A
  12. int main(void)
    ) M! C5 b3 N  j: V7 L
  13. {+ ^' S% i; K2 y0 P
  14.     /* USER CODE BEGIN 1 */
    " B" U8 c! O; g1 U
  15. " X! J4 T+ u3 P- c( o/ `! f" Q
  16.     /* USER CODE END 1 */3 P7 W! S* _' h5 \4 m
  17. + E8 Y* c0 D2 v/ I
  18.     /* MCU Configuration--------------------------------------------------------*/
      L( u, `8 O1 U4 o# r/ R
  19. ' m& f; s4 s" `7 q
  20.     /* Reset of all peripherals, Initializes the Flash interface and the Systick. */( i$ r; {) [3 f: Q6 P
  21.     HAL_Init();) o1 \* N2 f2 X, h1 C4 e
  22. * D% R$ ]& ?% k. x+ o
  23.     /* USER CODE BEGIN Init */7 _! L; T. U9 w

  24. ) l% ]# s  f0 B( a$ A
  25.     /* USER CODE END Init */
    4 g5 h$ Q. @: ^

  26. : b+ d' z8 M9 y
  27.     /* Configure the system clock */+ C* s7 K+ k1 q  {9 e+ g
  28.     SystemClock_Config();0 ?; u% R$ o( }- l" F- ^8 O

  29. ' t* n( S) Z/ F2 ?; g, o
  30.     /* USER CODE BEGIN SysInit */
    . z# V( M# ]8 t7 _
  31. 0 x! R2 x$ c- p2 t5 v
  32.     /* USER CODE END SysInit */6 [9 `3 |- \* S3 y9 y$ q8 v- C! k% X

  33. * ?7 s; z( U" W; w" v
  34.     /* Initialize all configured peripherals */
    # p8 {& Z  ~8 o0 N- e
  35.     MX_GPIO_Init();
    6 w+ |" U& o* N  {$ z2 g! X
  36.     MX_USART1_UART_Init();9 I1 c& B& H" k/ o* \" Q$ A9 o1 F( B
  37.     /* USER CODE BEGIN 2 */5 T- z6 ^- N3 ~0 g, D3 T
  38.     HAL_GPIO_WritePin(GPIOC,GPIO_PIN_0,GPIO_PIN_SET);                                                                //初始化LED灯,默认点亮- r/ V1 u6 `" z; `  a
  39.     HAL_GPIO_WritePin(GPIOC,GPIO_PIN_1,GPIO_PIN_SET);                                                                //初始化LED灯,默认点亮
    " J+ L  L" ?0 Q  ?4 t2 B
  40.     HAL_GPIO_WritePin(GPIOC,GPIO_PIN_2,GPIO_PIN_SET);                                                                //初始化LED灯,默认点亮
    ' ]- y! `7 M' [4 `( z
  41.     HAL_GPIO_WritePin(GPIOC,GPIO_PIN_3,GPIO_PIN_SET);                                                                //初始化LED灯,默认点亮  G" F0 C- @/ n; [2 |" m  B
  42.    
    * v7 P0 c/ O: `7 X1 d5 \
  43.     /* USER CODE END 2 */# X" w& f0 k/ ~9 W# q

  44. ( d# \9 {" T% V# ?$ d8 H) b! _
  45.     /* Infinite loop */8 F. X4 ]. j2 E# o) I* W+ ~
  46.     /* USER CODE BEGIN WHILE */! d, D1 O7 E/ k2 N
  47.     while (1)
    0 e: ?( `+ T* ^$ g6 E. z# b
  48.     {. r/ w+ J" g' _- m' W
  49.         /* USER CODE END WHILE */, u% m+ N! i% g% a3 ^9 Y% o
  50.         /* USER CODE BEGIN 3 */
    3 s( a/ M" l: k, h  g# {: V
  51.         HAL_Delay(500);; z) X4 f6 ?: ?
  52.         HAL_GPIO_TogglePin(GPIOC,GPIO_PIN_0);                                                                        //反转LED灯& w% }3 j, \0 ~) O+ k
  53.         HAL_GPIO_TogglePin(GPIOC,GPIO_PIN_1);                                                                        //反转LED灯
    : u6 Z+ m1 P! h- U- _
  54.         HAL_GPIO_TogglePin(GPIOC,GPIO_PIN_2);                                                                        //反转LED灯, k" O& {, K% z2 L2 S* ^1 j6 \
  55.         HAL_GPIO_TogglePin(GPIOC,GPIO_PIN_3);                                                                        //反转LED灯/ O. b/ p+ l7 [
  56.         printf("hello world,this is printf function!\r\n");                      //printf打印, R7 \2 _6 I6 [$ Y
  57.     }
    ' d! c% A& k* D
  58.     /* USER CODE END 3 *// z/ n3 R% v, n; m) e' T
  59. }
复制代码

7 ]4 m# P' H: d3、设置编程仿真下载模式8 i  M/ v, b+ ~8 e
(1)选择Options for target ...>>Debug>>J-Link/J-JTRACE Cortex,点击Settings>>选择Port(SW),可以看到搜索成功SW Device,表示芯片可用,可以下载。+ z! i0 Z/ T' s# U0 Y4 U1 a+ _$ T

" W  i* H4 ?$ |
edefb6b9a2a14be3b1221ad6d5c7a8a2.png
4 @7 c5 L- a' m  A5 U5 r5 }" [, U5 A
(2)点击编译,完成后提示“0 error(s),0 warning(s)”。
% y( n8 U0 O. A9 g+ o
  ~2 W  U- T% {9 T8 N3 E% V4 B4 g
e0b7e3e353b345a7987fe5f821de2dda.png ' F$ y0 `! p8 J7 D7 w9 p% @( H
​​3 A9 n  x& m' v4 i" R
(3)点击Download(或者快捷键F8),即可下载程序。' h9 Q" w4 M8 L4 f
9 H- d' n3 K' r8 G
eb3f250f19e44862a7df80c2492fcd01.png
7 J- L/ z; p7 |$ J​​
) P1 [! t$ `0 h( b1 g+ C
6 q7 H8 {6 b: @, v9 E6 Q" l- }6 |(4) 如果下载程序后,没有看到LED1、LED2、LED3、LED4闪烁,可以按下述方式设置一下(Reset and run表示下载后自动复位和重启运行)。或者重新彻底断电再次上电(或按开发板的Reset按键复位MCU即可)。
( O, n7 ]" b3 Y( E' r+ z
% j9 P: o  E, R: o- j! v* {
9f8aa1a4e8f04041bcf5cb183facd100.png 8 K& F0 Z2 l7 X6 r( l% b  h
​​
$ y* ~9 u/ e& v$ m: D4 c" U( a4、串口printf打印实验效果展示
0 ]) V9 I* J' q7 }0 u/ ?        程序烧录到开发板后,即可看到LED1、LED2、LED3、LED4初始化后每隔500ms闪烁一次,并且打开串口助手后(串口参数:波特率115200、N、8、1),可以看到printf每隔500ms打印一次log数据。# b: V% a. a+ f* W

2 F8 ]" e2 p, U' R, N 06445a6b81d24af4a118aadebfd333de.png
) o! w& V) }) u% C$ @+ Q
9 `0 i0 @, R7 o————————————————
; }( r& y5 [5 ?! B3 |版权声明:智能小屋ZYXC
; m+ l1 v' z4 k7 I( W  g8 L  E% q; n6 k+ Y- O
收藏 评论0 发布时间:2023-1-14 18:53

举报

0个回答
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版