时序收敛方法一:控制集优化

目录

一、控制集

[1.1 控制集](#1.1 控制集)

[1.2 控制集的影响](#1.2 控制集的影响)

[1.3 大控制集设计](#1.3 大控制集设计)

[1.4 设计规避大控制集方法](#1.4 设计规避大控制集方法)

[1.5 控制集优化](#1.5 控制集优化)

二、工程示例

三、参考资料


一、控制集

1.1 控制集

控制集Control Set是控制信号(置位/复位信号、时钟使能信号和时钟信号)的组合,用于驱动任意给定的SRL、LUTRAM 或寄存器,对于控制信号的任意独特组合,都会组成1个独立控制集。

1.2 控制集的影响

只有完全相同控制信号(时钟,复位,使能信号)的触发器才能被放进同一个 slice,设计如果所含独立控制集过多,即同一个slice中可放置的触发器减少,可能导致资源浪费过多并且布局选项减少,从而导致功耗上升且可实现的时钟频率降低。设计所含控制集越少,则布局选项更多且灵活性更高,并且通常可以得到更好的结果。

1.3 大控制集设计

如果设计中存在一些不规范,则容易产生较大的控制集

  • 每个寄存器使用不同的 复位 信号(尤其是异步复位)。

  • 每个寄存器使用不同的 时钟使能

  • 每个寄存器分散在多个 always 块中,工具难以合并。

  • 使用条件复杂的复位/使能逻辑,而不是统一 gating。

1.4 设计规避大控制集方法

要从设计上避免出现较大的控制集,可以从以下角度考虑

1)统一复位信号

合并多个复位为一个全局复位,对不需要严格复位的寄存器,可去掉复位。

2)优先使用同步复位

异步复位会形成独立控制集,同步复位可由逻辑优化合并。

3)减少 CE(时钟使能)数量

多个独立 CE 信号会形成多个控制集,可通过数据选择逻辑替代 CE。

4)避免门控时钟(Gated Clock)

多个门控时钟 = 多个控制集,用 CE 或逻辑条件替代门控时钟;

  1. 对不需要复位的寄存器取消复位

很多数据通路寄存器在上电时会被逻辑覆盖,无需复位。

6)统一时钟树

多个独立时钟会导致多个控制集,若频率相同,可考虑时钟域合并(时钟复用)。

1.5 控制集优化

通常每 8 个 CLB 寄存器对应 1 个控制集,CLB 寄存器数量/8,对于设计中控制集需要优化的占比参考如下

二、工程示例

2.1工程代码

示例工程中存在同步控制与异步控制的触发器的控制集场景,

复制代码
// bad_design.v
module control_set #(parameter N=20)(
    input  wire clk,
    input  wire [N-1:0] rst_vec, // 每个寄存器有不同复位
    input  wire [N-1:0] ce_vec,  // 每个寄存器有不同CE
    input  wire [N-1:0] d_in,
    output reg  [N-1:0] q_out,

    input  wire  rst, // 每个寄存器有相同复位
    input  wire  ce, // 每个寄存器有相同CE
    output reg [N-1:0]  q_same
);
// 每个寄存器单独一个 always 块,复位和CE都不同
generate
    genvar i;
    for(i=0;i<N;i=i+1) 
        begin
            always @(posedge clk) 
                begin
                    if (rst_vec[i]) q_out[i] <= d_in[i];
                    // else if (ce_vec[i]) q_out[i] <= d_in[0];
                    // if (rst_vec[i]) q_out[i] <= 0;
                    // else if (ce_vec[i]) q_out[i] <= d_in[0];
                end
        end       
endgenerate
generate
    genvar j;
    for(j=0;j<N;j=j+1) 
        begin
            always @(posedge clk) 
                begin
                    if (rst) q_same[j] <= 0;
                    else if (ce) q_same[j] <= d_in[j];
                end
        end       
endgenerate
endmodule

2.2 控制集报告

console执行命令report_control_sets,可生成控制集报告,报告有summary(概览),Histogram(控制集扇出的分布),Flip-Flop Distribution(触发器类型)

summary报告如下,统计了设计中总的控制集数量,以及综合和物理综合阶段因复制增加的控制集数量

Histogram则是按照扇出的大小来统计各阶段的数量

Flip-Flop Distribution如下图,报告不同控制信号触发器的分布情况

三、参考资料

​《ug949-vivado-design-methodology-zh-cn》

相关推荐
逆小舟1 小时前
【STM32】串口
stm32·单片机·嵌入式硬件
ThreeYear_s1 小时前
【FPGA+DSP系列】——PWM电平光耦转换电路实验分析----电路原理分析,器件选型
单片机·嵌入式硬件·fpga开发
夜月yeyue3 小时前
嵌入式开发中的 Git CI/CD
c++·git·单片机·嵌入式硬件·ci/cd·硬件架构
锻炼²3 小时前
(已解决)vscode打开stm32cubemx生成的工程报红色波浪线警告
ide·vscode·stm32·stm32cubemx·vscode打开keil工程
axuan126515 小时前
16.【NXP 号令者RT1052】开发——实战-FlexPWM 输出
单片机·嵌入式硬件·mcu
墨辰JC5 小时前
基于STM32标准库的FreeRTOS移植与任务创建
数据库·stm32·嵌入式硬件·freertos
时光の尘5 小时前
【STM32】DMA超详细解析·入门级教程
stm32·单片机·嵌入式硬件·mcu·串口·dma·usart
chao1898445 小时前
基于TMS320F28069 DSP开发板实现RS485通信
单片机·嵌入式硬件
朱嘉鼎6 小时前
消费级MCU如何管理内存
单片机·嵌入式硬件
R6bandito_7 小时前
STM32 HAL库原子操作编译问题解决指南
c语言·ide·经验分享·stm32·单片机·嵌入式硬件·mcu