在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

FPGA時序約束案例之多周期路徑約束的四個步驟

454398 ? 來源:科學計算technomania ? 作者:貓叔 ? 2020-11-14 11:13 ? 次閱讀

作者:貓叔

多周期路徑約束

多周期路徑,我們一般按照以下4個步驟來約束:

1. 帶有使能的數據

首先來看帶有使能的數據,在本工程中的Tming Report中,也提示了同一個時鐘域之間的幾個路徑建立時間不滿足要求


其實這幾個路徑都是帶有使能的路徑,使能的周期為2倍的時鐘周期,本來就應該在2個時鐘周期內去判斷時序收斂。因此,我們添加時序約束:

set_multicycle_path 2 -setup -from [get_cells {cmd_parse_i0/send_resp_data_reg[*]} -include_replicated_objects] -to [get_cells {resp_gen_i0/to_bcd_i0/bcd_out_reg[*]}]
set_multicycle_path 1 -hold -from [get_cells {cmd_parse_i0/send_resp_data_reg[*]} -include_replicated_objects] -to [get_cells {resp_gen_i0/to_bcd_i0/bcd_out_reg[*]}]

也可以寫為:

set_multicycle_path -from [get_cells {cmd_parse_i0/send_resp_data_reg[*]} -include_replicated_objects] -to [get_cells {resp_gen_i0/to_bcd_i0/bcd_out_reg[*]}] 2
set_multicycle_path -hold -from [get_cells {cmd_parse_i0/send_resp_data_reg[*]} -include_replicated_objects] -to [get_cells {resp_gen_i0/to_bcd_i0/bcd_out_reg[*]}] 1

這兩種寫法是等價的。

我們也可以直接點擊右鍵通過GUI的方式進行約束,效果都是一樣的。

在工程的uart_tx_ctl.v和uart_rx_ctl.v文件中,也存在帶有使能的數據,但這些路徑在未加多路徑約束時并未報出時序錯誤或者警告。

在接收端,捕獲時鐘頻率是200MHz,串口速率是115200,采用16倍的Oversampling,因此使能信號周期是時鐘周期的200e6/115200/16=108.5倍。

在接收端,捕獲時鐘頻率是166667MHz,串口速率是115200,采用16倍的Oversampling,因此使能信號周期是時鐘周期的166.667e6/115200/16=90.4倍。

因此,時序約束如下:

# 串口接收端
set_multicycle_path  -from [get_cells uart_rx_i0/uart_rx_ctl_i0/* -filter IS_SEQUENTIAL] -to [get_cells uart_rx_i0/uart_rx_ctl_i0/* -filter IS_SEQUENTIAL] 108
set_multicycle_path -hold -from [get_cells uart_rx_i0/uart_rx_ctl_i0/* -filter IS_SEQUENTIAL] -to [get_cells uart_rx_i0/uart_rx_ctl_i0/* -filter IS_SEQUENTIAL] 107
# 串口發送端
set_multicycle_path -from [get_cells uart_tx_i0/uart_tx_ctl_i0/* -filter IS_SEQUENTIAL] -to [get_cells uart_tx_i0/uart_tx_ctl_i0/* -filter IS_SEQUENTIAL] 90
set_multicycle_path -hold -from [get_cells uart_tx_i0/uart_tx_ctl_i0/* -filter IS_SEQUENTIAL] -to [get_cells uart_tx_i0/uart_tx_ctl_i0/* -filter IS_SEQUENTIAL] 89

約束中的filter參數也將在下一章節具體講解。

2. 兩個有數據交互的時鐘之間存在相位差

在本工程中,沒有這種應用場景,因此不需要添加此類約束。

3. 存在快時鐘到慢時鐘的路徑

在本工程中,沒有這種應用場景,因此不需要添加此類約束。

4. 存在慢時鐘到快時鐘的路徑

在本工程中,沒有這種應用場景,因此不需要添加此類約束。

綜上,我們所有的時序約束如下:

# 主時鐘約束
create_clock -period 25.000 -name clk2 [get_ports clk_in2]

# 衍生時鐘約束
create_generated_clock -name clk_samp -source [get_pins clk_gen_i0/clk_core_i0/clk_tx] -divide_by 32 [get_pins clk_gen_i0/BUFHCE_clk_samp_i0/O]
create_generated_clock -name spi_clk -source [get_pins dac_spi_i0/out_ddr_flop_spi_clk_i0/ODDR_inst/C] -divide_by 1 -invert [get_ports spi_clk_pin]
create_generated_clock -name clk_tx -source [get_pins clk_gen_i0/clk_core_i0/inst/mmcm_adv_inst/CLKIN1] [get_pins clk_gen_i0/clk_core_i0/inst/mmcm_adv_inst/CLKOUT1]
create_generated_clock -name clk_rx -source [get_pins clk_gen_i0/clk_core_i0/inst/mmcm_adv_inst/CLKIN1] [get_pins clk_gen_i0/clk_core_i0/inst/mmcm_adv_inst/CLKOUT0]

# 設置異步時鐘
set_clock_groups -asynchronous -group [get_clocks clk_samp] -group [get_clocks clk2]

# 延遲約束
create_clock -period 6.000 -name virtual_clock
set_input_delay -clock [get_clocks -of_objects [get_ports clk_pin_p]] 0.000 [get_ports rxd_pin]
set_input_delay -clock [get_clocks -of_objects [get_ports clk_pin_p]] -min -0.500 [get_ports rxd_pin]
set_input_delay -clock virtual_clock -max 0.000 [get_ports lb_sel_pin]
set_input_delay -clock virtual_clock -min -0.500 [get_ports lb_sel_pin]
set_output_delay -clock virtual_clock -max 0.000 [get_ports {txd_pin {led_pins[*]}}]
set_output_delay -clock virtual_clock -min -0.500 [get_ports {txd_pin {led_pins[*]}}]
set_output_delay -clock spi_clk -max 1.000 [get_ports {spi_mosi_pin dac_cs_n_pin dac_clr_n_pin}]
set_output_delay -clock spi_clk -min -1.000 [get_ports {spi_mosi_pin dac_cs_n_pin dac_clr_n_pin}]

# 偽路徑約束
set_false_path -from [get_clocks clk_rx] -to [get_clocks clk_tx]
set_false_path -from [get_ports rst_pin]

# 多周期約束
set_multicycle_path 2 -setup -from [get_cells {cmd_parse_i0/send_resp_data_reg[*]} -include_replicated_objects] -to [get_cells {resp_gen_i0/to_bcd_i0/bcd_out_reg[*]}]
set_multicycle_path 1 -hold -from [get_cells {cmd_parse_i0/send_resp_data_reg[*]} -include_replicated_objects] -to [get_cells {resp_gen_i0/to_bcd_i0/bcd_out_reg[*]}]

# 串口接收端
set_multicycle_path 108 -setup -from [get_cells uart_rx_i0/uart_rx_ctl_i0/* -filter IS_SEQUENTIAL] -to [get_cells uart_rx_i0/uart_rx_ctl_i0/* -filter IS_SEQUENTIAL]
set_multicycle_path 107 -hold -from [get_cells uart_rx_i0/uart_rx_ctl_i0/* -filter IS_SEQUENTIAL] -to [get_cells uart_rx_i0/uart_rx_ctl_i0/* -filter IS_SEQUENTIAL]
# 串口發送端
set_multicycle_path 90 -setup -from [get_cells uart_tx_i0/uart_tx_ctl_i0/* -filter IS_SEQUENTIAL] -to [get_cells uart_tx_i0/uart_tx_ctl_i0/* -filter IS_SEQUENTIAL] 
set_multicycle_path 89 -hold -from [get_cells uart_tx_i0/uart_tx_ctl_i0/* -filter IS_SEQUENTIAL] -to [get_cells uart_tx_i0/uart_tx_ctl_i0/* -filter IS_SEQUENTIAL]

重新Synthesis并Implementation后,可以看到,已經沒有了時序錯誤


僅有的兩個warning也只是說rst沒有設置input_delay,spi_clk_pin沒有設置output_delay,但我們已經對rst設置了偽路徑,而spi_clk_pin是我們約束的輸出時鐘,無需設置output_delay。

到這里,教科書版的時序約束教程就基本講完了。但我們平時的工程中,跟上面這種約束還是有差異的:

首先是虛擬時鐘,這個約束在平時的工程中基本不會用到,像需要設置虛擬時鐘的場景,我們也都是通過設計來保證時序收斂,設置虛擬時鐘的意義不大。

第二就是output delay,在FPGA的最后一級寄存器到輸出的路徑上,往往都使用了IOB,也就是IO block,因此最后一級寄存器的位置是固定的,從buffer到pad的走線延時是確定的。在這種情況下,是否滿足時序要求完全取決于設計,做約束只是驗證一下看看時序是否收斂。所以也基本不做。但是input delay是需要的,因為這是上一級器件輸出的時序關系。

第三個就是多周期路徑,我們講了那么多多周期路徑的應用場景,但實際我們是根據Timing report來進行約束的,即便那幾種場景都存在,但如果Timing report中沒有提示任何的時序 warning,我們往往也不會去添加約束。

第四個就是在設置了多周期后,如果還是提示Intra-Clocks Paths的setup time不過,那就要看下程序,是否寫的不規范。比如

如果設置了多周期路徑后,還是提示Intra-Clocks Paths的setup time不過,那就要看下程序,是否寫的不規范。比如

always @ (posedge clk)
begin
    regA <= regB;

    if(regA != regB)
        regC <= 4'hf;
    else 
        regC <= {regC[2:0], 1'b0};

    if((&flag[3:0]) && regA != regB) 
        regD <= regB;
end

這么寫的話,如果時鐘頻率稍微高一點,比如250MHz,就很容易導致從regB到regD的setup time不滿足要求。因為begin end里面的代碼都是按順序執行的,要在4ns內完成這些賦值與判斷的邏輯,挑戰還是挺大的。因此,我們可以改寫為:

always @ (posedge clk)
begin
    regA <= regB;
end 

always @ (posedge clk)
begin
    if(regA != regB)
        regC <= 4'hf;
    else 
        regC <= {regC[2:0], 1'b0};
end 

always @ (posedge phy_clk)
begin
    if((&flag[3:0]) && regA != regB) 
        regD <= regB;
end 

把寄存器的賦值分開,功能還是一樣的,只是分到了幾個always中,這樣就不會導致時序問題了。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1629

    文章

    21759

    瀏覽量

    604272
  • 寄存器
    +關注

    關注

    31

    文章

    5357

    瀏覽量

    120656
  • 時序約束
    +關注

    關注

    1

    文章

    115

    瀏覽量

    13432
收藏 人收藏

    評論

    相關推薦

    FPGA的IO口時序約束分析

      在高速系統中FPGA時序約束不止包括內部時鐘約束,還應包括完整的IO時序約束
    發表于 09-27 09:56 ?1762次閱讀

    FPGA時序約束之衍生時鐘約束和時鐘分組約束

    FPGA設計中,時序約束對于電路性能和可靠性非常重要。在上一篇的文章中,已經詳細介紹了FPGA時序約束
    發表于 06-12 17:29 ?2783次閱讀

    FPGA時序約束之偽路徑和多周期路徑

    前面幾篇FPGA時序約束進階篇,介紹了常用主時鐘約束、衍生時鐘約束、時鐘分組約束的設置,接下來介
    發表于 06-12 17:33 ?1849次閱讀

    FPGA時序約束時序路徑時序模型

    時序路徑作為時序約束時序分析的物理連接關系,可分為片間路徑和片內
    發表于 08-14 17:50 ?825次閱讀
    <b class='flag-5'>FPGA</b><b class='flag-5'>時序</b><b class='flag-5'>約束</b>之<b class='flag-5'>時序</b><b class='flag-5'>路徑</b>和<b class='flag-5'>時序</b>模型

    FPGA I/O口時序約束講解

    前面講解了時序約束的理論知識FPGA時序約束理論篇,本章講解時序
    發表于 08-14 18:22 ?1693次閱讀
    <b class='flag-5'>FPGA</b> I/O口<b class='flag-5'>時序</b><b class='flag-5'>約束</b>講解

    FPGA時序約束--基礎理論篇

    FPGA開發過程中,離不開時序約束,那么時序約束是什么?簡單點說,FPGA芯片中的邏輯電路,從輸
    發表于 11-15 17:41

    FPGA時序約束方法

    FPGA時序約束方法很好地資料,兩大主流的時序約束都講了!
    發表于 12-14 14:21 ?19次下載

    FPGA開發之時序約束周期約束

    時序約束可以使得布線的成功率的提高,減少ISE布局布線時間。這時候用到的全局約束就有周期約束和偏移約束
    發表于 02-09 02:56 ?725次閱讀

    FPGA中的時序約束設計

    好的FPGA設計一定是包含兩層面:良好的代碼風格和合理的約束時序約束作為
    發表于 11-17 07:54 ?2575次閱讀
    <b class='flag-5'>FPGA</b>中的<b class='flag-5'>時序</b><b class='flag-5'>約束</b>設計

    FPGA時序約束案例:偽路徑約束介紹

    路徑約束 在本章節的2 約束主時鐘一節中,我們看到在不加時序約束時,Timing Report會提示很多的error,其中就有跨時鐘域的e
    的頭像 發表于 11-14 11:28 ?3007次閱讀
    <b class='flag-5'>FPGA</b><b class='flag-5'>時序</b><b class='flag-5'>約束</b>案例:偽<b class='flag-5'>路徑</b><b class='flag-5'>約束</b>介紹

    FPGA時序約束的概念和基本策略

    A 時序約束的概念和基本策略 時序約束主要包括周期約束(FFS到FFS,即觸發器到觸發器)和偏移約束
    的頭像 發表于 09-30 15:17 ?5115次閱讀

    FPGA設計之時序約束四大步驟

    本文章探討一下FPGA時序約束步驟,本文章內容,來源于配置的明德揚時序約束專題課視頻。
    發表于 03-16 09:17 ?3594次閱讀
    <b class='flag-5'>FPGA</b>設計之<b class='flag-5'>時序</b><b class='flag-5'>約束</b><b class='flag-5'>四大步驟</b>

    FPGA設計之時序約束

    上一篇《FPGA時序約束分享01_約束四大步驟》一文中,介紹了時序
    發表于 03-18 10:29 ?1680次閱讀
    <b class='flag-5'>FPGA</b>設計之<b class='flag-5'>時序</b><b class='flag-5'>約束</b>

    淺談FPGA時序約束四大步驟

    很多讀者對于怎么進行約束約束步驟過程有哪些等,不是很清楚。明德揚根據以往項目的經驗,把時序約束步驟
    的頭像 發表于 07-02 10:56 ?5569次閱讀
    淺談<b class='flag-5'>FPGA</b>的<b class='flag-5'>時序</b><b class='flag-5'>約束</b><b class='flag-5'>四大步驟</b>

    FPGA時序約束的原理是什么?

    FPGA開發過程中,離不開時序約束,那么時序約束是什么?簡單點說,FPGA芯片中的邏輯電路,從輸
    發表于 06-26 14:42 ?728次閱讀
    <b class='flag-5'>FPGA</b><b class='flag-5'>時序</b><b class='flag-5'>約束</b>的原理是什么?
    主站蜘蛛池模板: 亚洲第一福利网站| 四虎影院成人| 九九黄色网| 婷婷网址| 亚洲zscs综合网站| 91精品国产91久久久久青草| 欧美高清milf在线播放| 色天使亚洲| 视频在线观看一区二区三区| 国模私拍一区二区三区| 欧美成人精品| 免费一看一级毛片| 男人的天堂97| 久久奈| 九九涩| 国产手机免费视频| 国产精品亚洲四区在线观看| 亚洲免费色| 综合久色| 国产黄色一级网站| 久久老色鬼天天综合网观看| 人人爽人人干| 国产破苞合集 magnet| 福利盒子手机看片| 午夜h| 亚洲黄网站wwwwww| 波多野结衣福利| 色涩网站在线观看| 狼人久草| 超级乱淫小黄文小说| 西西人体www303sw大胆高清| 天堂最新版在线地址| 色444| 超薄肉色丝袜精品足j福利| 天天色色色| 香蕉成人国产精品免费看网站| 国产chinesehd精品酒店| 我不卡老子影院午夜伦我不卡四虎| 免费午夜视频在线观看| 国产高清在线精品| 91操视频|