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以及串口不进中断问题解决 的相关文章

  • UART串口通信

    目录 一 通信特点二 通信应用三 接线示意图三 UART通信协议四 STM32F4 串口使用1 资源分布2 特性3 UART框图4 使用方法5 相关库函数6 函数实例 五 实战 上位机控制开发板小灯 一 通信特点 异步 串行 全双工 一般描
  • 串行通信基础知识与UART驱动构件使用方法

    串行通信基础 串行通信接口 异步串行通信 UART 常称为 串口 或SCI xff0c 在USB未普及之前 xff0c 是PC机必备通信接口之一 通信方式为单字节通信 xff0c 是最简单的串行通信方式 RS232 RS485 接线简单 x
  • UART串口通信协议详解

    UART xff1a 通信异步收发器 xff0c 串行 异步通信总线 xff0c 两条数据线 xff08 收发 xff09 xff0c 全双工 xff08 可以同时接收和发送 xff09 一 UART帧格式 xff08 UART协议 xff
  • HAL_UART_IRQHandler(UART_HandleTypeDef *huart)里面的中断接收函数

    目录 前言1 UART Receive IT2 HAL UART Receive3 HAL UART Receive IT 前言 看了很长时间串口中断的HAL库 xff0c 最容易混淆的就是函数的名称 xff0c 主要集中在UART Rec
  • Node.js笔记:SerialPort(串口)模块使用(基于9.x.x)

    文章目录 目的 模块安装 基础使用 扫描端口 打开端口 发送数据 接收数据 错误处理 数据解析器 SerialPort类 构造方法 属性 事件 方法 命令行工具 总结 目的 上位机与各种电路模块间常常采用串口进行通讯 Node js中可以使
  • STM32 基础系列教程 24 - USB_HID_key

    前言 学习stm32 USB接口使用 学会用CUBE工具快速创建USB设备工程及调试 关于usb的相关知道请读者提前准备并学习 当然如果不想深究其中原理的话 跟着本文来操作就可以实现基于USB的设备开发了 需要提示的是 stm32在使用us
  • 51单片机串口通信(UART)

    项目描述 1 串口工作方式为1 8位UART 波特率可变 无校验位 2 通信数据格式为 1位起始位 8位数据位 1位停止位 3 上电后MCU给上位机发送问候语 之后等待上位机的信息 MCU和上位机的通信为收发交替进行 MCU接收到的信息会实
  • STM32 基础系列教程 38 - Lwip_http

    前言 HTTP协议 HyperText Transfer Protocol 超文本传输协议 是因特网上应用最为广泛的种网络传输协议 所有的WWW文件都必须遵守这个标准 HTTP是一个基于TCP IP通信协议来传递数据 HTML 文件 图片文
  • STM32 基础系列教程 47 - MD5

    前言 MD5消息摘要算法 英语 MD5 Message Digest Algorithm 一种被广泛使用的密码散列函数 可以产生出一个128位 16字节 的散列值 hash value 用于确保信息传输完整一致 MD5由美国密码学家罗纳德
  • MicroPython串口数据转换技巧

    技巧一 还原从串口接收的HEX字符串 首先上官方文档 确认接收数据类型为bytes 串口读来的bytes类型HEX数据转换成HEX类型字符串转换函数 ByteToHex的转换 返回数据16进制字符串 def ByteToHex bins r
  • STM32 基础系列教程 36 - Lwip_dns

    前言 域名系统 英文 DomainNameSystem 缩写 DNS 是互联网的一项服务 它作为将域名和IP地址相互映射的一个分布式数据库 能够使人更方便地访问互联网 DNS使用TCP和UDP端口53 当前 对于每一级域名长度的限制是63个
  • STM32Cube学习(2)——定时器中断

    0 引言 单片机 STM32F407ZGT6 仿真器 ST Link V2 开发环境 STM32CubeIDE 1 10 1 功能说明 采用定时器中断的方式 实现LED按照定时器频率闪烁 前情提要 STM32Cube学习 1 点灯 配置 参
  • STM32CubeIDE使用笔记(01):基础说明与开发流程

    文章目录 目的 基础事项 下载安装 界面说明 项目文件夹 常用快捷键 开发流程 总结 目的 STM32cubeIDE是ST官方推出的一款用于开发STM32的工具 其实就是整合了STM32CubeMX和TrueSTUDIO而成 对于STM32
  • Android Things:连接到串行调试控制台

    我一直在尝试连接到串行控制台树莓派 3 with 安卓事物 using USB to TTL cable从我的Linux Ubuntu 机器 尽管我按照文档连接了电缆 但执行时我得到的只是minicom命令如下 with 没有机会输入任何字
  • 以字符串形式接收数字(uart)

    我正在尝试通过 uart 接收一个包装为字符串的数字 我发送数字 1000 所以我得到 4 个字节 空字符 但是 当我使用 atoi 将数组转换为数字并将整数与 1000 进行比较时 我并不总是得到正确的数字 这是我用于接收号码的中断处理函
  • Gem5 中与 ARM 裸机的 UART 通信

    我目前正在使用 Gem5 我必须通过 UART 从我的主机访问 ARMv8 裸机选项 所以我尝试了很多方法 但我还没有准备好 您能否让我知道 如何在裸机类型编程中将主机的串行端口映射到 ARMv8 的串行端口 任何帮助 将不胜感激 工作设置
  • 从 Linux 用户空间设置 16550A UART 硬件 FIFO 中断级别

    我目前正在使用 16550 兼容的 UART 并且我希望能够更改 FIFO 中断触发级别 我在高 UART 负载下丢失字节 并且我想降低阈值 这是一个动力不足的嵌入式系统 当然 如果我愿意 我可以在 8250 port c 驱动程序中更改它
  • IOError:[Errno 2]没有这样的文件或目录(当它确实存在时)Python [重复]

    这个问题在这里已经有答案了 我正在通过 python 中的 uart 传输文件文件夹 下面您可以看到简单的功能 但有一个问题 因为我收到如标题所示的错误 IOError Errno 2 No such file or directory 1
  • GATT 配置文件和 UART 服务

    我是开发通过蓝牙连接到外围设备的移动应用程序的新手 我搜索到 GATT 是用于蓝牙LE 通信的相关配置文件 但我们的客户建议我们使用 UART 服务 现在我很困惑 1 这两件事是如何关联的 2 我们是否必须选择其中之一 如果是的话 每一个的
  • 如何在R中从串口读取数据

    我想绘制来自串行端口的实时数据 我认为 R 将是完成这项工作的好工具 我在尝试从串行端口 COM4 读取数据时遇到了困难 我已经验证数据是通过 terra term 传入的 并在尝试 R 之前关闭会话 但我似乎无法在 R 中获取任何内容 我

随机推荐

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

    问题分析 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