0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

STA學習記錄-時鐘定義

冬至子 ? 來源:行走的BUG永動機 ? 作者:行走的BUG永動機 ? 2023-05-26 17:20 ? 次閱讀

STA的準備工作包括:設定時鐘、指定IO時序特性、指定false path和multicycle path

1 什么是STA環(huán)境

看下面這張圖,假定Design Under Analysis(DUA)會與其他同步設計交互,這意味著DUA會從前一級觸發(fā)器接收數(shù)據(jù),并將數(shù)據(jù)發(fā)送到DUA后一級觸發(fā)器

圖片

為了對這種設計執(zhí)行STA,需要指定觸發(fā)器的時鐘、進入DUA和退出DUA的所有路徑上的時序約束

2 指定時鐘

定義時鐘時需要提供以下信息

  • Clock source:可以是design的port,也可以是design內(nèi)部的pin
  • Period:時鐘周期
  • Duty cycle:高電平持續(xù)時間和低電平持續(xù)時間
  • Edge time:上升沿和下降沿出現(xiàn)的時刻

通過時鐘定義,所有內(nèi)部的timing path都將受到約束,表明所有的internal path都可以用時鐘路徑來分析

下面是一個基本的時鐘定義:

create_clock \\
 -name SYSCLK \\
 -period 20 \\
 -waveform {0 5} \\
 [get_ports SCLK]

在這個例子中,定義的時鐘名稱為SYSCLK,并且指定定義的時鐘是在端口 SCLK上定義的

SYSCLK的時鐘周期時20(如果沒有明確指定時間的單位,默認是ns)

-waveform中,第一個變量是上升沿出現(xiàn)的時刻,第二個變量是下降沿出現(xiàn)的時刻,因此在這個例子中,上升沿出現(xiàn)在0ns,下降沿出現(xiàn)在5ns

這個例子對應的波形圖如下

圖片

-waveform中可以指定任意數(shù)量的邊沿,但是所有的邊沿必須在一個周期之內(nèi)

邊沿時刻從0時刻之后的第一個上升沿開始,然后依次是下降沿、上升沿、下降沿……

-waveform {time_rise time_fall time_rise time_fall ...}

-waveform中需要指定偶數(shù)個邊沿,并且-waveform指定的是一個周期內(nèi)的波形,在后續(xù)周期中不斷重復

如果沒有指定-waveform,默認是

-waveform {0, period/2}

下面看一個不使用-waveform選項的時鐘定義

create_clock -period 5 [get_ports SCAN_CLK]

其對應的波形圖如下:

圖片

在這個例子中,由于沒有指定-name,因此定義時鐘名稱與端口名稱相同

再來看另一個例子

create_clock -name BDYCLK \\
-period 15 \\
-waveform {5 12} \\
[get_ports GBLCLK]

其對應的波形圖如下:

圖片

在這個例子中,根據(jù)-waveform可以知道,第一個上升沿出現(xiàn)在5ns,第一下降沿出現(xiàn)在12ns

因為選項-waveform給出的上升沿和下降沿時刻會在每個cycle里重復,又因為-period指定周期是15ns,

所以在第二個cycle中,上升沿應該出現(xiàn)在15+5=20ns處

下降沿出現(xiàn)在15+12=27ns處

再來看另外兩個例子:

# Figureacreate_clock  -period 10 \\ 
-waveform {0 5} \\
[get_ports FCLK]

#Figurebcreate_clock -period 125 \\
-waveform {100 150} \\
[get_ports ARMCLK]

對應的波形圖如下:

圖片

對于圖(a),周期為10ns,上升沿出現(xiàn)在5ns,下降沿出現(xiàn)在10ns

在第二個cycle中,上升沿出現(xiàn)在10+5=15ns,下降沿出現(xiàn)在10+10=20ns

對于圖(b),周期為125ns,從選項-waveform {100 150}可以知道,上升沿出現(xiàn)在100ns處,并且 high duration = 150-100=50ns,那么low duration = period - high duration,即low duration = 75ns

因為150ns的時刻已經(jīng)超出了第一個cycle的時間范圍,并且low duration的時長小于上升沿出現(xiàn)的時刻,那么可以推斷出 在第一個cycle中有一個下降沿 ,這個下降沿出現(xiàn)的時刻可以用100 - low duration得到(100 - 75 = 25ns)

出現(xiàn)這種情況的原因是:選項-waveform要從上升沿開始

根據(jù)下面的例子,再次理解一下選項-waveform

#Figure (a)
create_clock -period 1.0 \\
-waveform {0.5 1.375} \\
[get_ports MAIN_CLK]

#Figure (b)
create_clock -period 1.2 \\
-waveform {0.3 0.4 0.8 1.0} \\
[get_ports JTAG_CLK]

對應的波形圖如下:

圖片

在這個例子中,圖(a)的分析方式與上一個例子相同

圖(b)由于選項-waveform中給出的上升沿和下降沿時刻都在第一個cycle時間范圍內(nèi),因此不需要進行額外的推斷

在某些情況下,比如在頂層的輸入端口或某些PLL的輸出端口,工具無法自動計算出過渡時間,此時在clock source出顯示指定過渡時間很有用,可以使用set_clock_transition來指定

set_clock_transition -rise 0.1 [get_clocks CLK_CONFIG]

set_clock_transition -fall 0.12 [get_clocks CLK_CONFIG]

# 這個約束僅適用于ideal clocks,一旦構(gòu)建了時鐘樹就將其忽略

3 時鐘不確定度

可以用set_clock_uncertainty來指定時鐘周期的timing uncertainty,用不確定度來建模那些會降低有效時鐘周期的因素

set_clock_uncertainty -setup 0.2 [get_clocks CLK_CONFIG]

set_clock_uncertainty -hold 0.05 [get_clocks CLK_CONFIG]

setup check會減少可用的有效時鐘周期

對于hold check,clock uncertainty被用作需要滿足的額外時序裕量

這里我的理解是,由于clock uncertainty的存在,減小了有效的時鐘周期,并且在clock uncertainty范圍內(nèi),我們無法預測clock是否有效,為了保證數(shù)據(jù)的正確性,在進行數(shù)據(jù)傳輸時,應當避開clock uncertainty的范圍

圖片

下面幾個command可以用來指定跨時鐘邊界path上的clock uncertainty,被稱為 inter-clock uncertainty

set_clock_uncertainty -from VIRTUAL-SYS_CLK -to SYSCLK -hold 0.05

set_clock_uncertainty -from VIRTUAL-SYS_CLK -to SYSCLK -setup 0.3

set_clock_uncertainty -from SYS_CLK -to CFG_CLK -hold 0.05

set_clock_uncertainty -from SYS_CLK -to CFG_CLK -setup 0.1

圖片

從圖中可以看到,該電路為兩個不同的clock domain SYS_CLK和CFG_CLK之間的path,根據(jù)上面約束可知,setup check的uncertainty是100ps,hold check的uncertainty是50ps

4 時鐘延遲

可以使用set_clock_latency來指定時鐘的延遲,用法如下:

set_clock_latency 1.8 -rise [get_clocks MAIN_CLK]
# MIN_CLK的上升沿延遲是1.8ns
set_clock_latency 2.1 -fall [all_clocks]
# 所有時鐘的下降沿延遲是2.1ns

# -rise和-fall指的是 時鐘在DFF的clock pin上的延遲

時鐘延遲有兩種:network latency和source latency

  • network latency:從時鐘定義點(creat_clock)到DFF的clock pin上的延遲
  • source latency:指的是從時鐘源到時鐘定義點的延遲

下圖直觀的展示了這兩個延遲類型的位置

圖片

以下是一些指定源延遲和網(wǎng)絡延遲的示例

# 沒有給出 -source 選項,表明是 network latency
# 沒有給出 -fall和-rise選項,表明fall和rise是相同的
# 沒有給出 -min和-max選項,表明min和max是相同的

set_clock_latency 0.8 [get_clocks CLK_CONFIG]

set_clock_latency 1.9 -source [get_clocks SYS_CLK]

set_clock_latency 0.851 -source -min [get_clocks CFG_CLK]

set_clock_latency 1.322 -source -max [get_clocks CFG_CLK]

一個重要的區(qū)別:

當clock tree建立后,network latency可以忽略,source latency不可以忽略

這是因為network latency的作用是在clock tree綜合之前用來估算clock tree上的latency,當clock tree綜合之后,我們可以計算出clock tree上的實際的latency,因此不在需要network latency

當clock tree綜合后,總的clock latency = source latency + clock tree上的實際latency

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 觸發(fā)器
    +關(guān)注

    關(guān)注

    14

    文章

    2000

    瀏覽量

    61257
  • 時鐘源
    +關(guān)注

    關(guān)注

    0

    文章

    93

    瀏覽量

    16005
  • PLL電路
    +關(guān)注

    關(guān)注

    0

    文章

    92

    瀏覽量

    6432
  • dff
    dff
    +關(guān)注

    關(guān)注

    0

    文章

    26

    瀏覽量

    3425
收藏 人收藏

    評論

    相關(guān)推薦

    【小e物聯(lián)網(wǎng)試用體驗】+小e做為AP和STA

    通過學習小e開發(fā)板的各種資料,了解到小e開發(fā)板可以作為AP、STA連接到路由器和AP+STA, AP就是無線接入點,無線網(wǎng)的創(chuàng)建者,也是網(wǎng)絡的中心節(jié)點,例如家用無線路由器就是一個典型的AP。S
    發(fā)表于 05-22 17:16

    USART程序USATR_RX_STA為什么要定義成無符號字符型

    研究了幾天還是沒有研究出來的問題,所以上來請教高手們。在《例說STM32》的USART部分,有u8USATR_RX_STA=0這一定義語句,我的問題是:1.USATR_RX_STA為什么要定義
    發(fā)表于 06-17 04:35

    MCU產(chǎn)生12MHz時鐘應用于ADC和STA339BW差異有多大?

    一個放大器系統(tǒng):ADC + STA339BW + MCU,MCU產(chǎn)生12MHz時鐘應用于ADC(連接到MCLK引腳)和STA339BW(連接到XTI引腳)。我不知道會有多少差異,這會影響THD
    發(fā)表于 07-22 16:10

    STM32時鐘學習記錄

    STM32 時鐘學習記錄時鐘樹介紹在STM32 時鐘系統(tǒng)中,有5 個重要的時鐘源:分別是LSI
    發(fā)表于 08-13 07:38

    FOC學習記錄

    FOC學習——第一天(20210208)##前言——20210208###為什么博客希望養(yǎng)成一個記錄和總結(jié)的好習慣學習的過程記錄就像日記,可追溯分享下
    發(fā)表于 08-17 07:15

    Wifi的STA模式連接wifi的過程分享

    Harmony OS 設備開發(fā)學習記錄(十四)–Wifi的STA模式連接wifi基于hispark wifi套件采用harmony os 2.0全量代碼一、在源碼中建立demo文件在app下建立
    發(fā)表于 02-15 06:14

    STA7056.pdf

    The STA7056 is a mono Bridge Amplifier assembled in single in line 9 pins package. The STA
    發(fā)表于 09-19 14:47 ?25次下載
    <b class='flag-5'>STA</b>7056.pdf

    C語言學習記錄筆記需要的趕緊下載學習

    本文檔的主要內(nèi)容詳細介紹的是C語言學習記錄筆記需要的趕緊下載學習
    發(fā)表于 02-12 08:00 ?7次下載
    C語言<b class='flag-5'>學習</b><b class='flag-5'>記錄</b>筆記需要的趕緊下載<b class='flag-5'>學習</b>

    GD32F407的時鐘學習記錄

    GD32F407的時鐘學習記錄起因: 因工作原因,使用到了國產(chǎn)的GD32F407,順便學習了下他們的時鐘,構(gòu)成,這里簡單講一下ADC,CAN
    發(fā)表于 11-29 17:36 ?16次下載
    GD32F407的<b class='flag-5'>時鐘</b><b class='flag-5'>學習</b><b class='flag-5'>記錄</b>

    用CubeMX開發(fā)HAL學習記錄(一)

    提示:文章寫完后,目錄可以自動生成,如何生成可參考右邊的幫助文檔用CubeMX開發(fā)HAL學習記錄(一)前言一、CubeMX基本特點1、集成MCU Finder功能,便于用戶進行芯片選型2、圖形化方式
    發(fā)表于 12-09 17:06 ?8次下載
    用CubeMX開發(fā)HAL<b class='flag-5'>學習</b><b class='flag-5'>記錄</b>(一)

    Harmony OS 設備開發(fā)學習記錄(十四)--Wifi的STA模式連接wifi

    Harmony OS 設備開發(fā)學習記錄(十四)–Wifi的STA模式連接wifi基于hispark wifi套件采用harmony os 2.0全量代碼一、在源碼中建立demo文件在app下建立
    發(fā)表于 12-14 19:09 ?2次下載
    Harmony OS 設備開發(fā)<b class='flag-5'>學習</b><b class='flag-5'>記錄</b>(十四)--Wifi的<b class='flag-5'>STA</b>模式連接wifi

    藍橋杯單片機學習過程記錄(八)時鐘芯片

    藍橋杯單片機學習過程記錄(八)時鐘芯片//時鐘芯片#include#includesbit sck=P1^7;sbit
    發(fā)表于 12-23 19:15 ?6次下載
    藍橋杯單片機<b class='flag-5'>學習</b>過程<b class='flag-5'>記錄</b>(八)<b class='flag-5'>時鐘</b>芯片

    藍橋杯單片機學習過程記錄(十四)第六屆溫度記錄

    藍橋杯單片機學習過程記錄(十四)第六屆溫度記錄結(jié)果實現(xiàn)的問題:時鐘和定時器兩個時間走的不同,定時器5ms下200次不是1s,差別挺大,沒找到什么原因。官方的底層驅(qū)動下,ds1302的
    發(fā)表于 12-29 19:19 ?11次下載
    藍橋杯單片機<b class='flag-5'>學習</b>過程<b class='flag-5'>記錄</b>(十四)第六屆溫度<b class='flag-5'>記錄</b>

    STM32 task3學習記錄

    寄存器的四位控制3.stm32f10x.h用宏定義的方式實現(xiàn)了地址映射4.GPIO_TypeDef用typedef關(guān)鍵字聲明了GPIO_TypeDef的結(jié)構(gòu)體類型,結(jié)構(gòu)體內(nèi)定義了七個_IO uint32_t類型的變量5.時鐘系統(tǒng)
    發(fā)表于 01-12 17:52 ?0次下載
    STM32 task3<b class='flag-5'>學習</b><b class='flag-5'>記錄</b>

    STM32F103學習筆記-時鐘

    本筆記簡要介紹了時鐘的相關(guān)定義和配置。
    發(fā)表于 01-18 08:31 ?2次下載
    STM32F103<b class='flag-5'>學習</b>筆記-<b class='flag-5'>時鐘</b>