https://mp.weixin.qq.com/s/UYVSO3XFJmhe5bUD_XbMLg

 
先介绍如何使用AddressAdjuster,然后分析UI参数的生成及使用。
 
 
1. AddressAdjuster的使用
 
a. 创建AddressAdjuster实例
 
注意usage()方法有一个implicit Parameters参数,在方法范围内引入了一个隐式参数对象,在new AddressAdjuster的时候会使用。
 
b. 关联node的上下游节点
 
 
c. 关联chip_id的上游节点
 
 
d. 引用module构建硬件模块
 
 
2. UI生成
 
UI是指Node的DUEB参数中的UI。
 
引用adjuster.module后会执行module定义的代码,其中:
 
会调用node.in方法:
 
bundulesIn和edgesIn都是lazy变量:
 
并且bundlesIn依赖于edgesIn,这里主要关注edgesIn:
 
edgesIn依赖于iPorts和uiParams:
 
这里的iPorts为输入口,即与parent的连接口,iPorts.size = 1。
 
uiParams用到了uoParams:
 
这里oPorts为输出口,即与local和remote相连的连接口。n分别为local和remote节点。
 
所以uiParams中的:
a. iPorts.size = 1;
b. uoParams为local和remote节点向上传播的TLManagerPortParameters参数,uoParams.size = 2;
 
mapParamsU的实现为:
把uoParams传递给uFn()方法,返回一个UI;然后把这个UI复制成n(=1)份。
 
uFn()的实现为:
 
返回的一个UI为:
 
3. UI使用
 
a. edgesIn
 
edgesIn通过调用edgeI方法生成:
其中i为生成的UI。
 
edgeI方法的实现为:
 
其中,pu为UI,即TLManagerPortParameters:
 
b. bundlesIn
 
bundlesIn通过edgesIn和bundleI方法生成:
 
bundleI方法的实现如下:
 
ei.bundle的实现如下:
 
TLEdgeParameters是TLEdgeIn的父类:
所以TLEdgeParameters中的manager参数,即是传入的UI参数。
 
TLBundleParameters()伴生方法的实现如下:
 
可以看到其中并没有使用UI,亦即manager参数中的实际地址集合。
 
c. parentEdge的使用
 
所以不需要关注parent,只需要关注parentEdge的使用,以坚持是否用到其中的地址集合即可:
 
parentEdge的使用如下:
TLArbiter.robin中也没有实际使用到manager的地址集合。
 
所以managerFn的实现中,废了大力气生成的地址集合,目前来看并没有实际用处。
 

Rocket - diplomacy - AddressAdjuster分析的更多相关文章

  1. Rocket - diplomacy - AddressAdjuster

    https://mp.weixin.qq.com/s/X0s5CWN84GEiwpNR7tiRgA 基于AddressAdjuster介绍LazyModule的实现.   参考链接:https://g ...

  2. Rocket - diplomacy - DUEB参数模型分析

    https://mp.weixin.qq.com/s/533bJxcPRgO4W2gf_OEhEw   分析DUEB参数模型中各种参数类型的可能性.     1. 节点类型   根据参数的传播方向,可 ...

  3. Rocket - diplomacy - LazyModule的组织方式

    https://mp.weixin.qq.com/s/vaDUekxkFkOJLmzg5jCngw 简单介绍LazyModule/LazyModuleImp的组织方式. 1. LazyModule L ...

  4. Rocket - diplomacy - misaligned

    https://mp.weixin.qq.com/s/poCJBcx45clXHm6Uuv8M6w 介绍AddressSet.misaligned的实现.之前介绍的比较概括,也有偏差.这里根据实际执行 ...

  5. Rocket - diplomacy - LazyModule的实例化(补)

    https://mp.weixin.qq.com/s/rgCRorjPYyyD6i7moIzbZg   介绍LazyModule和Node构造方法的执行过程,即实例化过程.     1. NullIn ...

  6. Rocket - diplomacy - LazyModule的实例化

    https://mp.weixin.qq.com/s/9PsBt4_4qHx4i6C5XtuiUw   介绍LazyModule和Node构造方法的执行过程,即实例化过程.     1. NullIn ...

  7. Rocket - diplomacy - LazyModule

    https://mp.weixin.qq.com/s/FBU8fE4u9-UK6mRGQOlvbQ   介绍LazyModule的实现.     ​​   1. children   LazyModu ...

  8. Rocket - diplomacy - ValName

    https://mp.weixin.qq.com/s/so-2x5KLfYF0IMCCqNThwQ   简单调试ValName实现:   1. 使用     ​​   Desugar之后如下: ​​ ...

  9. Rocket - diplomacy - NodeHandle相关类

    https://mp.weixin.qq.com/s/GWL41P1G1BXm2sTeLmckdA   介绍NodeHandle相关的类.     ​​   1. NoHandle   顶层类(tra ...

随机推荐

  1. Codeforces Round #626 D. Present

    D. Present 题目大意:给你一个大小是n的序列,求两两之间相加进行异或之后的答案. 这个题目我并没有想到怎么写,有点偷懒于是就去看了题解.. 题解很套路... 题解: 因为这个是用到了异或,所 ...

  2. 最终父类【根类】:Object类&Objects类

    一.java.lang.Object类 1.Object类介绍 Object类是所有类的父类.一个类都会直接或间接继承自该类: ​ 该类中提供了一些非常常用的方法! 2.toString()方法 A: ...

  3. 【Spark】这一篇或许能让你大概了解如何通过JavaAPI实现DataFrame的相关操作

    文章目录 需求概述 步骤 一.创建Maven工程并导包 二.选用第一种方法:利用反射机制配合样例类构建DataFrame 开发代码 选用第二种方法:通过StrucType配合Row构建DataFram ...

  4. 【Scala】新手入门,基础语法概览

    目录 变量.常量和数据类型 var val 数据类型 条件表达式 块表达式 to循环 for循环 for推导式 scala中的方法和函数 方法的定义 函数的定义 函数和方法的区别 变量.常量和数据类型 ...

  5. qt获取指定目录下符合条件的文件路径

    1)设置名称过滤器 QDir * dir = new QDir(路径); QStringList filter; Filter << QStringLiteral(“筛选的文件条件,如.x ...

  6. 构建自己的专用OpenCV----记录一次由applyColorMap()引发的探索

    在编写实际项目的过程中,我需要实现绿色主题的"伪彩色"变换.在目前提供的模板中,只有summer最为接近,但是它的颜色太浅了,看上去不是很清晰.所以我结合ocean和summer两 ...

  7. [hdu5400 Arithmetic Sequence]预处理,容斥

    题意:http://acm.hdu.edu.cn/showproblem.php?pid=5400 思路:预处理出每个点向左和向右的最远边界,从左向右枚举中间点,把区间答案加到总答案里面.由与可能与前 ...

  8. mybatis分页助手分页

    一.编写dao及配置文件 (1)配置文件两种方式 第一种: <!--SqlSeesionFactoryBean对象--><bean id="sqlSessionFactor ...

  9. 1025 PAT Ranking (25分) 思路分析 +满分代码

    题目 Programming Ability Test (PAT) is organized by the College of Computer Science and Technology of ...

  10. 宝塔webHook自动同步代码的使用

    #!/bin/bashecho ""#输出当前时间date --date='0 days ago' "+%Y-%m-%d %H:%M:%S"echo " ...