Stm32L0 STM32CUBE中UART和使用LPUART1以及串口不进中断问题解决

2023-05-16

使用STM32CUBE配置串口USART2

 USART2中断

使用STM32CUBE配置串口LPUART1,这个串口要配置115200可能需要修改时钟,太低的系统时钟可能无法达到这个速度

配置中断LPUART1

 GPIO设置一般默认就可以

 都使用LL库

生成代码,此处很关键,默认生成的代码里没有使能LPUART1,需要手动使能,官方应该是出于功耗考虑,但是新手就在此掉坑了

/**
  ******************************************************************************
  * @file    usart.c
  * @brief   This file provides code for the configuration
  *          of the USART instances.
  ******************************************************************************
  * @attention
  *
  * <h2><center>&copy; Copyright (c) 2021 STMicroelectronics.
  * All rights reserved.</center></h2>
  *
  * This software component is licensed by ST under BSD 3-Clause license,
  * the "License"; You may not use this file except in compliance with the
  * License. You may obtain a copy of the License at:
  *                        opensource.org/licenses/BSD-3-Clause
  *
  ******************************************************************************
  */

/* Includes ------------------------------------------------------------------*/
#include "usart.h"

/* USER CODE BEGIN 0 */

/* USER CODE END 0 */

/* LPUART1 init function */

void MX_LPUART1_UART_Init(void)
{

  /* USER CODE BEGIN LPUART1_Init 0 */

  /* USER CODE END LPUART1_Init 0 */

  LL_LPUART_InitTypeDef LPUART_InitStruct = {0};

  LL_GPIO_InitTypeDef GPIO_InitStruct = {0};

  /* Peripheral clock enable */
  LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_LPUART1);

  LL_IOP_GRP1_EnableClock(LL_IOP_GRP1_PERIPH_GPIOA);
  /**LPUART1 GPIO Configuration
  PA2   ------> LPUART1_TX
  PA3   ------> LPUART1_RX
  */
  GPIO_InitStruct.Pin = LL_GPIO_PIN_2;
  GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
  GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW;
  GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
  GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
  GPIO_InitStruct.Alternate = LL_GPIO_AF_6;
  LL_GPIO_Init(GPIOA, &GPIO_InitStruct);

  GPIO_InitStruct.Pin = LL_GPIO_PIN_3;
  GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
  GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_LOW;
  GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
  GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
  GPIO_InitStruct.Alternate = LL_GPIO_AF_6;
  LL_GPIO_Init(GPIOA, &GPIO_InitStruct);

  /* LPUART1 interrupt Init */
  NVIC_SetPriority(LPUART1_IRQn, 0);
  NVIC_EnableIRQ(LPUART1_IRQn);

  /* USER CODE BEGIN LPUART1_Init 1 */

  /* USER CODE END LPUART1_Init 1 */
  LPUART_InitStruct.BaudRate = 9600;
  LPUART_InitStruct.DataWidth = LL_LPUART_DATAWIDTH_8B;
  LPUART_InitStruct.StopBits = LL_LPUART_STOPBITS_1;
  LPUART_InitStruct.Parity = LL_LPUART_PARITY_NONE;
  LPUART_InitStruct.TransferDirection = LL_LPUART_DIRECTION_TX_RX;
  LPUART_InitStruct.HardwareFlowControl = LL_LPUART_HWCONTROL_NONE;
  LL_LPUART_Init(LPUART1, &LPUART_InitStruct);
  /* USER CODE BEGIN LPUART1_Init 2 */

  /* USER CODE END LPUART1_Init 2 */

}
/* USART2 init function */

void MX_USART2_UART_Init(void)
{

  /* USER CODE BEGIN USART2_Init 0 */

  /* USER CODE END USART2_Init 0 */

  LL_USART_InitTypeDef USART_InitStruct = {0};

  LL_GPIO_InitTypeDef GPIO_InitStruct = {0};

  /* Peripheral clock enable */
  LL_APB1_GRP1_EnableClock(LL_APB1_GRP1_PERIPH_USART2);

  LL_IOP_GRP1_EnableClock(LL_IOP_GRP1_PERIPH_GPIOA);
  /**USART2 GPIO Configuration
  PA9   ------> USART2_TX
  PA10   ------> USART2_RX
  */
  GPIO_InitStruct.Pin = LL_GPIO_PIN_9;
  GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
  GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_HIGH;
  GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
  GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
  GPIO_InitStruct.Alternate = LL_GPIO_AF_4;
  LL_GPIO_Init(GPIOA, &GPIO_InitStruct);

  GPIO_InitStruct.Pin = LL_GPIO_PIN_10;
  GPIO_InitStruct.Mode = LL_GPIO_MODE_ALTERNATE;
  GPIO_InitStruct.Speed = LL_GPIO_SPEED_FREQ_HIGH;
  GPIO_InitStruct.OutputType = LL_GPIO_OUTPUT_PUSHPULL;
  GPIO_InitStruct.Pull = LL_GPIO_PULL_NO;
  GPIO_InitStruct.Alternate = LL_GPIO_AF_4;
  LL_GPIO_Init(GPIOA, &GPIO_InitStruct);

  /* USART2 interrupt Init */
  NVIC_SetPriority(USART2_IRQn, 0);
  NVIC_EnableIRQ(USART2_IRQn);

  /* USER CODE BEGIN USART2_Init 1 */

  /* USER CODE END USART2_Init 1 */
  USART_InitStruct.BaudRate = 115200;
  USART_InitStruct.DataWidth = LL_USART_DATAWIDTH_8B;
  USART_InitStruct.StopBits = LL_USART_STOPBITS_1;
  USART_InitStruct.Parity = LL_USART_PARITY_NONE;
  USART_InitStruct.TransferDirection = LL_USART_DIRECTION_TX_RX;
  USART_InitStruct.HardwareFlowControl = LL_USART_HWCONTROL_NONE;
  USART_InitStruct.OverSampling = LL_USART_OVERSAMPLING_16;
  LL_USART_Init(USART2, &USART_InitStruct);
  LL_USART_DisableOverrunDetect(USART2);
  LL_USART_DisableDMADeactOnRxErr(USART2);
  LL_USART_ConfigAsyncMode(USART2);
  LL_USART_Enable(USART2);
  /* USER CODE BEGIN USART2_Init 2 */

  /* USER CODE END USART2_Init 2 */

}

/* USER CODE BEGIN 1 */

/* USER CODE END 1 */

/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

 使能LPUART1代码

  /* USER CODE BEGIN LPUART1_Init 2 */
  LL_USART_DisableOverrunDetect(LPUART1);
  LL_USART_DisableDMADeactOnRxErr(LPUART1);
  LL_USART_ConfigAsyncMode(LPUART1);
	LL_USART_Enable(LPUART1);
  /* USER CODE END LPUART1_Init 2 */

切记,这样串口是不会进中断的, STM32CUBE默认不给开启中断,就说是不是坑

    /* 开启串口1中断 */
  LL_USART_EnableIT_RXNE(LPUART1);
    /* 开启串口2中断 */
  LL_USART_EnableIT_RXNE(USART2);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Stm32L0 STM32CUBE中UART和使用LPUART1以及串口不进中断问题解决 的相关文章

随机推荐

  • 笔记本电脑外放声音吱吱响怎么办?

    问题分析 xff1a 1 硬件问题 xff1a 喇叭坏了 2 软件设置问题 xff1a 声音产生冲突了 解决方案 xff1a 当一个喇叭坏了 xff0c 或者两个喇叭的声音冲突了 xff0c 都可以使用如下方式 xff1a 针对于win10
  • mac修改默认终端为iterm2

  • 视频下载4大神器

    1 downie 可以下载 上面所有你想的到的视频网站的视频 xff0c 而且下载速度很快 2 ykdl 可以通过命令行下载爱奇艺的视频 xff0c 还有其他网站的视频 3 you get 4 youtube dl
  • jupyter_notebook_config.py的配置详解

    Configuration file for jupyter notebook Application SingletonConfigurable configuration This is an application The date
  • js Function 参数按值传递详解

    如果传入参数是基本数据类型 xff0c 那么按值传递是很容易理解的 xff1b 如果传入参数是引用数据类型 xff0c 那么会很容易陷入误区 xff0c 错误地认为是引用传递 xff1b 错误例子一 xff1a function setCo
  • 准确率、精准率、召回率和F1值详解

    专业术语的中英文对照表 英文名准确率Accuracy精准率Precise召回率RecallF1值F1 measure Precise和Recall是广泛应用在信息检索和统计学分类领域的两个度量值 xff0c 用来评价结果的质量 xff1b
  • snippet,让你编码效率翻倍

    为什么谈到Snippet 今天下午在用vscode做小程序的时候 xff0c 发现很不方便 xff0c 因为商店里提供的代码片段极为有限 xff0c 而且平时几乎每天都需要用到代码片段 xff0c 所以就在思考他们是怎么做到给别人提供代码的
  • 验证Promise是同步的

    前言 Promise是ES6提出的解决异步编程导致陷入回调的地狱问题 例子1 console log 1 var a 61 new Promise function resolve reject console log 2 resolve
  • Nextcloud下载文件出错、无法下载、网页卡死解决办法

    通常出现这种情况是因为用了一些Nextcloud不支持的下载工具 xff0c 通常需要去下载工具中设置 通过Nextcloud下载大文件的时候1G或更大时 xff0c Internet Download Manager会将系统卡住 xff0
  • 原生js实现JSONP

    介绍 JSONP是JSON with Padding 填充式JSON或参数式JSON 的简写 xff0c 是一种非常常用的跨域请求方式 主要原理是利用了script 标签可以跨域请求的特性 xff0c 由其 src属性发送请求到服务器 xf
  • ESP32设备驱动-SHT20温湿度传感器驱动

    SHT20温湿度传感器驱动 文章目录 SHT20温湿度传感器驱动 1 SHT20介绍 2 硬件准备 3 软件准备 4 驱动实现 1 SHT20介绍 Sensirion 的 SHT20 湿度和温度传感器已成为外形尺寸和智能方面的行业标准 嵌入
  • ESP32设备驱动-BME680环境传感器驱动

    BME680环境传感器驱动 文章目录 BME680环境传感器驱动 1 BME680介绍 2 硬件准备 3 软件准备 4 驱动实现 1 BME680介绍 BME680 是一款集成环境传感器 专为尺寸和低功耗是关键要求的移动应用和可穿戴设备而开
  • ESP32设备驱动-HDC2080温湿度传感器驱动

    HDC2080温湿度传感器驱动 文章目录 HDC2080温湿度传感器驱动 2 硬件准备 3 软件准备 4 驱动实现 HDC2080 器件是一款集成式湿度和温度传感器 可在小型 DFN 封装中以极低的功耗提供高精度测量 基于电容的传感器包括新
  • ESP32设备驱动-BMP388气压传感器驱动

    BMP388气压传感器驱动 文章目录 BMP388气压传感器驱动 1 BMP388介绍 2 硬件准备 3 软件准备 4 驱动实现 1 BMP388介绍 BMP388 是一款非常小巧 低功耗和低噪声的 24 位绝对气压传感器 它可以实现精确的
  • ESP32设备驱动-BMA400加速度传感器驱动

    BMA400加速度传感器驱动 文章目录 BMA400加速度传感器驱动 1 BMA400介绍 2 硬件准备 3 软件准备 4 驱动实现 1 BMA400介绍 BMA400 是第一款真正的超低功耗加速度传感器 不会影响性能 BMA400 具有
  • ESP32设备驱动-BH1745NUC 亮度和颜色传感器驱动

    BH1745NUC 亮度和颜色传感器驱动 文章目录 BH1745NUC 亮度和颜色传感器驱动 2 硬件准备 3 软件准备 4 驱动实现 BH1745NUC 是具有 I C 总线接口的数字颜色传感器 IC 该 IC 感应红光 绿光和蓝光 RG
  • ESP32设备驱动-LPS25H压阻式压力传感器驱动

    LPS25H压阻式压力传感器驱动 文章目录 LPS25H压阻式压力传感器驱动 1 LPS25H介绍 2 硬件准备 3 软件准备 4 驱动实现 1 LPS25H介绍 LPS25H 是一款超紧凑型绝对压阻式压力传感器 它包括一个单片传感元件和一
  • ESP32设备驱动-LPS25H压阻式压力传感器驱动

    1 LPS22HB介绍 文章目录 1 LPS22HB介绍 2 硬件准备 3 软件准备 4 驱动实现 LPS22HB 是一款超紧凑型压阻式绝对压力传感器 可用作数字输出气压计 该设备包括一个传感元件和一个 I2C 接口 该接口通过 I2C 或
  • ESP32设备驱动-LIS3MDL磁场传感器驱动

    LIS3MDL磁场传感器驱动 文章目录 LIS3MDL磁场传感器驱动 1 LIS3MDL介绍 2 硬件准备 3 软件准备 4 驱动实现 1 LIS3MDL介绍 LIS3MDL 具有 4 8 12 16 高斯的用户可选满量程 自检功能允许用户
  • Stm32L0 STM32CUBE中UART和使用LPUART1以及串口不进中断问题解决

    使用STM32CUBE配置串口USART2 USART2中断 使用STM32CUBE配置串口LPUART1 xff0c 这个串口要配置115200可能需要修改时钟 xff0c 太低的系统时钟可能无法达到这个速度 配置中断LPUART1 GP