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

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

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

教你們怎么去設(shè)定寄存器的初始值

FPGA技術(shù)驛站 ? 來源:Teacher Gao ? 作者:Teacher Gao ? 2021-04-01 10:27 ? 次閱讀

對于寄存器,如果沒有明確指定其初始值,Vivado會根據(jù)其類型(FDCE/FDRE/FDPE/FDRE)設(shè)定合適的初始值。有些工程師喜歡使用復位信號,對所有的寄存器進行上電復位,使其在處理數(shù)據(jù)之前達到期望初始狀態(tài)。但這會有一個不利之處就是復位信號的扇出很大,從而消耗了大量的布線資源,甚至造成布線擁塞。那么能不能讓寄存器在上電之后不用通過復位就輸出期望值呢?答案是肯定的。

Xilinx也建議對于同步元件,最好設(shè)定其初始值。這里我們以最常用的寄存器為例。如果使用的是VHDL,可以采用下面的方法設(shè)定寄存器初始值,如下圖所示。

ccd385aa-923c-11eb-8b86-12bb97331649.png

如果使用的是Verilog,可以采用下面的方法設(shè)定寄存器初始值,如下圖所示。

ccdf4f48-923c-11eb-8b86-12bb97331649.png

此外,對于Verilog,也可通過initial設(shè)定初始值,如下圖所示。

ccedec4c-923c-11eb-8b86-12bb97331649.png

采用這種方法的好處是:綜合工具是支持的,這樣生成bit文件時這些初始值會被寫入配置文件中,上電即可生效,避免了使用復位造成的扇出過大;同時在仿真時,也能跟實際業(yè)務(wù)相匹配。 為了驗證這個方法是否生效,只需要打開綜合后的.dcp,找到相應(yīng)的寄存器,在其Property窗口中查看屬性INIT的值,如下圖所示。

ccff28e0-923c-11eb-8b86-12bb97331649.png

編輯:jq

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

    關(guān)注

    31

    文章

    5271

    瀏覽量

    119654
  • 上電復位
    +關(guān)注

    關(guān)注

    1

    文章

    39

    瀏覽量

    15761
  • init
    +關(guān)注

    關(guān)注

    0

    文章

    16

    瀏覽量

    3418

原文標題:如何設(shè)定寄存器的初始值?

文章出處:【微信號:Lauren_FPGA,微信公眾號:FPGA技術(shù)驛站】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    詳解寄存器模型鏡像

    DUT的配置寄存器是實際,reg_model有鏡像、期望的概念。
    的頭像 發(fā)表于 10-23 09:43 ?44次閱讀
    詳解<b class='flag-5'>寄存器</b>模型鏡像<b class='flag-5'>值</b>

    TAS5733L按照初始化的寄存器配置,播放音樂無聲是怎么回事?

    按照貴司提供的初始化的寄存器配置(如附件)設(shè)置,讀取0x05,0x06也是設(shè)定。播放音樂此時仍然無聲。 請問,是否還有額外的寄存器需要
    發(fā)表于 10-21 07:41

    寄存器是什么意思?寄存器是如何構(gòu)成的?

    在計算機科學中,寄存器(Register)是一個高速存儲單元,它位于中央處理(CPU)內(nèi)部,用于存儲計算機程序執(zhí)行過程中所需要的數(shù)據(jù)、指令地址或狀態(tài)信息。寄存器是計算機體系結(jié)構(gòu)中至關(guān)重要的組成部分,對計算機的運算速度和性能有著
    的頭像 發(fā)表于 08-02 18:23 ?2471次閱讀
    <b class='flag-5'>寄存器</b>是什么意思?<b class='flag-5'>寄存器</b>是如何構(gòu)成的?

    寄存器尋址的實現(xiàn)方式

    在計算機體系結(jié)構(gòu)中,寄存器尋址是一種常見的尋址方式,它允許程序直接訪問CPU內(nèi)部的寄存器。寄存器尋址可以提高程序的執(zhí)行效率,因為它避免了對內(nèi)存的訪問。 寄存器尋址的基本概念
    的頭像 發(fā)表于 07-12 10:36 ?443次閱讀

    寄存器分為基本寄存器和什么兩種

    寄存器是計算機中用于存儲數(shù)據(jù)的高速存儲單元,它們是CPU內(nèi)部的重要組成部分。寄存器可以分為基本寄存器和擴展寄存器兩種類型。 一、基本寄存器
    的頭像 發(fā)表于 07-12 10:31 ?841次閱讀

    loop指令執(zhí)行時,隱含的寄存器

    當執(zhí)行l(wèi)oop指令時,隱含的寄存器是CX寄存器。CX寄存器是循環(huán)計數(shù)寄存器,它存儲了循環(huán)的迭代次數(shù)。 在匯編語言中,loop指令用于實現(xiàn)循
    的頭像 發(fā)表于 02-14 16:15 ?771次閱讀

    CPU的6個主要寄存器

    CPU寄存器是中央處理內(nèi)的組成部分,是有限存貯容量的高速存貯部件。寄存器是CPU內(nèi)部的元件,包括通用寄存器、專用寄存器和控制
    的頭像 發(fā)表于 02-03 15:15 ?3309次閱讀

    個人對STM32 SysTick的總結(jié)(寄存器操作)

    一、概述:SysTick是一個簡單的遞減24位計數(shù)。如果你不需要再應(yīng)用程序中嵌入操作系統(tǒng),SysTick可以作為簡單的延時和產(chǎn)生周期性的中斷。狀態(tài)控制寄存器的第0位可以使能計數(shù),當前
    的頭像 發(fā)表于 01-06 08:00 ?1593次閱讀
    個人對STM32 SysTick的總結(jié)(<b class='flag-5'>寄存器</b>操作)

    ADC轉(zhuǎn)換的時候OFFSET寄存器與FS寄存器怎么使用呢?

    您好, 我想問一下ADC轉(zhuǎn)換的時候這個OFFSET寄存器與FS寄存器怎么使用呢?比如說OFFSET的為0x80015b,這個
    發(fā)表于 12-15 06:28

    jvm配置堆內(nèi)存初始值參數(shù)

    程序中,堆內(nèi)存的初始值是非常重要的,它決定了程序在運行過程中能夠使用的內(nèi)存大小。因此,在優(yōu)化JVM性能的過程中,對于堆內(nèi)存初始值的合理配置是至關(guān)重要的。 首先,我們需要了解JVM中堆內(nèi)存的基本概念。堆
    的頭像 發(fā)表于 12-05 14:17 ?679次閱讀

    寄存器查看的功能和使用

    對于搞嵌入式底層開發(fā)的軟件或者硬件工程師來說,經(jīng)常會涉及到查看芯片手冊,比如某個芯片的串口控制寄存器,需要知道這個對應(yīng)寄存器的哪些位
    的頭像 發(fā)表于 11-28 12:26 ?1632次閱讀
    <b class='flag-5'>寄存器</b>查看<b class='flag-5'>器</b>的功能和使用

    UVM寄存器模型的常規(guī)方法有哪些呢?

    在應(yīng)用寄存器模型時, 除了利用它的寄存器信息, 還可以利用它來跟蹤寄存器。
    的頭像 發(fā)表于 11-25 09:27 ?1595次閱讀
    UVM<b class='flag-5'>寄存器</b>模型的常規(guī)方法有哪些呢?

    MSP430F5529硬件IIC驅(qū)動OLED(初始化使用的寄存器)

    MSP430F5529硬件IIC驅(qū)動OLED(初始化使用的寄存器)
    發(fā)表于 11-24 16:36 ?1次下載

    寄存器開發(fā),HAL開發(fā)和LL開發(fā)的區(qū)別和參考代碼

    1,寄存器開發(fā)【難度:難】寄存器開發(fā)是一種直接訪問微控制寄存器的編程方法,它提供了對硬件的極大靈活性和直接控制。在
    的頭像 發(fā)表于 11-17 08:00 ?1164次閱讀
    <b class='flag-5'>寄存器</b>開發(fā),HAL開發(fā)和LL開發(fā)的區(qū)別和參考代碼

    gic的寄存器 gicv3的LPI中斷

    (1)gicv2的寄存器 gicv2寄存器,都是使用memory-mapped的方式訪問的 ? ?GICD_: distributor的寄存器 ? ?GICH_: 虛擬interfa
    的頭像 發(fā)表于 11-08 16:09 ?641次閱讀