完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
有没有哪位大佬清楚DMA原理的
想请教下,芯片厂是如何确保DMA传输过程中的数据都是OK的 比如传输前后SRAM里面的数据不变,传输出来的数据却发现有丢失,出错 |
|
相关推荐
1个回答
|
|
在DMA传输过程中,确保数据的正确性是非常重要的。以下是一些方法来确保DMA传输过程中数据的准确性:
1. 使用错误检查和纠正码(ECC):ECC是一种在数据传输中用来检测和纠正错误的技术。它可以检测并修正单个比特错误,从而确保数据的准确性。芯片厂商可以在SRAM中集成ECC,以检测和纠正在DMA传输过程中可能发生的错误。 2. 使用校验和:在发送数据之前,可以计算数据的校验和,并将其附加到数据中。在接收端,可以重新计算收到的数据的校验和,并将其与发送端的校验和进行比较,以确保数据的正确性。 3. 使用双缓冲区:在DMA传输过程中,可以使用双缓冲区来存储数据。一边将数据写入一个缓冲区,另一边从另一个缓冲区读取数据。这样可以确保在传输过程中数据不受干扰,并且可以有效地进行错误检测和纠正。 4. 进行验证和测试:在芯片制造过程中,厂商会对芯片进行严格的测试和验证。这些测试包括针对DMA传输的测试,以确保传输过程中数据的完整性和正确性。 总的来说,芯片制造商会使用一系列的技术和方法来确保DMA传输过程中数据的正确性。这些方法包括使用ECC、校验和、双缓冲区以及验证和测试等。 |
|
|
|
只有小组成员才能发言,加入小组>>
调试STM32H750的FMC总线读写PSRAM遇到的问题求解?
1535 浏览 1 评论
X-NUCLEO-IHM08M1板文档中输出电流为15Arms,15Arms是怎么得出来的呢?
1484 浏览 1 评论
905 浏览 2 评论
STM32F030F4 HSI时钟温度测试过不去是怎么回事?
651 浏览 2 评论
ST25R3916能否对ISO15693的标签芯片进行分区域写密码?
1530 浏览 2 评论
1841浏览 9评论
STM32仿真器是选择ST-LINK还是选择J-LINK?各有什么优势啊?
590浏览 4评论
STM32F0_TIM2输出pwm2后OLED变暗或者系统重启是怎么回事?
491浏览 3评论
492浏览 3评论
stm32cubemx生成mdk-arm v4项目文件无法打开是什么原因导致的?
472浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-3 02:22 , Processed in 0.764264 second(s), Total 83, Slave 65 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号