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

STM32CubeIDE的WIFI通信经验分享

[复制链接]
攻城狮Melo 发布时间:2023-4-7 15:08
一、stm32的WIFI配置6 n. C. v# Q* k0 H/ Y
        通常WIFI模块就是一个独立的单片机,只是内置了WFIF通信软件的单片机,并该通信软件提供了AT通信指令集给开发人员,基于这些指令集我们就可以针对项目需要进行二次集成开发出所需的业务应用软件。
1 y5 f/ f0 E/ p* _& `0 X/ l
$ B4 D9 e' {$ M$ x
        本文本文采用的开发板是stm32L496VGT3,该开发板的MCU及WIFI模块(MW31)硬件电路图如下:2 C. w* [) `6 Z6 d& j

8 H/ O( p8 u, A! l& @3 P0 }        MCU采用PC4、PC5连接WIFI实现通信,PB0、PB1作为辅助控制。- _  k* G2 U6 i! e

+ ~+ F; W$ H- o) G
d0dfa03d396047499c57c8f5a8ad06d7.png $ S+ t* M3 s9 a7 s) m! l' \8 K
7 V3 E# P4 p9 f8 E% z' q
WIFI模块给出了两个通信接口,一个用来连接MCU(电路板已经连接好了,本文就采用该接口实现MCP串口通信控制WIFI模块),一个用来给外置使用。
% n. S9 ~. B2 ?) l# a. A$ w8 h3 x% c) ~  c" c% z
99bba58bce1b452490dc250168d45cfb.png
) z, w7 U' Y8 N& q# N6 b% ?# A" K! C5 |( Y$ k; y* p3 \
与WIFI通信关联的MCU的IO端口设置要求,开发板给出如下:; p% }  `$ q! G: [' @
3 G- p  y. j. M$ [' Y% i) L
f8e3ff7fe3934d8e9fef03f1cfe49d8d.png
; T; E- k& T2 B- o
  R: x6 g6 \  t         以及各个IO口具体参数要求
. [7 ]- m' K/ e+ Q, J7 w: S$ |
& v9 q1 R( G8 v- v# Q2 {
ee5109a3a7214726a6a7d5b02bcb7da4.png . E: h7 r& R$ C
; C6 k' J5 q% z+ r
         打开CubeMX配置页面,按上述要求设置WIFI配置通信接口USART3:
& {8 Y% N: M* H8 F5 `- |4 s) A, l. Z3 d! u8 Z: {2 `/ w6 s
f7387884706e47dabc01717c21fcbffc.png
" J( b) l( t% O7 [& B/ C) \8 Z" O" q- f
         开启USART3外部中断功能:+ ~$ b$ d, A5 E- Z
/ R8 j) T! O/ q6 X
68aa2fdb1ed749138e8f932b78947a78.png : V: @5 l/ R9 d6 w
- s) A: n- h9 _7 W' h( p0 P
         设置PC4、PC5的IO接口参数# o  `7 v, s" k0 a: E5 u

2 F  u9 f9 f- e0 Y( W! E  @
a23de988873f4b8c8645b2a5fe61ae18.png   W1 s0 p; b' n0 Q- A: I3 j+ r  C

. R8 v) o" C& g         同时芯片图形化配置页面设置PB0、PB1为GPIO_OutPut模式,并进入GPIO配置页面,设置PB0、PB1的IO接口参数:4 }! A( \* N1 |+ C. ]; d9 K+ t; k
  j- a7 P7 l$ d3 s
3d67266a85744e0ebfc4ef63abf704c3.png * H7 k+ k* A+ B+ p% }6 }7 z
; y4 Q9 n! f. |' q/ S" Z
          完成配置点击保存按钮或代码生产按钮生成代码:
3 Y5 i+ |+ P! n) W. E5 R) s3 a1 H" B2 K" A0 W' }( x$ I
557d3788476c48f193e40d4bde41a7fa.png 4 T& V2 ~0 i# ?# ?( u* f2 l
7 K/ C3 o% }4 d% ~8 J0 J& ]9 m1 t
$ [4 g- i$ o" ]9 l
二、代码设计3 Y, Y  e+ G* M, P7 L' J
        本文基于前一篇博文的串口通信能力基础上来实现的,即已经完成了printf函数映射到lpusart进行串口通信
- I8 H4 }: V' s/ I5 a( b1 Z7 D+ I, k5 A* `6 y6 @6 ]+ N, x
         我们先实现串口USART3的接收回调实现,在改写ICore目录下的usart.h、usart.c代码文件:0 a6 x1 K; M7 q6 G5 B. {* Z+ `
4 M+ e* X' q; h
        usart.h内容如下,类似lpusart串口添加了串口USART3的接收辅助变量:
  1. /*
    9 q' M: w# Y' e3 [
  2. * usart.h4 l' L" I* }6 q8 v( r; |% C1 E0 p
  3. *: r* @9 Y5 j6 Z1 ^
  4. *  Created on: Oct 20, 2022
    8 A$ X; Q$ i+ A$ G
  5. *      Author: Administrator
    ' |8 j+ h/ @6 M2 k: ]
  6. */
    & K7 w/ z0 y3 c( N
  7. ' m& ~9 b" e) Y0 ^7 J, `( p+ g0 O
  8. #ifndef INC_USART_H_
    : y+ q  u7 c+ j/ G
  9. #define INC_USART_H_
    $ E& D* `* m4 h* N4 A! b  h

  10. 2 r" u* F" Y5 x- g. o
  11. #include "stm32l4xx_hal.h" //HAL库文件声明% V6 I+ v9 x2 W2 C' s
  12. #include <string.h>//用于字符串处理的库
    $ c- }- h# J0 h
  13. #include "print.h"//用于printf函数串口重映射) L9 v0 L: T! G! X5 }
  14. 1 M5 }3 [/ e6 p( _6 O5 y. ^2 [9 v
  15. extern UART_HandleTypeDef hlpuart1;//声明LPUSART的HAL库结构体
    ) [& Y: b( S9 R. P" @4 u! o
  16. extern UART_HandleTypeDef huart3;//声明USART3的HAL库结构体2 e/ ?3 V. \6 P6 V
  17. ; O( e6 J5 a4 L2 O* A0 v' ]
  18. #define HLPUSART_REC_LEN  256//定义LPUSART最大接收字节数6 ~# }' O+ Y" N  \6 v
  19. #define USART3_REC_LEN  256//定义USART3最大接收字节数
      P3 S+ s% I5 j7 {' ]
  20. $ j+ S7 J+ a# j3 N( Z$ Y2 M. G
  21. extern uint8_t  HLPUSART_RX_BUF[HLPUSART_REC_LEN];//接收缓冲,最大HLPUSART_REC_LEN个字节.末字节为换行符7 D; U! \6 @- g! C: ?% P2 m
  22. extern uint16_t HLPUSART_RX_STA;//接收状态标记
    & V$ O2 G/ X5 Y- X9 `- [6 a
  23. extern uint8_t HLPUSART_NewData;//当前串口中断接收的1个字节数据的缓存) d/ Z. n0 Y5 S1 E0 k

  24. 3 W8 y5 q- A0 w5 ~! ^
  25. extern uint8_t USART3_RX_BUF[USART3_REC_LEN];        //接收缓冲,最大USART_REC_LEN个字节.
    ! j& Q; d+ ~' m1 }+ _% a( ^
  26. extern uint16_t USART3_RX_STA;                                //接收状态标记,bit15:接收完成标志,bit14:接收到0x0d,bit11~0:接收到的有效字节数目
    : M5 L* k) r5 I+ ^! n5 r( H$ n
  27. extern uint8_t USART3_NewData;                                        //当前串口中断接收的1个字节数据的缓存8 |. p( c- |( `0 _$ [, V

  28. ( m7 ~' _) f0 R3 b5 n
  29. void  HAL_UART_RxCpltCallback(UART_HandleTypeDef  *huart);//串口中断回调函数声明9 ?5 M% O7 y3 q9 Y  j9 a) S

  30. 1 X6 ^  M3 a$ M; D2 e9 O
  31. #endif /* INC_USART_H_ */
复制代码
/ c+ t) y5 r0 r8 D
        usart.c内容如下,添加了USART3的回调处理,实现接收来自WIFI模块的数据,lpusart和USART3的回调处理几乎一样的,主要就是接收到一个数据,就缓存起来,并再次开启中断接收;在接收到回车字段或缓存溢出是,进行标记(HLPUSART_RX_STA和USART3_RX_STA的前四位可以标记,后12位为数据长度记录)改写,该标记留给外部调用来处理,不再回调函数中进行接收标记复位:
+ {3 s" w7 t" G7 q; d- k& D1 g
  1. /*7 |3 n) N$ n7 c) W# {+ E
  2. * usart.c& ^0 U' H9 P' |6 Z7 c
  3. *
    ( k$ D  N5 q% P2 O
  4. *  Created on: Oct 20, 2022( h+ d8 }3 Y8 j, P
  5. *      Author: Administrator
    ) e# h$ A# O6 N; ^9 t9 U
  6. */
    5 S; H8 j3 [, Q6 x4 j( W
  7. 5 v- K9 A- J2 h; g3 r1 `" I
  8. #include "usart.h"3 a: Q  X! H, ~9 E1 T2 ^
  9. #include "wifi.h"
    . T6 Z- T% _, D

  10. 4 L& K0 }, j5 t
  11. uint8_t  HLPUSART_RX_BUF[HLPUSART_REC_LEN];//接收缓冲,最大HLPUSART_REC_LEN个字节.末字节为换行符
    1 Q. F8 Y+ w% l% Y; ~7 `" U
  12. /*
    . G/ z1 h1 \( g1 O% `5 D" k
  13. * bit15:接收到回车(0x0d)时设置HLPUSART_RX_STA|=0x8000;
    ' I6 n8 [# q5 Z" `# T  t
  14. * bit14:接收溢出标志,数据超出缓存长度时,设置HLPUSART_RX_STA|=0x4000;) z4 k( c7 q" _1 ^  j
  15. * bit13:预留2 Y& W( |8 V  D) x6 m: h
  16. * bit12:预留
    % J3 r$ N/ \. G1 i6 l8 v( U
  17. * bit11~0:接收到的有效字节数目(0~4095)
    ! o' i6 P4 j$ o* ?3 }
  18. */0 W3 t. U' s3 d% l# J
  19. uint16_t HLPUSART_RX_STA=0;接收状态标记//bit15:接收完成标志,bit14:接收到回车(0x0d),bit13~0:接收到的有效字节数目
    7 m8 A1 ~' Z4 Q
  20. uint8_t HLPUSART_NewData;//当前串口中断接收的1个字节数据的缓存6 o+ F; d' t4 |& C# Q

  21. ( Q" X. Q% T& q, t
  22. uint8_t USART3_RX_BUF[USART3_REC_LEN];        //接收缓冲,最大USART_REC_LEN个字节.4 X$ P  A# k/ V, ?* l
  23. uint16_t USART3_RX_STA=0;                                //接收状态标记,bit15:接收完成标志,bit14:接收到0x0d,bit11~0:接收到的有效字节数目
    / q3 `9 h, T5 U+ B3 p
  24. uint8_t USART3_NewData;                                        //当前串口中断接收的1个字节数据的缓存. a& h( N0 n$ N7 H3 G2 y
  25.   e7 B. U5 C# P1 G5 ?8 }
  26. void  HAL_UART_RxCpltCallback(UART_HandleTypeDef  *huart)//串口中断回调函数$ ]' `& m/ z# o' H
  27. {
    4 N& y1 u8 j. A
  28.         if(huart ==&hlpuart1)//判断中断来源(串口1:USB转串口)4 {' o5 B' Q* w4 t
  29.     {
    " A  _* q- H' S
  30.                 if(HLPUSART_NewData==0x0d){//回车标记
    % X0 T) R7 H  C" z" d" j( b$ s
  31.                HLPUSART_RX_STA|=0x8000;//标记接到回车. m8 G0 _. r) n" [1 i; A
  32.                 }else{2 U- ]) L% j1 V
  33.                         if((HLPUSART_RX_STA&0X0FFF)<HLPUSART_REC_LEN){9 b8 p7 t1 W# N
  34.                                 HLPUSART_RX_BUF[HLPUSART_RX_STA&0X0FFF]=HLPUSART_NewData; //将收到的数据放入数组5 q8 R) E7 d; u, x
  35.                                 HLPUSART_RX_STA++;  //数据长度计数加1. Q4 g) N$ [+ d
  36.                         }else{
    ' O/ G" |. m+ |# K; r
  37.                                 HLPUSART_RX_STA|=0x4000;//数据超出缓存长度,标记溢出
    7 @4 O. S2 [* k% b  P# u, e2 ~1 n
  38.                         }) W, J6 }7 J8 y
  39.         }6 D. X. @/ ^! @7 ^7 f* g1 c
  40.        HAL_UART_Receive_IT(&hlpuart1,(uint8_t *)&HLPUSART_NewData,1); //再开启接收中断( j  p. K1 _2 m3 n
  41.     }6 S; L/ ~" e- \% s8 S
  42.         if(huart ==&huart3)//判断中断来源(串口3:WIFI模块)
    , F, f( I5 M% k. X+ h) ]0 z0 C
  43.         {
    : ^+ R2 L. M' z9 I! v
  44.                 if(USART3_NewData==0x0d){//回车标记
    1 t: ]! v1 n6 _  j+ h" A/ ~0 G
  45.                         USART3_RX_STA|=0x8000;//标记接到回车
    , [: Y( x' ]( f1 |
  46.                 }else{# y0 v9 k7 \/ F, Z% ]
  47.                         if((USART3_RX_STA&0X0FFF)<USART3_REC_LEN){
    3 |$ Z1 X, L' h
  48.                                 USART3_RX_BUF[USART3_RX_STA&0X0FFF]=USART3_NewData; //将收到的数据放入数组
    8 K; `" W0 E& ]. u3 G/ H) f
  49.                                 USART3_RX_STA++;  //数据长度计数加1
    ! N: F. `. _* ~; g) Q7 B3 ?: G
  50.                         }else{7 l$ |7 Q5 R! p
  51.                                 USART3_RX_STA|=0x4000;//数据超出缓存长度,标记溢出
    ; {! b2 S# h! P* \) A
  52.                         }
    ( b) h* Y" z7 r4 [# k8 F
  53.         }7 a' r4 g# F' D" ~/ p2 d, a
  54.                 HAL_UART_Receive_IT(&huart3,(uint8_t *)&USART3_NewData,1); //再开启接收中断  [' z$ f( J+ G5 T. T" Q) i
  55.         }  m' c7 _; A! S/ Q1 |- B
  56. }
复制代码
( T3 L5 f6 R9 U
        在ICore目录下创建wifi.h和wifi.c源码文件实现WIFI驱动:; {" }7 h+ w% y( `. J5 E1 F" h

) J: W' }" y, `3 \2 T. W( n        wifi.h内容如下:5 a1 F0 u3 w  u6 |
  1. /*& |/ j* H+ g6 k5 e( v4 n0 g
  2. * wifi.h
    7 \5 Q/ l; c, ^
  3. *
    " J3 B: V0 {9 W8 E. P# h1 A
  4. *  Created on:- P3 q- Z/ K4 ~
  5. *      Author: Administrator7 q" Q! b! P7 L' ~! x9 d& B
  6. */
    0 K4 o1 q" k$ Y3 h3 d* V1 X
  7. 9 P! x( K( G0 f8 }
  8. #ifndef WIFI_WIFI_H_
    6 `- R* R! k% \' C$ X( F# l. f
  9. #define WIFI_WIFI_H_
    * }; C5 R6 G9 \
  10. $ g3 ]( d6 m2 |- h  l! y1 a' ~* L
  11. #include "stm32l4xx_hal.h" //HAL库文件声明+ A- H" n6 @' P6 q% d
  12. #include "usart.h"
    2 e& n1 S4 o( c5 `) B# L
  13. #include "main.h", H" F3 S, l' [, ]
  14. #include <string.h>//用于字符串处理的库; }7 `# k2 q) }! i
  15. #include <stdarg.h>) K# S; g( J# R& H, L" w( f* J
  16. #include <stdlib.h># @7 x2 _8 m# n; y  u
  17. #include "stdio.h"
    . r' o- {3 ?5 H& P
  18. ( \7 \8 ?4 h% w2 Z5 p
  19. extern UART_HandleTypeDef huart3;//声明UART2的HAL库结构体$ o( O0 N, N2 r5 K- U  ~
  20. / ~' [6 _: @- h' ?& h* [0 ~$ f
  21. void WIFI_printf (char *fmt, ...); //WIFI模块发送% L: N8 J6 G# N/ @" j5 x
  22. void WIFI_TCP_SEND (char *fmt, ...);//在TCP模式下的发送数据(不处理返回状态的盲发)
    & ]9 q  F6 J; X6 s( \  l

  23. 9 J, w: w# E& M1 Y/ {
  24. #endif /* WIFI_WIFI_H_ */
复制代码

5 n9 j, g7 |, T        wifi.c内容如下,本质上就是调用HAL_UART_Transmit函数对huart3句柄进行写入数据操作,实现发送数据到WIFI模块:
- }5 m8 B6 P9 w1 @! B9 u. ?
  1. /*# \/ z/ {7 m! Y* _9 W: L' h; ~* }
  2. * wifi.c
    ' y9 i" Z. b+ X% d
  3. *9 H: P' n6 D; e! _  M( b
  4. *  Created on:
    8 n6 J( c8 V4 W
  5. *      Author: Administrator5 t/ j, O  l+ u1 ^- y
  6. */9 R4 @: W4 K( k% w1 r9 C
  7. 1 j/ _1 w5 V, @: F/ S5 q' q
  8. #include "wifi.h"
    - ~) x- k3 \2 H/ {$ e

  9. " `% T1 k/ x5 ]6 b
  10. //WIFI模块通信,使用UART3,这是专用的printf函数
    : Y: d+ r  h7 u% x3 E" Z
  11. //调用方法:WIFI_printf("123"); //向USART2发送字符123; c2 L1 ]! _! F6 l0 c
  12. void WIFI_printf (char *fmt, ...)
    % [* m% {" u8 Y' d
  13. {8 A* R; n, V0 w# A7 z  b# l
  14.         char buff[USART3_REC_LEN+1];  //用于存放转换后的数据 [长度]- j3 O) @2 m$ U0 L" i
  15.         uint16_t i=0;
    0 t- Y) W4 M+ _" G3 G7 p; @
  16.         va_list arg_ptr;
    * R+ h1 ^# ~5 G4 f" B4 ~  _
  17.         va_start(arg_ptr, fmt);, X8 j: t) a  k# I
  18.         vsnprintf(buff, USART3_REC_LEN+1, fmt, arg_ptr);//数据转换. M1 S7 N) c+ K5 J3 _2 r) r
  19.         i=strlen(buff);//得出数据长度. ~* y8 E8 q" B3 L, {+ D
  20.         if(strlen(buff)>USART3_REC_LEN)i=USART3_REC_LEN;//如果长度大于最大值,则长度等于最大值(多出部分忽略)
    + i. y7 _7 i1 H0 a) k# Y4 G6 J+ Q
  21.         /*HAL_StatusTypeDef ret =*/ HAL_UART_Transmit(&huart3,(uint8_t *)buff,i,0xffff);//串口发送函数(串口号,内容,数量,溢出时间)
    ; M+ w% v/ I" E7 r, _
  22.     //printf("WIFI_printf Len:%02d\r\n",ret);
    ! c. u( Q5 q1 \, p4 M
  23.     va_end(arg_ptr);
    * i! `3 w) A% P3 o" C! n) w
  24. }
    6 V, f! ^/ V* e9 {( M
  25. //WIFI模块在TCP模式下的数据发送:TCP发送的规定是先发AT+CIPSEND=数量,等待返回“>“后再发送数据内容。
    8 X1 I3 E3 U4 u/ U' K0 x
  26. //调用方法:WIFI_TCP_SEND("123\r\n"); //TCP方式发送字符123和回车换行
      y/ f& k; W* q: F* ~
  27. void WIFI_TCP_SEND (char *fmt, ...)& Z5 p. i5 W6 O+ ], p. E$ }" l4 t5 F
  28. {
    4 A8 y6 V% S( R' w7 D7 }) W4 o  t
  29.         char buff[USART3_REC_LEN+1];  //用于存放转换后的数据 [长度]
    " D5 c. |. t8 \
  30.         uint16_t i=0;, n( c0 P+ C8 T0 m9 R- B4 b/ @. o
  31.         va_list arg_ptr;0 [% E9 I4 z6 u, \: q
  32.         va_start(arg_ptr, fmt);: k2 N& c4 e+ H3 s7 r
  33.         vsnprintf(buff, USART3_REC_LEN+1, fmt, arg_ptr);//数据转换
    8 ~7 u" B0 e9 V$ b2 h
  34.         i=strlen(buff);//得出数据长度, Z8 C$ z4 B" h1 \6 F9 p1 i
  35.         if(strlen(buff)>USART3_REC_LEN)i=USART3_REC_LEN;//如果长度大于最大值,则长度等于最大值(多出部分忽略)" `. G8 l, P7 L. G: T
  36.         WIFI_printf("AT+CIPSEND=%d\r\n",i);//先发送AT指令和数据数量- i* [2 S" i1 i+ s3 H, \
  37.         HAL_Delay(100);//等待WIFI模块返回">",此处没做返回是不是">"的判断。稳定性要求高的项目要另加判断。
    % u/ v- p! N: s. i) x" f
  38.     HAL_UART_Transmit(&huart3,(uint8_t *)buff,i,0xffff);//发送数据内容(串口号,内容,数量,溢出时间)
    + D" m0 W6 E7 F0 c' M1 E
  39.     va_end(arg_ptr);; s; c! }, Q" s! `+ ]# o" r' p' P
  40. }
    4 x$ }  n) s& M& b: W( u) ]
  41. . e8 b3 B, M* v+ T+ {
  42. //所有USART串口的中断回调函数HAL_UART_RxCpltCallback,统一存放在【usart.C】文件中。& v; M7 t# Z2 W6 f- q
复制代码
* ^! O4 H5 T9 X0 {: g: }
        在main.c文件添加WIFI通信实现代码,main.c部分内容如下:. T' A$ r1 N" r! w6 |! A
  1. /* USER CODE END Header */
    # i* q& n5 F% c; m% W% h
  2. /* Includes ------------------------------------------------------------------*/
    ! K0 @/ @; N0 I
  3. #include "main.h") K7 f' M* p2 J; \  J& J, A/ g
  4. #include "usart.h"
    ! c; u+ r, T9 f& N
  5. #include "gpio.h"
    + U7 ~7 k3 h! Z% G
  6. 5 B: T1 ~5 ^& a' z" D
  7. /* Private includes ----------------------------------------------------------*/' D& g' W  d& l5 L
  8. /* USER CODE BEGIN Includes */7 Z8 d' A9 }: t/ ?" M
  9. //用户编写1
    - @4 v5 A9 m4 u" @! H# Q2 L
  10. #include "../../ICore/key.h"
    ; x& |2 a( V" ]2 ~7 J
  11. #include "../../ICore/led.h"; v  u1 O4 I! K; _) y
  12. #include "../../ICore/print.h". v! L, s! i) L# R( u
  13. #include "../../ICore/usart.h"   //添加串口usart3接收回调实现的头文件. a+ U, z- }5 e$ H8 k5 U+ |
  14. #include "../../ICore/wifi.h"    //添加串口usart3写入数据实现的头文件, D: u$ I3 S9 D1 e8 ^2 W2 u
  15. /* USER CODE END Includes */
    ! ^! @, P0 T2 o  A) O

  16. 7 ~4 @9 B/ b' }4 q3 t
  17. /* Private typedef -----------------------------------------------------------*/2 }1 `4 z3 S" V8 n9 t& C8 z
  18. /* USER CODE BEGIN PTD */' ?- _0 d: H  @" J
  19. & {: o. h8 E9 ?& q$ L
  20. /* USER CODE END PTD */
    1 j6 T8 U4 L2 Z) }* d
  21. 3 `5 |1 g" t" ]! @5 w- G
  22. /* Private define ------------------------------------------------------------*/
    3 U; Z8 @) q  }6 `( x% D
  23. /* USER CODE BEGIN PD */
      b& R; ]* Y8 x9 \( |' R
  24. /* USER CODE END PD */* M: J$ {) ^3 L# g
  25. / u+ I/ l- |0 U4 ?
  26. /* Private macro -------------------------------------------------------------*/6 s# R$ e. s4 ^" y: M; C
  27. /* USER CODE BEGIN PM */
    5 g% E, y5 {1 ?' p. ]  v) z7 S

  28. 2 N; \9 B0 G) f" }' D
  29. /* USER CODE END PM */( W  U# }  u' |

  30. " j# R3 H# |6 A/ s
  31. /* Private variables ---------------------------------------------------------*/
    / S8 A  o" ~5 `5 w1 _

  32. ( l7 a) Z5 M0 a  @0 N0 ^
  33. /* USER CODE BEGIN PV */' i: f& ?4 G/ x* a

  34. 6 {, I7 X4 `2 K) f& J, N# |) S
  35. /* USER CODE END PV */
      F; F$ L3 ]6 P0 O9 r) M

  36. 0 d4 m# |& W/ {. }$ c
  37. /* Private function prototypes -----------------------------------------------*/$ C0 R4 i: B! f& m$ e. _, s  q
  38. void SystemClock_Config(void);
    $ V4 O  w  A( l
  39. /* USER CODE BEGIN PFP */- X8 K1 S% T. z: O. _5 e' J2 L
  40.   A# i, I8 \# R$ [
  41. /* USER CODE END PFP */( K) l9 b3 N# f6 q- m/ X
  42. 1 @* P- Z8 V" G: \  \9 e7 v6 y( |2 s% ?
  43. /* Private user code ---------------------------------------------------------*/
    # @* i9 Q9 n2 H' f' `
  44. /* USER CODE BEGIN 0 */% H8 y+ Y: O0 U" X/ [

  45. $ B/ v) w& y$ D, X) a2 Z
  46. /* USER CODE END 0 */
    ' I& n. U, O: d, l* C

  47.   }2 R, _& O% @: `
  48. /**
    2 H& z* S5 Q$ |6 v
  49.   * @brief  The application entry point.
    6 F- M* T+ K8 H2 |
  50.   * @retval int9 q( q& m9 S3 m2 S
  51.   */. Y* F$ `& k- s# F* B5 Z
  52. int main(void)6 R3 ]3 V  }% N7 T0 m5 A9 z
  53. {' B) @, `* M/ ]! B+ Q# j' j- S
  54.   /* USER CODE BEGIN 1 */0 h$ F3 T" |% ]1 q. p' z) f" [
  55. 1 n- o: L: |  g2 S' L3 e* _
  56.   /* USER CODE END 1 */
    . C& i/ k4 _- ~" e  k

  57. 9 H5 Z7 P( E1 t, _* G
  58.   /* MCU Configuration--------------------------------------------------------*/
    / f. y% D* I/ I3 y# J

  59. ; |. u8 X0 }9 x* z: g" W$ |! O" m
  60.   /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
    5 M/ L" h. x* g2 H& S! o2 P9 t) w
  61.   HAL_Init();
    1 x8 m, X4 D$ h

  62. 6 o; K; k( |; Q% t
  63.   /* USER CODE BEGIN Init */; O( C8 e- p) _5 N3 m
  64. % y- r: k( k/ N& @( p
  65.   /* USER CODE END Init */
    - Y/ @( ^, f' U+ U) w+ Z0 W( f

  66. # j& Q  J4 o2 N; V# h
  67.   /* Configure the system clock */* K; j! w: f/ j& o, L6 t. X. r
  68.   SystemClock_Config();
    2 N1 c0 Q1 ~7 N( S

  69. 5 H8 L, j9 c1 h+ e3 _1 _
  70.   /* USER CODE BEGIN SysInit */1 I" x3 ]" N8 _; `) T" a! b5 c

  71. 2 I/ U1 H) k7 D' {  c: i# P
  72.   /* USER CODE END SysInit */. _( U4 v6 p2 |$ Z) b$ S

  73. + \9 ~: U  G! N5 [1 b* r- ~
  74.   /* Initialize all configured peripherals */
    7 @0 w0 \+ J9 M: z+ z  Z6 K# e. w
  75.   MX_GPIO_Init();
    6 b4 @" p8 e0 A+ L5 k$ L
  76.   MX_LPUART1_UART_Init();
    2 T. l! j, V1 v
  77.   MX_USART3_UART_Init();  t: M# j" Z, u- c
  78.   /* USER CODE BEGIN 2 */
    ( {- V/ E4 d. ]8 d
  79.   //用户编写2
    3 [' x  _5 L# j) }* [8 \
  80.   ResetPrintInit(&hlpuart1);
    . D2 K' ^$ C# D
  81.   HAL_UART_Receive_IT(&hlpuart1,(uint8_t *)&HLPUSART_NewData, 1); //再开启接收中断
    / ^) F) e) L9 K; F+ {: _. g# ?
  82.   HLPUSART_RX_STA = 0;
    4 b! F2 k8 k2 M( ^
  83.   HAL_UART_Receive_IT(&huart3,(uint8_t *)&USART3_NewData, 1); //usart3开启接收中断3 h! }1 V7 [: `5 P
  84.   USART3_RX_STA = 0;1 a+ W3 j9 I" Y) z3 G' G
  85.   set_led0_val(0);
    ; ?1 k1 y+ ]9 P0 m. y$ H9 _
  86.   set_led1_val(get_key0_val());# _( \* q4 J1 w9 p
  87.   /* USER CODE END 2 */4 c% m6 [  \# L6 }4 r5 E" ^1 z

  88. 6 {( w( I' Z# D% E8 ]
  89.   /* Infinite loop */1 l+ E/ X' ?: @" J& _
  90.   /* USER CODE BEGIN WHILE */
    * D1 \" E9 c- i
  91.   while (1)" T9 n0 w/ [  P/ ?1 |  A. p
  92.   {4 z% L- g* `( v2 j
  93.     //用户编写3$ t; _6 Z% u* E
  94.         //接收到电脑发送给(lpusart)数据,转身将其发送到给usart3,进而实现送数据给WIFI模块
    3 A- L9 S$ Y  ]/ O) W& P- F* H
  95.                 if(HLPUSART_RX_STA&0xC000){//溢出或换行,重新开始
    ! ^( ], P& k6 o3 C& Y; g0 a
  96.                         WIFI_printf("%.*s\r\n",HLPUSART_RX_STA&0X0FFF, HLPUSART_RX_BUF);
    / u; t" V" B6 q5 N9 n
  97.                         HLPUSART_RX_STA=0;//接收错误,重新开始# E  Q, [& X; M- J: e
  98.                         HAL_Delay(100);//等待
    9 \5 o9 Q$ A$ B4 z6 j* A0 J3 b
  99.                 }
    2 L8 o* G, u; H1 n6 J3 Y
  100.         //接收到WIFI模块发送给(usart3)数据,转身将其发送到给lpusart,进而实现送数据给电脑终端/ w  a! T" N& y8 i' o/ ]
  101.                 if(USART3_RX_STA&0xC000){//溢出或换行,重新开始0 ]* s1 z9 ]4 i5 X1 O+ [
  102.                         printf("%.*s\r\n", USART3_RX_STA&0X0FFF, USART3_RX_BUF);
    : k* |6 Z& S7 ~, u
  103.                         USART3_RX_STA=0;//接收错误,重新开始) ^# _  _/ @7 b4 P4 o' V- D# {
  104.                         HAL_Delay(100);//等待5 L8 t) ^! L5 Y4 W7 }/ g
  105.                 }8 u8 X( j- ^4 \# S( y# M- l  B
  106.     /*
    3 X% s) `  Z0 S0 e% @0 Z( m) p
  107.           if(KEY_0())//按下KEY0判断
    8 w% j0 e% Z" V- t% |' a
  108.           {
    9 e7 h, ]. s" V7 K7 u4 h
  109.                   printf("KEY0被按下\r\n");
    & k- {" @3 }  w' b
  110.                   WIFI_printf("AT+UARTE?\r\n");//发送AT指令- R8 V5 |: S; h# B4 q, ?
  111.                   HAL_Delay(100);//等待
    % G% m' A; q9 H' G
  112.           }
    4 A0 N5 w) s. }" g1 X- o( G! w/ ]
  113.     */$ I- t3 ^% M  c& K' K! X

  114. 3 h7 M9 X' n  g/ u; `
  115.     /* USER CODE END WHILE */  i  g! E+ I4 h  e! O9 B$ b; u

  116. 0 R: _+ d, d7 W* j' M' Z, U
  117.     /* USER CODE BEGIN 3 */) r1 q1 G" Y5 `( a0 T6 \
  118.   }
    , U, M3 z5 i, S. C% ]1 v/ s
  119.   /* USER CODE END 3 */, b* }2 s# R/ W0 C' @. j5 s/ k
  120. }
复制代码
+ U2 d$ W9 K* q! h0 x$ Z3 P# K
三、编译及测试9 q! X2 |) ]1 e2 P! `8 B
        点击编译及运行按钮,, i* z1 \2 Y4 Z- q0 l# n, V$ W

7 c7 j2 U! y) U1 W) G
76edc5d8973a4353a22d862a1dfee32d.png - n& ]: V, t$ f/ N" C, F

1 T9 [' z2 z' y8 S4 c
. C/ y* E7 ]8 n0 b
         如果编译及下载无异常,采用串口助手连接开发板,本文将开发板作为Station 模式连接家里的路由,设置账号密码及查询是否成功:
/ ^% k) P% q0 K0 q8 z' i
1 o& ?, F5 v3 h' S1 o+ ?: z, \
13c125dce2994d678897f00375ed1584.png
7 P% F/ |+ q/ A6 Z7 P
1 N: ^6 n* j) W8 a# C; g% G* d& l
32e595f3a73b486cad08a7610c64d993.png
$ @* A! L" U  U
' n! X" D8 Q: P/ D, F: E3 ~! _+ }3 G 测试运行结果如下:
. i- U3 o" T( }' e* B3 R4 u* w9 J
f072771e64914b50822fc3c2ea7f3d69.png
: d! o4 }# N4 j  m" c6 H6 y: [
7 N4 {! n9 L2 B0 c, v% {% ^
         访问家里的路由控制界面查看如下:
: ^% L  M7 o* R0 n2 _
7 J5 s, M" k- Q' `6 a5 Y' w+ l
9f85f15d0244403c892a10888c57089e.png
5 L- @* V5 Q5 p/ ~. Y' M+ k2 I, I# |2 V7 l( V9 f
  R& J5 Q& z2 F% y" S' n
四、关于WIFI模块的串口应用- e. Q2 x( ?2 V2 d% n6 G: G
        通过上面的实现,市面上大部分WIFI模块都能适用。只要AT指令能直达WIFI模块,无论是从MCU还是从电脑端,对于WIFI模块的操作就是看AT指令支持的情况及我们对AT指令的组合应用,可以实现项目开发中各种对WIFI使用的要求。当然在具体项目中,对于WIFI模块的选型就是看他们WIFI模块给的AT指令能否直接或间接组合满足项目要求。- Q6 {0 y. T! W8 S
! N3 R3 M6 |9 n& Z6 Y, S$ K$ @) _
        2022-11-21补充下面给出MW31模块的AT指令及部分测试演示。
6 b+ i' x* A! ?* Q' T9 n

1 i. H) x2 q  F9 }& K; c! {; h% [" ?【1】基础指令
' p! _% r0 n  M% ~; r( |9 f/ j1 z  |* i/ ~- o) Z$ Y6 ]
af4cbd13f84745a3b15f7bb142e14752.png 8 S) Y% q/ f, {- V7 u& S
- i) v. r& O; H4 |
【2】UASRT管理
! x$ S& q1 W- l/ {2 x. z2 [0 _4 u& J, `, f# R
af80a59911fd4c6c94e53ba7a7d112a8.png ( U% j, p/ i, \2 Q" M% C9 R" M
4 Y# T! t/ c3 h2 W1 a
【3】WIFI管理
* h, A! p* V# n! A4 ]  [+ v: M8 J1 q4 f. ^+ S7 b( b5 v
8d5c8728a246406b9164db1e34567c0a.png & {' N4 R) Y# q6 G% K6 F$ d
  z  T! Q* ]1 j  j( k: l$ z
【4】 TCP/UDP通信, N. O# @7 R, R2 H2 }! d

, W) K# @( V( h$ @' `. W: k: P0 @
cddaa4defdc34eb9873462285de9c5dd.png " Q, s1 f3 Z  F! O5 B" x

) {+ n- U: ~: Z5 b8 q% x

$ U8 c+ \9 o+ V$ K5 i6 g 关键指令测试演示:$ y) N2 ^/ d5 C: c+ w  x, i+ k

  l+ |9 o; ~( A6 i5 g8 q" G; @1)部分查询指令测试:8 J# Y! a5 L/ I3 a8 f. m4 |

. t" V+ x6 h# ]: F
d7ba28f8276a4277a45494ba9b0b071d.png
$ T$ }. R9 ^% _' L( V. J/ M, n, [. q) ^* }6 g- g
2)部分TCP通信测试" x: H( i& d. Y/ X+ P+ c! u( P' ?
, B9 g: _: K6 ~2 l3 Y6 u  }- c2 F
9b88cbf6c5004792868123d7eed75895.png
/ B' {- `. i' V! t) }+ _5 n- D) H1 p( H% M
————————————————
' O) z0 o- O4 W4 j/ j8 q版权声明:py_free-物联智能
5 _2 D" \6 z: B7 t* f) S如有侵权请联系删除; D2 v1 Y7 X' K. c; ]

9 ?$ i) {. h* x9 E$ R4 a" b! @+ {2 C! ^. o: _1 T: v0 Y
2 H1 G" v$ S, V& h3 L$ K7 |
收藏 评论0 发布时间:2023-4-7 15:08

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版