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

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

3天内不再提示

控制类寄存器的两种实现方式

ruikundianzi 来源:IC的世界 作者:IC的世界 2023-10-17 10:36 次阅读

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

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

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

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

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

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

f2de41c6-6c56-11ee-939d-92fbcf53809c.png

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

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

优点:

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

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

缺点:

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

不利于规模扩展,例如client_id数量从8增加到800时,寄存器的数量会大量增加,且800选1的逻辑延时较大。

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

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

优点:

规模扩展方便,例如client_id数量从8增加到800,仅仅需要修改cfg_ram的规模,重新定义一下cfg_ram读地址位宽,data_proc_a/b/c仅仅需要修改client_id位宽参数

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

缺点:

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

审核编辑:汤梓红

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

    关注

    30

    文章

    5036

    浏览量

    117762
  • 接口
    +关注

    关注

    33

    文章

    7643

    浏览量

    148520
  • 信号
    +关注

    关注

    11

    文章

    2640

    浏览量

    75392
  • PCIe
    +关注

    关注

    13

    文章

    1083

    浏览量

    80865

原文标题:IC设计:控制类寄存器2种实现方式

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

收藏 人收藏

    评论

    相关推荐

    dm9000读写寄存器的问题

    )方式2的函数名为phy_read,估摸着意思是读网卡芯片的寄存器,但我看DM9000的时候只看到一寄存器,并没有分成两类,那么这
    发表于 10-31 16:13

    C语言访问MCU寄存器两种方式

    来源网络单片机的特殊功能寄存器SFR,是SRAM地址已经确定的SRAM单元,在C语言环境下对其访问归纳起来有两种方法。1、采用标准C的强制类型转换和指针来实现采用标准C的强制转换和指针的概念来
    发表于 03-07 17:00

    C语言访问MCU寄存器两种方式

    来源 网络存SFR,是SRAM地址已经确定的SRAM单元,在C语言环境下对其访问归纳起来有两种方法。1、采用标准C的强制类型转换和指针来实现 采用标准C的强制转换和指针的概念来实现访
    发表于 05-04 08:53

    C语言访问MCU寄存器两种方式

    单片机的特殊功能寄存器SFR,是SRAM地址已经确定的SRAM单元,在C语言环境下对其访问归纳起来有两种方法。1采用标准C的强制类型转换和指针来实现采用标准C的强制转换和指针的概念来实现
    发表于 03-01 10:17

    两种方式实现C语言访问MCU寄存器

    来源 网络单片机的特殊功能寄存器SFR,是SRAM地址已经确定的SRAM单元,在C语言环境下对其访问归纳起来有两种方法。 1、采用标准C的强制类型转换和指针来实现 采用标准C的强制转换和指针的概念来
    发表于 04-19 14:45

    如何实现C语言访问MCU寄存器?掌握这两种方式就够了!

    单片机的特殊功能寄存器SFR,是SRAM地址已经确定的SRAM单元,在C语言环境下对其访问归纳起来有两种方法。1采用标准C的强制类型转换和指针来实现采用标准C的强制转换和指针的概念来实现
    发表于 07-13 14:51

    汽车控制器的CAN唤醒和硬线唤醒两种方式比较?

    控制器两种唤醒方式,一个是硬线唤醒,通过IGN线实现控制器的上电;另一是通过接收CAN信号
    发表于 10-11 14:51

    如何实现C语言访问MCU寄存器?掌握这两种方式就够了!

    单片机的特殊功能寄存器SFR,是SRAM地址已经确定的SRAM单元,在C语言环境下对其访问归纳起来有两种方法。1、采用标准C的强制类型转换和指针来实现采用标准C的强制转换和指针的概念来实现
    发表于 03-08 09:42

    ROM和RAM这两种寄存器的区别是什么呢

    ROM或者对于玩电脑的人并不陌生,什么内存3G(内存就是RAM),硬盘100G(硬盘就是ROM)单片机里面和电脑一样,有ROM和RAM之分..那这两种寄存器的区别是什么呢?1 . ROM的功能:ROM的数据在程序运行的时候是不容改变的,除非你再次烧写程序,他就会改变,就像
    发表于 03-01 07:35

    寄存器寻址方式

    寄存器寻址方式   寄存器寻址是对由指令选定的工作寄存器(R0--R7)进行读/写,由指令操作码字节的最低3位指明所寻址的工作寄存器
    发表于 03-14 15:29 2558次阅读

    寄存器间接寻址方式

    寄存器间接寻址方式   寄存器间接寻址是将指定的寄存器内容为地址,由该地址所指定的单元内容作为操作数。MCS-51规定R2或R1为间接寻址
    发表于 03-14 15:29 4833次阅读

    寄存器实现步进电机速度控制

    介绍一种用寄存器实现电机速度控制的方法该方法占用空间小控制灵活能方便地实现电机速度控制!
    发表于 04-06 15:24 14次下载

    C语言访问MCU寄存器两种方式

    单片机的特殊功能寄存器SFR,是SRAM地址已经确定的SRAM单元,在C语言环境下对其访问归纳起来有两种方法。
    发表于 04-11 06:01 10次下载
    C语言访问MCU<b class='flag-5'>寄存器</b>的<b class='flag-5'>两种</b><b class='flag-5'>方式</b>

    如何实现C语言访问MCU寄存器?掌握这两种方式就够了!

    单片机的特殊功能寄存器SFR,是SRAM地址已经确定的SRAM单元,在C语言环境下对其访问归纳起来有两种方法。1、采用标准C的强制类型转换和指针来实现采用标准C的强制转换和指针的概念来实现
    发表于 11-21 19:21 14次下载
    如何<b class='flag-5'>实现</b>C语言访问MCU<b class='flag-5'>寄存器</b>?掌握这<b class='flag-5'>两种</b><b class='flag-5'>方式</b>就够了!

    控制寄存器2种实现方式

    下图所示,data_in为输入数据,data_out是处理后的数据,处理过程中data_proc_a/b/c需要用到控制寄存器对处理进行处理,client_id表示data的id号,模块采用时分复用的方式处理不同id的data。
    的头像 发表于 09-05 14:54 1115次阅读