0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

MCP电路实现方法及命令优先级实例

冬至子 来源:RTL2GDS 作者:老本 Benjamin 2023-06-27 15:10 次阅读

SDC中的各式各样的Exception,大体上可以分为“加严”和“放松”两种类型,如下面几个命令:

##更严格##
set_max_delay
set_min_delay
set_data_check
...
##更放松##
set_false_path
set_multicycle_path
set_case_analysis
set_disable_timing
...

需要强调的是需要加严的部分,对于异步路径,往往需要通过set_max_delay来约束,防止路径过长。而且有些跨时钟域(CDC)的路径,为了保证握手时的数据一致性,需要用到格雷码(Gray Code),约束时更加需要注意。

多周期路径

之前的文章有提到多半周期路径,是为了加快数据的处理速度。这里的多周期路径则是针对那些不需要太快的处理速度,一定程度上节省面积和功耗。多周期路径常常发生在memory读写路径,某些复位路径,从慢时钟域到快时钟域的路径等等。

当然,多周期路径是需要电路结构配合实现的,但总体思路有两个:

(1)通过Enable信号控制Clock的采样时刻

(2)通过Enable信号控制Data的变化时刻

下面举一个通过方法(2)实现n-1个周期路径的例子:

图片

上图主体上是从D1寄存器到D2寄存器的一条路径,中间经过了很长的组合逻辑。特殊之处在于D1/D2的数据变化是受FSM状态机控制的,其中D1数据变化发生在第1个时钟周期后(FF1的输出信号使能),D2数据变化发生在第n的时钟周期后(FFn的输出信号使能)。从下面的波形图可以看出,D1_OUT到D2_OUT经过了n-1个周期。

图片

优先级顺序

对于几个常见的exception命令,使用时要特别注意优先级顺序,避免出现想要的约束不起作用的情况。

图片

假设有一条从UFF1(CLKA)到UFF2(CLKB)的路径,想通过以下命令进行约束,最终的效果是怎样的呢?

# CMD1
set_multicycle_path 2 -from CLKA -to CLKB
# CMD2, 优先级比CMD1高,覆盖
set_multicycle_path 3 -from UFF1/CP
# CMD3,优先级更高,覆盖
set_max_delay 6.6 -from UFF1/CP -to UFF2/D
# CMD4,优先级比CMD3低,忽略
set_max_delay 5 -from CLKA -to CLKB
# CMD5,优先级最高,覆盖
set_false_path -to UFF2/D

可以看出,最终的效果还是false path,设置的max_delay不起作用。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5322

    浏览量

    120022
  • CDC
    CDC
    +关注

    关注

    0

    文章

    57

    浏览量

    17773
  • 状态机
    +关注

    关注

    2

    文章

    492

    浏览量

    27482
  • SDC
    SDC
    +关注

    关注

    0

    文章

    48

    浏览量

    15528
收藏 人收藏

    评论

    相关推荐

    RTOS应用中的优先级反转问题

    在嵌入式系统中,如果使用基于优先级调度算法的RTOS,系统中可能发生优先级反转现象。优先级反转用来描述系统中高优先级任务由于等待低优先级任务
    发表于 12-14 11:00 1177次阅读

    在μC OS-II中实现优先级调度的方法

    在μC/OS-II中实现优先级调度的方法
    发表于 05-16 15:05 23次下载

    在μCOS-II中实现优先级调度的方法

    在μC/OS-II中实现优先级调度的方法
    发表于 11-01 11:49 24次下载

    STM32F10X的中断优先级

    STM32(Cortex-M3)中有两个优先级的概念抢占式优先级和响应优先级,有人把响应优先级称作亚优先级或副
    发表于 11-04 15:02 41次下载

    DSP中断如何设置优先级

    原以为2812中断不能设置优先级。实际上硬件上优先级是做好的。但软件上有办法来设置优先级
    发表于 04-08 17:20 20次下载

    STM32单片机优先级的定义

    先占优先级也就是抢占优先级,概念等同于51单片机中的中断。假设有两中断先后触发,已经在执行的中断先占优先级如果没有后触发的中断 先占优先级更高,就会先处理先占
    发表于 12-07 15:09 9365次阅读
    STM32单片机<b class='flag-5'>优先级</b>的定义

    STM32实例:中断和优先级概念资料下载

    电子发烧友网为你提供STM32实例:中断和优先级概念资料下载的电子资料下载,更有其他相关的电路图、源代码、课件教程、中文资料、英文资料、参考设计、用户指南、解决方案等资料,希望可以帮助到广大的电子工程师们。
    发表于 03-29 16:53 2次下载
    STM32<b class='flag-5'>实例</b>:中断和<b class='flag-5'>优先级</b>概念资料下载

    cortex M内核优先级设置

    Cortex M内核中每个中断都有一个8位的优先级设置寄存器这个8位的寄存器可以分为抢占优先级和子优先级两个部分(通过设置优先级组设置)抢占优先级
    发表于 12-01 11:51 4次下载
    cortex M内核<b class='flag-5'>优先级</b>设置

    2.FreeRTOS中断优先级和任务优先级

    FreeRTOS中断优先级和任务优先级架构:Cortex-M3版本:FreeRTOS V9.0.0前言:最开始,我并没有搞清楚什么是中断优先级和任务优先级,但看了部分资料后发现这两个并
    发表于 12-04 20:21 9次下载
    2.FreeRTOS中断<b class='flag-5'>优先级</b>和任务<b class='flag-5'>优先级</b>

    STM32F103芯片中断优先级以及FreeRTOS优先级设置

    STM32F103只用了4个位来表达优先级,因此最多支持16的可编程优先级(0~15),15为最低优先级
    发表于 01-25 18:59 1次下载
    STM32F103芯片中断<b class='flag-5'>优先级</b>以及FreeRTOS<b class='flag-5'>优先级</b>设置

    uC/OS-II学习笔记——优先级反转与优先级继承机制

    优先级反转,是指某同步资源被较低优先级的进程/线程所拥有,较高优先级的进程/线程竞争该同步资源未获得该资源,而使得较高优先级进程/线程反而推迟被调度执行的现象。
    发表于 02-09 10:33 2次下载
    uC/OS-II学习笔记——<b class='flag-5'>优先级</b>反转与<b class='flag-5'>优先级</b>继承机制

    中断优先级处理的原则及配置 抢占优先级和响应优先级的区别

    首先我们需要知道什么是中断优先级:中断优先级是CPU响应中断的先后顺序
    的头像 发表于 05-18 15:10 2.7w次阅读
    中断<b class='flag-5'>优先级</b>处理的原则及配置 抢占<b class='flag-5'>优先级</b>和响应<b class='flag-5'>优先级</b>的区别

    FreeRTOS任务的优先级示例

    任务的优先级:0~24之间。数字越大,任务优先等级越高。高优先级的任务优先执行。
    的头像 发表于 09-15 11:13 2744次阅读

    Free RTOS的优先级翻转

    优先级翻转简介:就是高优先级的任务运行起来的效果好像成了低优先级,而低优先级比高优先级先运行;
    的头像 发表于 02-10 15:31 1270次阅读
    Free RTOS的<b class='flag-5'>优先级</b>翻转

    什么是优先级反转

    假设现在有三个任务TaskA(优先级高)、TaskB(优先级中)、TaskC(优先级低),一个信号量(Semaphore),此信号量用于任务之间争夺某个资源。在某一时刻,高优先级的Ta
    的头像 发表于 04-24 13:01 2223次阅读
    什么是<b class='flag-5'>优先级</b>反转