PLD 设计问答1
答:SCF 文件是 MAXPLUSII 的仿真文件, 可以在 MP2 中新建
1. 用 Altera_Cpld 作了一个 186(主 CPU)控制 sdram 的控制接口, 发现问题:要使得sdram 读写正确, 必须把 186(主 CPU)的 clk 送给 sdram, 而不能把 clk 经 cpld 的延时送给sdram
两者相差仅仅 4ns
而时序通过逻辑分析仪测试没有问题
此程序在 xilinx 器件上没有问题
这是怎么回事
答:建议将所有控制和时钟信号都从 PLD 输出, 因为 SDRAM 对时钟偏移(clock skew)很敏感, 而 Altera 的器件 PLL 允许对时钟频率和相位都进行完全控制
因此, 对于所有使用SDRAM 的设计, Altera 的器件 PLL 必须生成 SDRAM 时钟信号
要利用 SDRAM 作为数据或程序存储地址来完成设计, 是采用 MegaWizard 还是 Plug-In Manager 来将一个 PLL 在采用 Quartus II 软件的设计中的顶层示例
可以选择创建一个新的megafuntion 变量, 然后在 Plug-In manager 中创建 ALTCLKLOCK(I/P 菜单)变量
可以将 PLL设置成多个, 或是将输入划分开来, 以适应设计需求
一旦软件生成 PLL, 将其在设计中示例, 并使用 PLL 的“Clock”输出以驱动 CPU 时钟输入和输出 IP 引脚
2. 在 max7000 系列中, 只允许有两个输出使能信号, 可在设计中却存在三个, 每次编译时出现 “ device need too many [3/2] output enable signal”
如 果 不 更 换 器 件 ( 使 用 的 是max7064lc68)