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

【经验分享】STM32CubeMX--STM32L0系列ADC读取电压+LPUART串口通讯

[复制链接]
STMCU小助手 发布时间:2021-11-17 23:02
ADC+LPUART串口通讯
  q3 w1 i3 K: Y& |程序介绍:给ADC的第四通道一个电压,通过AD转换,输出到串口打印信息“The current AD value = ****** V”4 b/ a* _3 Y9 D& l, \" O
3 O, }  O3 s$ @& H4 d) _1 ?
调试过程中出现的问题' ]/ \+ K: s/ G, ~* x% _
因为用的内置AD,调试过程不复杂,基本一次就通了,但是串口调试的问题主要是会出现乱码情况,还有16进制显示全都是00 00 00,关于这些问题大多数都是由于波特率不匹配或者是波特率和晶振频率不匹配等。! w+ P5 W" Q2 t: d3 }" N5 r
" e5 o' h% r+ w) J
1.STM32CubeMX
6 j$ \- x2 O) w$ m2 a# d7 m% j) O; E7 {. Y# a* l
20191208211633928.jpg

- \! w; r7 X0 y  I3 a
/ Z* _0 [0 }/ c9 q; [2 M6 S+ f" p
20191208212351970.png

  x# H; h. Y) H9 q0 g8 t% n
/ b) Q* w' X3 h+ J1 ZSTM32CubeMX里面时钟图还是比较清晰直观的,比较容易上手,从图中可以看出这款芯片的LPUART是低功耗的,并且用的内部时钟(选择LPUART也是因为项目需求,UART类似),而ADC是内部有专用时钟,用HSI16M时钟工作  _( K4 \4 ?/ O& r* a5 F: L$ U1 P- r

* C% o! n- V+ Y0 P, i2.代码部分* B9 k' S: d# w' k7 N+ n$ M
9 E0 M( O2 m2 }# [6 A7 e' c6 h
  1. #include "main.h"3 P9 ?. y3 L$ |% S
  2. #include <stdio.h>
      f2 O7 z* @" n" F
  3. 7 I5 ?0 ~; G( j* Q4 c- k; K7 Y5 P
  4. ADC_HandleTypeDef hadc;
    7 ^6 j" t; d1 W* z  x8 L4 Y

  5. 5 ]; y2 g! ]# ^  U$ D
  6. UART_HandleTypeDef hlpuart1;  @2 z# W  [  o% g8 i

  7.   W) U5 n0 }- ]9 l% @
  8. ADC_ChannelConfTypeDef        sConfig;% y$ x0 h/ S- e) l% {! Q
  9. ! B8 J) w& Z. C" a" Z; X2 V
  10. static uint32_t adc_conv_var;
    3 _0 J0 x/ y% q: _8 D' ]
  11. float temp;
    # m' ]1 u% e' x
  12. 7 `5 i+ ?& m! I4 T' {7 c- ]
  13. void SystemClock_Config(void);9 ?# _7 g: d( Z1 C
  14. static void MX_GPIO_Init(void);5 O. j- X7 c0 D/ F& y; S
  15. static void MX_LPUART1_UART_Init(void);
    - X- n! |9 h$ S. Q8 Z/ l4 n
  16. static void MX_ADC_Init(void);+ K4 A; `  }" B! N) s
  17. static void GET_ADC_(void);* v: \% L. L* l( F' o' }# Z

  18. ' ]& @! [, T8 F7 s

  19. 9 o6 E. q! P' f- L7 h7 s
  20. int main(void)
    3 c0 m2 ^8 `8 H; u) ^- f
  21. {
    , ?' c6 S6 q4 @- }
  22. ( |8 B% Y. _3 [, z) C, h0 Q' X
  23.   HAL_Init();
    / z' R2 L2 l! k; G: i3 q' y. x6 U* a* P
  24. 5 Z, L: E' T, O7 b+ G6 T/ u
  25.   SystemClock_Config();
    & y9 M% n2 j1 R

  26.   i' x; ~' p' a, R( e
  27.   MX_GPIO_Init();
    & g  B- G0 @7 ?  |& X% d4 U+ }/ G& g

  28. / e, O: T( u3 y2 C* p
  29.   MX_ADC_Init();
    % |8 [. ^, h) V6 F! V7 }
  30.         - y" n# ~% r, }& W% W  k2 o7 j
  31.         GET_ADC_();
    6 D# _" _  i& g$ b2 W/ |  j
  32.         
    $ x5 a5 X8 ?4 L" `' G" m+ T
  33.         if((HAL_ADC_GetState(&hadc) & HAL_ADC_STATE_REG_EOC) == HAL_ADC_STATE_REG_EOC)
    , f: i9 C& {0 G% u" G+ [: z
  34.         {- p/ ]) I' n/ L6 f
  35.                 adc_conv_var =HAL_ADC_GetValue(&hadc);( A; {  K1 W, J- l- o( `. {
  36.                 temp=(float)adc_conv_var*(3.3/4096);        + K" K! s0 \% c3 A5 V6 C
  37.         }                ! {; Y& Y, g3 g$ q3 y9 Z2 g8 ]8 T

  38. 7 j7 G& h7 s" w9 |% i6 J8 r( H
  39.         MX_LPUART1_UART_Init();* G3 B+ X7 R* h9 j) K6 ]
  40.   printf("\r\n The current AD value = %f V \r\n",temp); $ |4 S7 {) g" f! S* X5 Y

  41. ; z) ~  F. s; V
  42.   while (1)
    % s0 J- z' W1 f, g, ~% n
  43.   {
    ( n* J% f2 b2 r3 e# q2 E) r
  44. ( M) Z; U( _% E/ w
  45.   }& _1 {* B/ E% o+ x, D; p, V. K- i
  46. }$ j" @) f- H9 b* }3 M* g8 j( c' }
  47. //printf函数重定向/ M: H$ ^; w2 E8 Q% }: S
  48. int fputc(int ch, FILE *f): A+ O/ z3 n( F  [- J. j9 _/ [/ L" u3 T
  49. {8 ]2 a! z; n2 g6 a! O  I
  50.         uint8_t temp1[1]={ch};
    + s/ i( {/ k3 r, g: j
  51.         HAL_UART_Transmit(&hlpuart1, temp1, 1,0xFFFF);
    8 e2 Y- |% z" p5 |7 l- Z) P
  52.         return ch;' N+ G5 L" J5 u& E: G, S& v0 k
  53. }0 ^8 \3 [2 {2 Q  F0 Y% q
  54. /**
    3 E& ^0 w- m( |" P# {2 R% J4 i4 ?
  55.   * @brief System Clock Configuration8 w' q8 N4 V  C+ U9 h
  56.   * @retval None
    0 {( P. ^: F$ q: H4 b. r
  57.   */, i/ J/ k* W' W8 O8 d0 j
  58. void SystemClock_Config(void)
      N* w2 W4 \) B% W; U
  59. {+ O/ D" K) H. m8 _( @
  60.   RCC_OscInitTypeDef RCC_OscInitStruct = {0};, G6 [/ k, r& J3 d6 k+ L9 \
  61.   RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
    1 V# a2 v# ^5 @, N$ _
  62.   RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
    6 v; e7 u% ~8 F" U
  63. % Z# `% W, ~0 p. q9 x9 E$ q
  64.   /** Configure the main internal regulator output voltage : f. Y3 B. A3 i1 O1 D7 y( p- _
  65.   */: Q* t$ T; d* u: ]$ N
  66.   __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);+ S" x6 A) v* E  N4 H/ C
  67.   /** Initializes the CPU, AHB and APB busses clocks
    4 b- x+ m1 u/ E2 z
  68.   */
    " `+ B: S) ~5 K/ H, ]. M/ j; u0 l
  69.   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_MSI;
    / a; G& p7 n0 V" ^* j
  70.   RCC_OscInitStruct.MSIState = RCC_MSI_ON;  g3 ~6 M2 X0 L6 u4 @/ x
  71.   RCC_OscInitStruct.MSICalibrationValue = 0;
    7 w. L  ]9 i8 x8 y$ P# M$ G+ e  K
  72.   RCC_OscInitStruct.MSIClockRange = RCC_MSIRANGE_5;0 D/ d# A/ h! b2 g7 V6 J
  73.   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;/ k& e& a% d0 _! H7 I; f" `  Q# E
  74.   if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)1 {7 v! z. ]; F) J4 m- L
  75.   {1 r  E; U  Y9 ~% a
  76.     Error_Handler();5 L$ T  i, o( A) N; v; S0 N8 ^8 H" `
  77.   }
    4 Q9 I. D) F, d  W
  78.   /** Initializes the CPU, AHB and APB busses clocks # c: H1 r0 T7 E. p  E0 I7 E1 K& N
  79.   */
    8 O& g; l: c7 G# l; C* s( N/ u& s
  80.   RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
    / q" q- M/ W6 a. w% o, `6 k
  81.                               |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
    , z5 l% ?$ q) \: u/ ^+ F8 A
  82.   RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_MSI;, {% L% z" o( Y( ?/ b1 _. e
  83.   RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
    4 h! e3 f" y5 m7 _: o: m1 E
  84.   RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;% G9 N5 B) ^  U) {. Z7 P7 o
  85.   RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
    / {) i2 F/ O) ~0 _' _

  86. % F% P* d, A0 G% k( c; v& h
  87.   if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)8 x- F6 x6 h0 E( S- d  o
  88.   {) [3 Q1 f3 x5 g$ X& d3 O
  89.     Error_Handler();8 S) M% k' w: J* R3 I7 R, f
  90.   }+ A( k, L7 s3 J! s4 _* N
  91.   PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_LPUART1;
    4 `( t# Y4 f' C' k8 |$ j
  92.   PeriphClkInit.Lpuart1ClockSelection = RCC_LPUART1CLKSOURCE_PCLK1;
    9 R( m. F. K& F* o- E) K6 {- c
  93.   if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)" o3 R; T. C7 D
  94.   {
    ' }, ?* j3 x9 {* G/ K5 S
  95.     Error_Handler();
    4 i- U0 t: r1 x8 p( t+ p2 Z6 ^
  96.   }! M. n- U' G, }/ p0 }
  97.   HAL_RCC_MCOConfig(RCC_MCO1, RCC_MCO1SOURCE_SYSCLK, RCC_MCODIV_1);
    1 q# |" H5 s* @6 |& f# Q
  98. }
    % O: O% k- I* _& f9 G. x; d( X: Q
  99. , d  a0 t4 F! F/ `* T9 u
  100. /**+ M, s7 d! ^5 g. ]5 p0 F% D
  101.   * @brief ADC Initialization Function& a$ \8 _1 O8 Q: \8 H$ w2 A' h
  102.   * @param None
    $ Y) K0 h/ \/ O/ `* x
  103.   * @retval None: c# i& Y9 \6 I
  104.   */
      t& ]" L; v9 J/ Y5 j: I; `4 V
  105. static void MX_ADC_Init(void)
    1 @1 a! `# ~% q/ D( P3 h2 m0 }- Z
  106. {
    7 v6 D9 L* A: h) @: x/ Y
  107.   ADC_ChannelConfTypeDef sConfig = {0};
    1 k7 M- Q5 {- b- A

  108. # {: x' T! J9 c$ T, Q
  109.   hadc.Instance = ADC1;
    7 q+ o% V; C3 r4 A& y
  110.   hadc.Init.OversamplingMode = DISABLE;
    ( E$ k4 X* ]. D( U
  111.   hadc.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV2;
    , m$ J* c6 w4 W
  112.   hadc.Init.Resolution = ADC_RESOLUTION_12B;6 ]; n$ u9 U( ~1 @1 B, o  S
  113.   hadc.Init.SamplingTime = ADC_SAMPLETIME_7CYCLES_5;
    2 L, g& `! k. H1 M% I
  114.   hadc.Init.ScanConvMode = ADC_SCAN_DIRECTION_FORWARD;
    0 ~4 X) t& A" X- P7 Y
  115.   hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT;
      ^  _  t; b" X1 c! T1 |
  116.   hadc.Init.ContinuousConvMode = ENABLE;% L7 y- R7 ^4 F5 J6 X% f7 b$ r
  117.   hadc.Init.DiscontinuousConvMode = DISABLE;
    , h& f8 o$ c- o% D: |
  118.   hadc.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
    9 `0 f; @# q$ F9 Y5 \
  119.   hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START;
    , }' Z. |4 h4 ]. i2 x  s; y( z
  120.   hadc.Init.DMAContinuousRequests = DISABLE;, f' D% ?# F" M+ u6 V/ [
  121.   hadc.Init.EOCSelection = ADC_EOC_SINGLE_CONV;" C' {2 R# E" p$ n
  122.   hadc.Init.Overrun = ADC_OVR_DATA_OVERWRITTEN;0 f* Q8 O9 M& \/ |0 ?/ N2 _
  123.   hadc.Init.LowPowerAutoWait = DISABLE;! @! l5 d5 ~0 S, y0 J
  124.   hadc.Init.LowPowerFrequencyMode = DISABLE;
    ) I: w9 b  V7 z
  125.   hadc.Init.LowPowerAutoPowerOff = DISABLE;0 D, C" L- f& t  }1 r$ w
  126.   if (HAL_ADC_Init(&hadc) != HAL_OK)
    5 ?8 g& _1 D7 [& B8 y1 r) u
  127.   {2 {: L$ |' T! p6 ?
  128.     Error_Handler();! Y4 m6 x6 c1 y# B3 J, l
  129.   }7 U# C' _% C  a& j  E' r
  130. 7 M4 |' x+ n$ ~5 e2 N
  131.   if (HAL_ADCEx_Calibration_Start(&hadc, ADC_SINGLE_ENDED) !=  HAL_OK) //启动校验功能
    " [) O0 q9 C+ O: U  j, e
  132.   {
    ; y5 S+ z$ c  g5 ]* e0 m
  133.     Error_Handler();
    ) Q3 R# q9 a9 l- `- u
  134.   }1 V* s& g( E0 p) G& T
  135. }
    9 L/ `- |6 \9 b+ _
  136. static void GET_ADC_(void)
    ) h4 U. b8 T* h2 e3 Z( X
  137. {
      g0 K4 z0 c: ^$ \7 X- F
  138.         sConfig.Channel      = ADC_CHANNEL_4;               /* Channel to be converted */
    3 t! o6 U# x( V) q
  139.   sConfig.Rank         = ADC_RANK_CHANNEL_NUMBER;    // 设置通道+ ~( r+ a/ n( R/ J' b6 p
  140.   if (HAL_ADC_ConfigChannel(&hadc, &sConfig) != HAL_OK)0 ]+ I( j! q4 N: a: r( |; f
  141.   {
    # I0 h# K  J! S& s. O3 E% }& y
  142.     Error_Handler();6 T' s2 I. i4 f0 r) k/ D
  143.   }
    - u$ y: w/ M, S, V
  144. $ z& t% u* e9 N4 A$ s
  145.         if (HAL_ADC_Start(&hadc) != HAL_OK)
    ! I0 z; H% l: q* b: B4 r
  146.   {6 w( _3 R3 m' v! A! w7 C
  147.     Error_Handler();$ A2 p& x% Z1 B: s
  148.   }) J- d* Q& |% r! P
  149.         HAL_ADC_PollForConversion(&hadc, 10);9 r1 S! T7 \8 P& u) a, ~+ n
  150. }% z) J- _* S5 w/ |7 |/ G1 ~! E
  151. /**
    6 v2 V6 d7 P, J* `% m9 n+ i
  152.   * @brief LPUART1 Initialization Function& H# e7 B: C9 [! ^9 L% J( w
  153.   * @param None
    # i& ]* E  x3 \8 c9 _' `' D
  154.   * @retval None
    + d( m9 L9 p7 e  ^. S2 I# I
  155.   */* {4 r% q, m: B4 f+ u
  156. static void MX_LPUART1_UART_Init(void)' N0 q% u8 L" M! ^! d$ O
  157. {
    2 }% o  U( q! B5 N) _. b: ]% y
  158.   hlpuart1.Instance = LPUART1;
    * K6 U- a7 f0 ?  H3 Z
  159.   hlpuart1.Init.BaudRate = 128000;' [& Q/ X5 j0 L$ f( Q, `9 v
  160.   hlpuart1.Init.WordLength = UART_WORDLENGTH_7B;0 b+ w" z0 n5 C! Q. f" [8 m
  161.   hlpuart1.Init.StopBits = UART_STOPBITS_1;
    9 F6 ^$ P) ?( l3 V# k- P" M
  162.   hlpuart1.Init.Parity = UART_PARITY_NONE;- N, ?1 `* N; Z0 c8 g. i4 C, G+ }3 i
  163.   hlpuart1.Init.Mode = UART_MODE_TX_RX;
    1 M- X0 o3 {5 ^9 C# T& |7 r( L, B
  164.   hlpuart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
    5 c" p% D1 b9 z. c0 w$ B
  165.   hlpuart1.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;" \; _+ x9 }" B# a% }; W
  166.   hlpuart1.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
    6 W" `  |! O3 _7 q( S, w3 M' ?% J
  167.   if (HAL_UART_Init(&hlpuart1) != HAL_OK)
    & }$ e8 Q! M3 d  X, f8 n! W4 _
  168.   {
    ! Q, ?% v7 R) e) u8 X# z# o' e
  169.     Error_Handler();! B' j& n/ u6 o  a1 F
  170.   }& }" s! ]7 L/ N1 _0 b7 n" H  z" h
  171. }
    * K) i, X+ M* \2 ^, y
  172. 5 H8 n$ |& W. `3 a* ?3 A/ O
  173. /**8 `5 P6 A2 f+ ]& v8 j$ m
  174.   * @brief GPIO Initialization Function
    3 B" q$ Z& s: U* u  C1 d
  175.   * @param None. B. b% O4 y; k
  176.   * @retval None& n" o) A2 O( ~( U4 i, P
  177.   */
      a; b2 f. z0 S/ L: @
  178. static void MX_GPIO_Init(void)
    . g5 H' ?" ?, A# n1 T+ ?
  179. {
    9 N, \' G' z+ C  ?* \
  180.   GPIO_InitTypeDef GPIO_InitStruct = {0};
    5 _) T; P1 T7 _& j! ?

  181. 3 P# k2 m; A! Y* P1 e' Z
  182.   /* GPIO Ports Clock Enable */
    5 @0 {2 C, Q8 S
  183.   __HAL_RCC_GPIOH_CLK_ENABLE();
    - [$ W0 S6 u8 D0 J
  184.   __HAL_RCC_GPIOA_CLK_ENABLE();
    , L$ ^( Q; y$ g0 P6 D
  185.   __HAL_RCC_GPIOC_CLK_ENABLE();
    $ b+ H: T7 J: Z4 G& j  C
  186.   __HAL_RCC_GPIOB_CLK_ENABLE();$ t0 O! f  k/ D4 a" n2 A

  187. , E- G$ a3 g: Z
  188.   /*Configure GPIO pin : PB13 */! ^# R7 g& C; M' y3 b7 f
  189.   GPIO_InitStruct.Pin = GPIO_PIN_13;% w0 I" N5 E& Q* A! f0 W* v  `
  190.   GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
    - @3 l0 z6 p$ M& ^5 d% m: f2 Z
  191.   GPIO_InitStruct.Pull = GPIO_NOPULL;( h+ E( c- N+ o
  192.   GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
    # |) u/ i: }' @7 T. i+ U; h& H1 d; W: I! r
  193.   GPIO_InitStruct.Alternate = GPIO_AF2_MCO;( W- |) r& U+ v0 X; t# Z- b
  194.   HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
    ! n6 I6 T* F+ S# c
  195. }
复制代码

$ Y: g$ T# q8 [* c, u4 a: |
! j2 \0 A. B0 `" d/ h: E  j
20191209094631525.png

+ k6 x; Z6 o1 l6 N' H" {! ?
& V) g) P& [  t  _
1 N/ C% \6 e, W+ p
收藏 评论0 发布时间:2021-11-17 23:02

举报

0个回答

所属标签

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32Cube扩展软件包
意法半导体边缘AI套件
ST - 理想汽车豪华SUV案例
ST意法半导体智能家居案例
STM32 ARM Cortex 32位微控制器
关注我们
st-img 微信公众号
st-img 手机版