单片机/MCU论坛
直播中

刘洋

11年用户 1208经验值
擅长:可编程逻辑 嵌入式技术
私信 关注

使用FIFO和16位工作寄存器级联模式时遇到的问题求解

我在外部访问模式下使用 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)

fanB

2024-1-30 17:21:10
我查看了您提供的示例项目,并注意到以下问题可能导致您遇到的问题:

1. 代码中使用的读取操作可能会导致数据点重复:
在您的示例代码中,您使用16位访问模式从FIFO中读取数据。但是,您对读取操作的实现可能会导致单个数据点被重复读取。请确保在读取操作后适当地更新读指针。您可以在读取后将读指针加上要读取的数据数量。例如,如果您要读取一个16位数据点,读指针应该增加2。这将确保下一次读取操作从正确的位置开始。

2. 写入操作可能未正确处理数据边界:
您的示例代码中,写操作是按字节写入数据的。当使用16位访问模式时,如果您要写入16位数据点,则应该确保写入操作仅在16位边界上进行。也就是说,您需要通过16位写入两个连续的字节。如果写操作未在正确的边界上进行,可能会导致读取操作返回重复的数据。请尝试在写入操作之前进行边界检查,并相应地调整写入指针。

请检查和修改您的读取和写入操作以解决这些问题,并再次测试您的代码。如果问题仍然存在,请提供更多详细信息,以便我可以更好地了解问题并提供进一步的帮助。
举报

更多回帖

发帖
×
20
完善资料,
赚取积分