加法进位链的手动约束-易灵思(Elitestek)社区-FPGA CPLD-ChipDebug

加法进位链的手动约束

在激光雷达中,使用FPGA实现TDC时需要手动约束进位链的位置。这里简单记录下。

在outflow下会生成一个<project>.qplace文件 。用于指示布线的各个原语资源的分布位置 。

图片[1]-加法进位链的手动约束-易灵思(Elitestek)社区-FPGA CPLD-ChipDebug

它的内容主是

<block name> <x> <y> <subblk> <block number>

<block name>是原语的单元名

<x>表示水平位置,对应floorplan.

<y>表示垂直位置 ,对应floorplan.

<subblk>表示子块的位置 。目前只DSP24和DSP12可以有子块。在一个block可以指定多个字块。

<block number>是给block的一个编号,从0开始往下排。

图片[2]-加法进位链的手动约束-易灵思(Elitestek)社区-FPGA CPLD-ChipDebug

锁定过程如下:

stp1:并把outflow下面的<project>.qplace文件得到到工程目录下(可以修改名字也可以不修改,假如我们修改为carrychain.qplace)。把该qplace文件中想要锁定的block保留,其余可以删除。

stp2:在工程目录下建一个efx_pnr_settings.ini文件 。

stp3:在efx_pnr_settings.ini文件中输入

fix_pins=carrychain_prj.qplace

stp4:重新编译。

以加法进位链为例 ,上面我们生成了一个4级的加法进位链。具体约束在哪个位置可以在floorplan中确认位置 。

比如这里我们把它的位置约束到第8列。看下面的语句,第二行是进位链的输入位置用于进入进位链,第3,4,5,6依次约束进位链的carry_tap[0][x]~FF即可。

之前也有一个疑问是是否应该约束加法器,但是资源列表中并没有相应的资源,而且经过分析也认为只需要约束寄存器即可。

#block name x y subblk block number#---------- -- -- ------ ------------carry_tap[0][0]~FF  8 3 0 #0carry_tap[0][1]~FF  8 4 0 #1carry_tap[0][2]~FF  8 5 0 #2carry_tap[0][3]~FF  8 6 0 #3tdc[0].carry_chain_inst/CHAIN_GEN[0].genblk1.EFX_ADD_inst 8 2 0 #2605

约束的效果如下:

图片[3]-加法进位链的手动约束-易灵思(Elitestek)社区-FPGA CPLD-ChipDebug

请登录后发表评论

    没有回复内容