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