• Rocket


    https://mp.weixin.qq.com/s/03BvgTNQtD75Guco6gUGQg

     
    简单介绍BusWrapper的实现。
     
    1. HasTLBusParams
     
    定义SoC的挂载点相关的宽度信息:
    a. beatBytes:一个时钟周期最大能请求的字节数;
    b. blockBytes:(推测)一次请求(可以包含多个beat)最大能请求的字节数;
     
    其他的通过这两个参数生成:
    a. beatBits:把beatBytes换算成位数;
    b. blockBits:把blockBytes换算成位数;
    c. blockBeats:最大的请求包含多少个beat;
    d. blockOffset:为block中的每个字节编址所需要的位数;
     
    限制条件:
    a. beatBytes需要是2的幂;
    b. blockBytes需要是2的幂;
     
    2. TLBusWrapper
     
    对总线(Bus)进行包装,是一个LazyModule:
     
    1) 类参数
     
    a. params:HasTLBusParams类型,传入基本宽度信息;
    b. busName:总线名称;
     
    2) 基本宽度信息
     
     
    3) inwardNode/outwardNode/Edge
     
     
    4) unifyManagers
     
    合并能力一致的manager的地址集合:
     
    5) crossHelper
     
    生成跨越时钟域的Helper:
     
    6) to/from
     
     
    a. to是指outwardNode在body中使用输出边连接到某个节点;
     
    b. from是指inwardNode在body中使用输入边连接到某个节点;
     
    7) coupleTo/coupleFrom
     
     
    coupleTo/coupleFrom与to/from类似,只是把outwardNode作为参数传入。
     
    这样避免了与TLBusWrapper的继承关系:
    a. 使用to/from方法的类,需要继承TLBusWrapper类,才能访问到outwardNode/inwardNode;
    b. 使用coupleTo/coupleFrom的类,则不需要继承TLBusWrapper类,因为outwardNode/inwardNode作为参数传入;
     
    8) crossToBus/crossFromBus
     
    a. crossToBus:outwardNode跨时钟域输出连接到参数中指定的bus;
    b. crossFromBus:inwardNode跨时钟域输入连接到参数中指定的bus;
     
    3. CanAttachTLSlaves
     
    可以连接下游节点。使用该trait的类需要继承自TLBusWrapper:
     
    1) toSlave
     
    outwardNode输出到gen生成的slave:
     
    2) toVariableWidthSlaveNodeOption
     
    outwardNode输出到参数传入的node:
     
    3) toVariableWidthSlaveNode
     
     
    4) toVariableWidthSlave
     
    可变宽度(VariableWidth)是指与不同下游节点连接边的数据总线宽度可以不同,所以这里使用TLFragmenter为Bus处理不同数据宽度的下游连接。(TLFragmenter向上传递下游节点参数的时候,并不改变其beatBytes参数,所以Bus看到的是下游节点的原始的数据总线宽度,可能是不相同的。)
     
    5) toFixedWidthSlaveNode
     
    固定宽度(FixedWidth)是指与不同下游节点连接边的数据总线宽度都相同,所以这里使用TLWidthWidget为Bus提供统一的数据总线宽度(beatBytes)。(TLWidthWidget改变项上传递的参数中的beatBytes参数,告诉Bus所有与之连接的下游节点的数据总线宽度都是beatBytes。)
     
    6) toFixedWidthSlave
     
    这里gen是一个call-by-name参数:
     
    7) toFixedWidthSingleBeatSlaveNode
     
    略,未使用。
     
    8) toFixedWidthSingleBeatSlave
     
    略,未使用。
     
    9) toLargeBurstSlave
     
    略,未使用。
     
    10) toFixedWidthPort
     
    输出到一个Port:
     
    4. CanAttachTLMasters
     
    可以连接上游节点。使用该trait的类需要继承自TLBusWrapper:
     
    1) fromMasterNode
     
    gen是一个TLOutwardNode:
     
    2) fromMaster
     
    gen是一个call-by-name参数,用于生成TLOutwardNode:
     
    3) fromPort
     
    gen生成的是一个port:
     
    4) fromCoherentMaster
     
    gen生成的是一个Coherent Master:
     
    5. HasTLXbarPhy
     
    使用该特征引入一个Xbar对象:
     
  • 相关阅读:
    c#遍历一个对象中所有的属性和值
    Redis和Memchaed缓存数据查询
    ASP.NET结合Redis实现分布式缓存
    C#使用Spire.Doc Word for .Net读写Word
    DataTable序列化
    ASP.NET网站不能在VS中调试
    winform窗体运行时的大小和设计时不一致
    ajax请求aspx.cs后台方法
    jQuery判断鼠标滚动方向
    使用MagickNet编辑图片
  • 原文地址:https://www.cnblogs.com/wjcdx/p/11478418.html
Copyright © 2020-2023  润新知