完善资料让更多小伙伴认识你,还能领取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开发板试用】简介、环境搭建、工程测试
177 浏览 0 评论
312 浏览 0 评论
imx6ull裸机编程,使用宏定义无法驱动,使用指针就可以驱动
691 浏览 1 评论
《DNK210使用指南 -CanMV版 V1.0》第三十二章 音频FFT实验
384 浏览 0 评论
飞凌嵌入式ElfBoard EL 1板卡-i2c与从设备通讯编程示例之i2c-tools工具使用
1284 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
11620 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-6 09:20 , Processed in 0.759831 second(s), Total 43, Slave 36 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号