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

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

3天内不再提示

控制类寄存器2种实现方式

倩倩 来源:CSDN 作者:CSDN 2022-09-05 14:54 次阅读

控制类寄存器2种实现方式

在数据处理过程中,需要一些可配置的寄存器,用于控制数据处理过程中的行为,如果各类处理信号的使能信号,还有功能模块的特定控制信号。

例如:在ETH处理过程中,有数据流使能控制,最大包长度控制信号。

例如:在PCIE中,存在bus master enable信号,max payload size等控制信号。

那么这类可配置的控制类寄存器是如何在数据处理过程中起作用的呢?有哪些实现方式呢?

下图所示,data_in为输入数据,data_out是处理后的数据,处理过程中data_proc_a/b/c需要用到控制寄存器对处理进行处理,client_id表示data的id号,模块采用时分复用的方式处理不同id的data。

60356820-2cd0-11ed-ba43-dac502259ad0.png

实现方式1: 寄存器信号线输出

通过寄存器信号线的方式输出给需要的模块,如图方式1,cfg module把所有的控制信号都暴露出来,送给需要的模块data_proc_a/b/c,data有效时,根据client_id选择需要的控制信号。

优点:

-此类设计简单,容易理解与实现。

-此设计限制小,可以用于各类情况下的设计

缺点:

-控制信号线较多,高频设计不利于布局布线

-不利于规模扩展,例如client_id数量从8增加到16,需要修改大量的代码。

实现方式2: 逻辑通过类ram接口主动获取

此设计中,控制寄存器以ram(或者类似)的方式实现,数据处理模块data_proc_a主动读取控制信号,当有效数据来临时,以client_id作为rdaddr读取,一次读取处理流程中所需的控制信号(rdata),进行数据处理,并且将控制信号(rdata)进行pipe与data对齐,提供给后期模块data_proc_b/c

优点:

-规模扩展方便,例如client_id数量从8增加到16,仅限cfg_ram的规模修改,data_proc_a/b/c仅仅需要修改client_id位宽参数

-控制信号线较少,有利于时序优化和布局布线

缺点:

-此设计适用于数据的pipeline处理,并且ram读出存在一定的读延时,存在一定限制。

一种主动的流控实现方式

1、流控机制

在数据发送过程中,发送者向接收者发送数据,通常需要接收者通知发送者自身是否可以接收数据,当接收者即将无法接收数据时(如FIFO快满时),发送者需要停止发送数据,这就是流控机制。

605c172c-2cd0-11ed-ba43-dac502259ad0.png

2、流控机制过程

初始化流程:

(1)复位释放后,初始化,module b 通过信号fc_update_signal 通知module a 自身fifo深度是多少

(2)Tx_fc_ctrl 收到初始化信息后,得知module b存在有效fifo 缓存,通知ren_ctrl允许产生读使能ren

(3)ren_ctrl产生读使能ren

(4)ren输出给tx_fc_ctrl,module b的有效fifo深度减一

(5)tx_fc_ctrl计算module b是否存在有效数据,有则允许ren_ctrl产生读使能

(6)ren_ctrl产生读使能ren,并通知到tx_fc_ctrl,module b的有效fifo深度减一

(7)tx_fc_ctrl计算module b是否存在有效数据,有则允许ren_ctrl产生读使能,没有则不允许ren_ctrl产生读使能

(a)Module b模块fifo已存在有效数据,从fifo读取一个数据,此时已释放出一个fifo深度

(b)Fc_update更新fc_update_signal,通知tx_fc_ctrl模块module b已释放一个fifo空间,tx_fc_ctrl记录的有效深度加1

(c)此时tx_fc_ctrl允许ren_ctrl产生读使能

3、特点说明

此种流控机制需要发送端和接收端配合管理有效缓存空间。相对比单一bit的flow ctrl信号来说,稍微复杂一些,但是有个显著的优点,相对于被动流控机制(见IC设计高级006:流控反压机制导致的路径延时),能够有效减少module b中的Data fifo的深度。

如图,data pipeline的深度是不确定的,可能是20~100个周期,而流控信号只有4个pipe,在考虑其他方面的延时有3拍,

不考虑性能的情况下:保证不溢出,module b的fifo深度最小需要:

本文流控机制:深度为1 ; 被动流控机制:深度为1+100+4+3

满足最大性能的情况下,保证下游不断流:module b的fifo深度需要:

本文流控机制:100+4+3+1 ; 被动流控机制:2*(100+4+3+1)

审核编辑 :李倩

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

    关注

    31

    文章

    5310

    浏览量

    119983
  • 控制信号
    +关注

    关注

    0

    文章

    162

    浏览量

    11948

原文标题:IC设计知识点:控制类寄存器两种实现方式等

文章出处:【微信号:IP与SoC设计,微信公众号:IP与SoC设计】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    接口的控制与状态寄存器什么作用

    的行为并获取硬件的状态信息。 接口的控制与状态寄存器的作用 在现代计算机系统中,硬件设备与软件之间的交互是通过一系列的接口来实现的。这些接口不仅需要能够传输数据,还需要能够控制硬件设备
    的头像 发表于 10-17 10:42 259次阅读

    什么是寄存器移位寻址

    寄存器移位寻址是一特定的寻址方式,主要出现在某些处理架构中,如ARM指令集。这种寻址方式在处理数据移动和操作时提供了极大的灵活性和效率。
    的头像 发表于 10-05 17:38 282次阅读

    寄存器间接寻址和寄存器寻址的区别

    寄存器间接寻址和寄存器寻址是计算机体系结构中两重要的寻址方式,它们在指令执行过程中起着关键作用。下面将从定义、原理、特点、应用场景以及区别等方面对这两
    的头像 发表于 10-05 17:13 771次阅读

    寄存器的类型和作用

    在计算机科学中,寄存器(Register)是一高速存储单元,它位于CPU内部,与CPU的运算单元和逻辑控制单元紧密相连。寄存器的主要作用是暂时存储指令、操作数和地址等临时数据,以便C
    的头像 发表于 09-05 14:11 1054次阅读

    寄存器的输入输出方式

    寄存器的输入输出方式是数字电路设计中至关重要的部分,它决定了数据如何在寄存器中进出以及处理的效率。下面将详细探讨寄存器的几种主要输入输出方式
    的头像 发表于 09-05 14:09 745次阅读

    寄存器寻址和直接寻址的区别

    寄存器寻址和直接寻址是计算机指令系统中的两基本寻址方式。它们在指令的执行过程中起着至关重要的作用,决定了指令操作数的来源和目标。下面我们将介绍这两寻址
    的头像 发表于 07-12 10:42 1277次阅读

    寄存器寻址的实现方式

    在计算机体系结构中,寄存器寻址是一常见的寻址方式,它允许程序直接访问CPU内部的寄存器寄存器寻址可以提高程序的执行效率,因为它避免了对内
    的头像 发表于 07-12 10:36 552次阅读

    寄存器分为基本寄存器和什么两

    寄存器是计算机中用于存储数据的高速存储单元,它们是CPU内部的重要组成部分。寄存器可以分为基本寄存器和扩展寄存器两种类型。 一、基本寄存器
    的头像 发表于 07-12 10:31 1101次阅读

    具有三态输出寄存器的 SN74HCT595-Q1 汽车8位移位寄存器数据表

    电子发烧友网站提供《具有三态输出寄存器的 SN74HCT595-Q1 汽车8位移位寄存器数据表.pdf》资料免费下载
    发表于 05-11 10:59 0次下载
    具有三态输出<b class='flag-5'>寄存器</b>的 SN74HCT595-Q1 汽车<b class='flag-5'>类</b>8位移位<b class='flag-5'>寄存器</b>数据表

    具有施密特触发输入和输出寄存器的汽车8位移位寄存器SN74HCS594-Q1数据表

    电子发烧友网站提供《具有施密特触发输入和输出寄存器的汽车8位移位寄存器SN74HCS594-Q1数据表.pdf》资料免费下载
    发表于 05-08 10:24 1次下载
    具有施密特触发输入和输出<b class='flag-5'>寄存器</b>的汽车<b class='flag-5'>类</b>8位移位<b class='flag-5'>寄存器</b>SN74HCS594-Q1数据表

    具有三态输出寄存器的汽车 8位移位寄存器SN74AHC165-Q1数据表

    电子发烧友网站提供《具有三态输出寄存器的汽车 8位移位寄存器SN74AHC165-Q1数据表.pdf》资料免费下载
    发表于 05-06 11:20 0次下载
    具有三态输出<b class='flag-5'>寄存器</b>的汽车<b class='flag-5'>类</b> 8位移位<b class='flag-5'>寄存器</b>SN74AHC165-Q1数据表

    带输出寄存器的汽车8位移位寄存器SN74LV8T594-Q1数据表

    电子发烧友网站提供《带输出寄存器的汽车8位移位寄存器SN74LV8T594-Q1数据表.pdf》资料免费下载
    发表于 04-29 10:07 0次下载
    带输出<b class='flag-5'>寄存器</b>的汽车<b class='flag-5'>类</b>8位移位<b class='flag-5'>寄存器</b>SN74LV8T594-Q1数据表

    CPU的6个主要寄存器

    CPU寄存器是中央处理内的组成部分,是有限存贮容量的高速存贮部件。寄存器是CPU内部的元件,包括通用寄存器、专用寄存器
    的头像 发表于 02-03 15:15 3880次阅读

    移位寄存器的工作原理 移位寄存器左移和右移怎么算

    移位寄存器是一用于在数字电路中实现数据移位操作的基本电路元件。它由多个触发以及相关控制电路组成,具有存储、接受和移动数据的功能。移位
    的头像 发表于 01-18 10:52 7231次阅读

    寄存器查看的功能和使用

    对于搞嵌入式底层开发的软件或者硬件工程师来说,经常会涉及到查看芯片手册,比如某个芯片的串口控制器寄存器值,需要知道这个值对应寄存器的哪些位,微软计算的程序员模式虽然可以查看
    的头像 发表于 11-28 12:26 1841次阅读
    <b class='flag-5'>寄存器</b>查看<b class='flag-5'>器</b>的功能和使用