完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
我在外部访问模式下使用 FIFO(它们 CAN 由 CPU 和 DMA 读取和写入)和使用 16 位工作寄存器级联模式时遇到问题。 我 CAN 实例化一个使用数据路径的 FIFO f0 和 f1 的组件,使用 8 位或 16 位访问填充两个 FIFO,但是当我尝试使用 16 位访问读取 FIFO 时,我得到奇怪的结果,我不断看到单个值重复 4 次。
我在这里创建了一个带有示例项目的 github 存储库:https://github.com/nlshipp/PSoc5_FifoTest 请注意,在本示例中,我没有使用总线或区块状态位,因为我只在任何时候向FIFO添加或删除4个元素。 该示例使用 8 或 16 位访问权限清除 FIFO,用四组值填充数据路径的两个 FIFO。 然后,它使用 8 或 16 位访问读出值,使用一组不同的值再次填充这些值,然后再次读取它们。 每次运行都使用不同的 8 或 16 位访问组合。 以下是输出: ** 首次使用 8 位访问权限运行并产生正确的输出 填充 FIFO 打印 fifos F0=00 F1=10 F0=00 F1=10 F0=0 1 F1=11 F0=02 F1=12 F0=03 F1=13 填充 FIFO 打印 fifos F0=20 F1=30 F0=30 F0=30 F0=31 F0=31 F0=32 F 0=23 F1=33 清除 fiFO ** 第二次运行:输出正确使用 16 位字填充 fifo 填充 fifo 打印 fifos F0=00 F1=10 F0=01 F1=11 F0=02 F1=12 F0=03 F1=13 填充 FIFO 打印 FIFO F0=20 F1=30 F0=30 F0=21 F1=31 F0=22 F1=23 F1=33 清除 FIFO ** 第三次运行会产生错误的输出:使用 16 位字 读取 fifo 填充 FIFO 打印 fifos F 0=00 F1=10 F0=0 1 F1=10 F0=02 F1=10 F0=03 F1=10 填充 FIFO 打印 FIFO F0=20 F1=33 F0=33 F0=33 Clearing f1=33 F0=33 Clearing f1=33 Clearing f1=33 Clearing f1=33 Clearing f1=33 Clearing f1=33 Clearing f1= 33 F1=33 Clearing f1=33 ** 第四次运行会产生错误的输出:使用 16 位字填写 fifo 使用 16 位字 读取 fifo 填充 fifo 打印 fifos F0=00 F1=10 F0=01 F1=10 F0=02 F1=10 F0=03 F1=10 F0=03 F0=10 F0=10 F0=10 F0=10 F0=10 F0=03 F0=10 F0=10 F0=10 F0=10 F0=03 F0=23 F1=23 F1=23 F1=23 F1=23 = 33 ** 第 5 次运行再次使用 8 位访问并生成正确的输出。 清除 FIFO 填充 FIFO 打印 FIFO F0=00 F1=10 F0=01 F1=11 F0=02 F1=12 F0=03 F1=13 填充 FIFO 打印 FIFO F0=20 F1= 30 F0=21 F1=31 F0=31 F0=31 F0=22 F1=32 F0=23 F1=33 |
|
相关推荐
1个回答
|
|
我查看了您提供的示例项目,并注意到以下问题可能导致您遇到的问题:
1. 代码中使用的读取操作可能会导致数据点重复: 在您的示例代码中,您使用16位访问模式从FIFO中读取数据。但是,您对读取操作的实现可能会导致单个数据点被重复读取。请确保在读取操作后适当地更新读指针。您可以在读取后将读指针加上要读取的数据数量。例如,如果您要读取一个16位数据点,读指针应该增加2。这将确保下一次读取操作从正确的位置开始。 2. 写入操作可能未正确处理数据边界: 您的示例代码中,写操作是按字节写入数据的。当使用16位访问模式时,如果您要写入16位数据点,则应该确保写入操作仅在16位边界上进行。也就是说,您需要通过16位写入两个连续的字节。如果写操作未在正确的边界上进行,可能会导致读取操作返回重复的数据。请尝试在写入操作之前进行边界检查,并相应地调整写入指针。 请检查和修改您的读取和写入操作以解决这些问题,并再次测试您的代码。如果问题仍然存在,请提供更多详细信息,以便我可以更好地了解问题并提供进一步的帮助。 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
【RA-Eco-RA2E1-48PIN-V1.0开发板试用】(第三篇)ADC采集+PWM输出
515 浏览 0 评论
《DNK210使用指南 -CanMV版 V1.0》第四十五章 人脸识别实验
515 浏览 0 评论
780 浏览 0 评论
如何用OpenCV的相机捕捉视频进行人脸检测--基于米尔NXP i.MX93开发板
1360 浏览 0 评论
《DNK210使用指南 -CanMV版 V1.0》第四十章 YOLO2人手检测实验
572 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
11759 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-22 01:28 , Processed in 0.696232 second(s), Total 73, Slave 56 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号