c语言中0x1u是多少,HAL库源文件stm32h7xx_hal_dma_ex.c学习笔记(2018-08-10 V1.1)

2024-01-03 17:59

本文主要是介绍c语言中0x1u是多少,HAL库源文件stm32h7xx_hal_dma_ex.c学习笔记(2018-08-10 V1.1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

自己写了个BDMA双缓冲配置的函数,验证了一下,BDMA双缓冲还是可以用的。手册还是比较靠谱的

7ffeb61b16913aa6c0c156596d23a904.gif

不想改动官方库,这样以后升级库也方便,以下代码放在单独的文件里。

#define BDMA_CCR_DBM_Pos        (15U)

#define BDMA_CCR_DBM_Msk        (0x1U << BDMA_CCR_DBM_Pos)                      /*!< 0x00008000 */

#define BDMA_CCR_DBM            BDMA_CCR_DBM_Msk                                /*!< DBM bits(Double-Buffer Mode)*/

#define BDMA_CCR_CT_Pos         (16U)

#define BDMA_CCR_CT_Msk         (0x1U << BDMA_CCR_CT_Pos)                      /*!< 0x00010000 */

#define BDMA_CCR_CT             BDMA_CCR_CT_Msk                                /*!< CT bits(Current Target Memory)*/

HAL_StatusTypeDef HAL_BDMAEx_MultiBufferStart_IT(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t SecondMemAddress, uint32_t DataLength)

{

HAL_StatusTypeDef status = HAL_OK;

__IO uint32_t *ifcRegister_Base = NULL; /* DMA Stream Interrupt Clear register */

/* Check the parameters */

assert_param(IS_DMA_BUFFER_SIZE(DataLength));

/* Memory-to-memory transfer not supported in double buffering mode */

if(hdma->Init.Direction == DMA_MEMORY_TO_MEMORY)

{

hdma->ErrorCode = HAL_DMA_ERROR_NOT_SUPPORTED;

return HAL_ERROR;

}

/* Process locked */

__HAL_LOCK(hdma);

if(HAL_DMA_STATE_READY == hdma->State)

{

/* Change DMA peripheral state */

hdma->State = HAL_DMA_STATE_BUSY;

/* Initialize the error code */

hdma->ErrorCode = HAL_DMA_ERROR_NONE;

/* Enable the Double buffer mode */

((BDMA_Channel_TypeDef   *)hdma->Instance)->CCR |= (uint32_t)BDMA_CCR_DBM;

/* Configure DMA Stream destination address */

*((uint32_t*)(&((BDMA_Channel_TypeDef   *)hdma->Instance)->CMAR)+1) = SecondMemAddress;

/* Configure the source, destination address and the data length */

/* Configure DMA Stream data length */

((BDMA_Channel_TypeDef   *)hdma->Instance)->CNDTR = DataLength;

/* Peripheral to Memory */

if((hdma->Init.Direction) == DMA_MEMORY_TO_PERIPH)

{

/* Configure DMA Stream destination address */

((BDMA_Channel_TypeDef   *)hdma->Instance)->CPAR = DstAddress;

/* Configure DMA Stream source address */

((BDMA_Channel_TypeDef   *)hdma->Instance)->CMAR = SrcAddress;

}

/* Clear all flags */

BDMA->IFCR  |= (BDMA_ISR_GIF0 << hdma->StreamIndex);

/* Clear the DMAMUX synchro overrun flag */

hdma->DMAmuxChannelStatus->CFR = hdma->DMAmuxChannelStatusMask;

if(hdma->DMAmuxRequestGen != 0U)

{

/* Clear the DMAMUX request generator overrun flag */

hdma->DMAmuxRequestGenStatus->RGCFR = hdma->DMAmuxRequestGenStatusMask;

}

/* Enable Common interrupts*/

MODIFY_REG(((BDMA_Channel_TypeDef   *)hdma->Instance)->CCR, (BDMA_CCR_TCIE | BDMA_CCR_HTIE | BDMA_CCR_TEIE), (BDMA_CCR_TCIE | BDMA_CCR_TEIE));

if(hdma->XferHalfCpltCallback != NULL)

{

/*Enable Half Transfer IT if corresponding Callback is set*/

((BDMA_Channel_TypeDef   *)hdma->Instance)->CCR  |= BDMA_CCR_HTIE;

}

/* Check if DMAMUX Synchronization is enabled*/

if((hdma->DMAmuxChannel->CCR & DMAMUX_CxCR_SE) != 0)

{

/* Enable DMAMUX sync overrun IT*/

hdma->DMAmuxChannel->CCR |= DMAMUX_CxCR_SOIE;

}

if(hdma->DMAmuxRequestGen != 0U)

{

/* if using DMAMUX request generator, enable the DMAMUX request generator overrun IT*/

/* enable the request gen overrun IT*/

hdma->DMAmuxRequestGen->RGCR |= DMAMUX_RGxCR_OIE;

}

/* Enable the peripheral */

__HAL_DMA_ENABLE(hdma);

}

else

{

/* Set the error code to busy */

hdma->ErrorCode = HAL_DMA_ERROR_BUSY;

/* Return error status */

status = HAL_ERROR;

}

return status;

}

另外需要注意的是,官方库的DMA中断处理中,没有针对BDMA双缓冲的处理,但是可以自己在DMA传输完成中断回调中判断当前使用的缓冲区自行处理。

static void HAL_TransferCplt(DMA_HandleTypeDef *hdma)

{

if((((BDMA_Channel_TypeDef   *)hdma->Instance)->CCR & BDMA_CCR_CT_Msk) != RESET) {

//...

} else {

//...

}

}

希望可以帮到需要用这个功能的人。

这篇关于c语言中0x1u是多少,HAL库源文件stm32h7xx_hal_dma_ex.c学习笔记(2018-08-10 V1.1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/566582

相关文章

使用Go语言开发一个命令行文件管理工具

《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

Go语言利用泛型封装常见的Map操作

《Go语言利用泛型封装常见的Map操作》Go语言在1.18版本中引入了泛型,这是Go语言发展的一个重要里程碑,它极大地增强了语言的表达能力和灵活性,本文将通过泛型实现封装常见的Map操作,感... 目录什么是泛型泛型解决了什么问题Go泛型基于泛型的常见Map操作代码合集总结什么是泛型泛型是一种编程范式,允

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3