## AGM CPLD 应用指南

## ● 软件流程选择

Supra 共有 3 种开发 Mode: Native 选项(AGM 自有 EDA 综合工具),Synplicity 选项(第三方综合工具,例如 Synplify,Mentor 等),Compatible 选项(兼容 Altera Quartus II 的综合工具)。

文档中的 Supra 主要基于 Quartus II 综合的设计流程,其它工具设计流程类似。

#### AG576 IO

AG576SL100 的可用 IO 与 AG256SL100 一致,比 Altera EPM570T100 多 4 个 IO,分别为:

| Device         | Pin_39 | Pin_88 | Pin_37 | Pin_90 |
|----------------|--------|--------|--------|--------|
| EPM570T100 Pin | VCCINT | VCCINT | GNDINT | GNDINT |
| AG576SL100 Pin | 10     | 10     | 10     | 10     |

如果 PCB 兼容 EPM570,39/88 接 3.3V 供电的话,有可能会使芯片输入 IO 电流较大。可以通过设置,使 AG576 的未用 IO 为三态模式。请在 EPM570 的原设计中设置 Unused Pin 选项为 AS input tri-stated with weak pull-up。如下图:



如果希望利用 AG576 多的 4 个 IO,可以在 asf 文件中加入对这 4 个 pin 的分配,如:  $set_location_assignment PIN_88 - to abc$ 

# ● 安全位设置

AG256/576 安全位(SECURITY\_BIT)可以使 CPLD 烧写好后,无法读取出内部程序,只能擦除或覆盖,从而实现用户设计的安全性。

设置方法:

方法一: Quartus MAX II 工程中,选 Assignment-Device 菜单,点 Device and Pin Options,选 General 类别,选中 Enables security bit support。重新编译。运行 Supra 转换流程。方法二:在 Supra 生成的 asf 文件中,加入一行:

set\_global\_assignment -name SECURITY\_BIT "ON"

## ● PLL 的使用

AG576 内部带有 1 个 PLL, 可通过以下方法调用:

在 Supra 中进入 Tools -> Create IP, 选择 PLL 或 Memory。

PLL 类型选择 PLL, 填写输入频率 (MHz), 输出频率, 相移等数据。

注意: PLL 的输入时钟应是芯片的全局输入时钟 IO 管脚。

完成后点击 Generate,目录中会产生比如 pll0.v、pll0.ip 两个文件。在 Quartus II 设计代码中即可调用产生的模块(\*.v)。

新生成的 Quartus II 工程中编辑源文件(如.v)加入 pll 模块(这样,原 MAX II 工程就不能正确编译了,请留好备份)

Verilog 文件方式:

```
pll0 pll_inst( // PLL
.clkin(clk),
.clkfb(clkout0), //从 clkout0 反馈
.pllen(1'b1),
.resetn(rst),
.pfden(1'b1),
.clkout0(clkout0), //clkout0
.clkout1(clkout1), //clkout1
.lock(lock) //锁定信号, PLL 正确锁定输出 1, 否则 0
);
```

在 Supra Migrate 时需要将产生好的 IP 加入 IP Files (\*.ip)。

如果在设计过程中添加或修改 IP 文件,Supra project 需要重新再新建一次并覆盖原工程,并执行 Migrate 一次,和运行 af quartus.tcl。

应用 AGM IP 的 Quartus II 工程中需要注意并确认下面信息,正确执行 Tcl 后会出现:由于 IP 声明包含在 alta\_sim.v 的库文件中,这个文件默认在 supra 的安装目录中,如: C:\Supra\etc\arch\rodinia,Quartus II project 应包含这个文件。同时,alta\_pll 应设为 Design Partition,如图:



# 注意:

如果 Supra 编译出错,有可能是新加入 PLL 使得 clk 时钟线布线不成功,说明 576 的全局时钟不够,可修改新项目中的下面设置:

Settings->Fitter Settings,More Settings, Maximum number of global clocks allowed,改为 2 或 3(一共是 4,PLL 用 2 个或 1 个时钟)。

## ● UFM 的使用

需要调用 alta ufms 模块:

使用 USER FLASH,需要通过 SPI 口控制输入输出。 同时提供内部晶振 OSC,可输出 4MHz 左右时钟,用于精度不高的时钟设计。

在设计中加入后,转换好的项目中,alta\_ufms 需要在 Quartus II 中设为 Design Partition,如下图,然后进行正常编译。

