本测试用例为验证 Xilinx FPGA部分可重构功能而定制。 代码整体结构如下:
data:image/s3,"s3://crabby-images/39503/3950382cbbaa361a48a34c445aed464d4d507eb7" alt=""
主要功能是,内图产生自测图像,通过DVI接口输出,并同时点亮3个LED灯。其中静态逻辑(Static,灰色部分)负责顶层集成,时钟处理,IIC输出控制接口芯片,产生内部测试图像并输出显示。彩色的部分是可重构逻辑,分别为Red,Blue,和Green三个模块,代表对三个色彩通道分别进行处理的逻辑。
data:image/s3,"s3://crabby-images/5938f/5938f7f024cdc1ede086dc561161dfe13c4e7e98" alt=""
2. ISE流程
部分可重构开发流程会用到2个工具ISE和Planahead。其中ISE负责把静态逻辑,和各个重构模块,分别独立综合成网标文件,提供给Planahead使用。 综合的时候要尤其注意,静态逻辑Static是可以加管脚约束的,各个重构模块逻辑综合时,要选择不添加IO buffer,如下图所示:
data:image/s3,"s3://crabby-images/399d6/399d6134ecdb24c1b24153e5311a348a1b64f2e5" alt=""
各个模块的ISE工程已经在Synth文件夹下组织好了,可以直接用ISE14.7打开。 3.Planahead流程
部分可重构的主要工作都在Planahead下完成,大体分成4个步骤: A.建立Planahead工程,导入Static静态网表和约束文件
首先打开Planahead,选择建立新网表工程,确定Enable PartialReconfiguration功能打开。
data:image/s3,"s3://crabby-images/b4e88/b4e88c3097e5e722b31b1a30f5177012e9c65357" alt=""
然后依次加入顶层Static网表和ucf约束文件:
data:image/s3,"s3://crabby-images/22e59/22e5934137892a033e1b38f7a7029b5882c4aaec" alt=""
data:image/s3,"s3://crabby-images/3748c/3748c7af6f5ed18afe5c0b4e4e9518058adb092c" alt=""
B.导入Reconfiguration网表文件并设置Partition
创建完成Planahead工程后,在Flow Manager中,选择Open SynthesizedDesign打开网表设计:
data:image/s3,"s3://crabby-images/bc3dc/bc3dcc5b108f0299ed1e4850a15b56b2f6c1780e" alt=""
接下来,我们要添加各个可重构的网标文件。选中netlist列表中的某个可重构子Module(此时它是Black Box,什么都没有),右键选择Set Partition:
data:image/s3,"s3://crabby-images/0c4c0/0c4c05b41633b0bdf9626050ff54ca3aba9ab511" alt=""
在弹出对话框中,设置比可重构Module某个实现的名字,Next后选择对应网表:
data:image/s3,"s3://crabby-images/cb6c0/cb6c0cd8d4eedb8580d8102c56470fe02b9913d3" alt=""
data:image/s3,"s3://crabby-images/a711a/a711a9d3d436a6d6384c6a5a156615bda4ded2d3" alt=""
接下来我们还可以在同一个Module下面,继续添加其它不同实现的网表文件,也可以添加Black Box网表(即空网表):
data:image/s3,"s3://crabby-images/3405b/3405b68cacc6f9da921abd0ad99d901dd44d1cf7" alt=""
data:image/s3,"s3://crabby-images/a05d3/a05d362484eb0762e1716ef6fbe201db8a588793" alt=""
依次把所有的网表都添加完毕,最终,在Source窗口,视图如下:
data:image/s3,"s3://crabby-images/4c7f7/4c7f74e81dadf98f5d11ac84222b0ea256ef69d0" alt=""
C.设置Partition
接下来,我们给3个Partition,分别设置其物理区域。使用Set Pblock Size选项,在Device视图中,划定合适的物理区域即可:
data:image/s3,"s3://crabby-images/095f4/095f4553b27eb976bc99c60f6fa480bda2aa9f66" alt=""
物理区域中会包含多种资源,不需要的我们可以不勾选,这样能减小最终bit文件的大小:
data:image/s3,"s3://crabby-images/f89b4/f89b4aa8a7ae2b588d55db6b407c7a8838cdf6b1" alt=""
设置完所有的partition后,可以跑一下DRC检查(Tools-> ReportDRC),确保所有的设置都没有问题:
data:image/s3,"s3://crabby-images/c215f/c215fd3fb370d86264095195d3c9114e5ff86d7b" alt=""
DRC检查结果:
data:image/s3,"s3://crabby-images/9db6d/9db6d41951d172da1770456d1d98f10c64ccca14" alt=""
D.创建Implementation Runs
最后我们创建ImplementationRuns,在此处可以创建不同的组合。
data:image/s3,"s3://crabby-images/a7d92/a7d92a14873b4dadc6dba81d3730f7f719f0c21e" alt=""
创建完成后,就可以跑Implementation布局布线了,跑完后每个run下都会生成多个bit文件,其中之一是全局的配置bit,另外多个是部分重构的bit文件。 如下示例中,可以看到部分重构的bit文件,相比完整的bit文件,其size很小,因此其加载速度会很快:
data:image/s3,"s3://crabby-images/82cf0/82cf0de045a221365911023668f309f429711788" alt=""