Rocket - diplomacy - IdRange】的更多相关文章

https://mp.weixin.qq.com/s/qqL2XWqAhVcnGSxs6kxhLg   介绍IdRange的实现.   ​​   1. 基本定义   A non-empty half-open range; [start, end)   非空,半闭合区间.   限定条件如下: a. start >= 0; b. start <= end;   2. compare   比较方法.用于排序.   3. overlaps   判断是否重叠. ​​   4. contains   t…
https://mp.weixin.qq.com/s/vaDUekxkFkOJLmzg5jCngw 简单介绍LazyModule/LazyModuleImp的组织方式. 1. LazyModule LazyModule是一个泛化的模块概念,其中包含了代表模块与其他模块相连的节点(diplomacy node),也包含了模块的内部逻辑实现(lazy val module). 其定义为: --------------------------------------------------------…
https://mp.weixin.qq.com/s/rgCRorjPYyyD6i7moIzbZg   介绍LazyModule和Node构造方法的执行过程,即实例化过程.     1. NullIntSource   以NullIntSource为例,将其作为顶层的LazyModule考虑: ​​     2. LazyModule实例化过程   1) 执行NullIntSource的构造方法,首先要逐层向上找到各个父类,然后逐层向下执行各个父类的构造方法:   a. 最开始执行LazyMod…
https://mp.weixin.qq.com/s/9PsBt4_4qHx4i6C5XtuiUw   介绍LazyModule和Node构造方法的执行过程,即实例化过程.     1. NullIntSource   以NullIntSource为例,将其作为顶层的LazyModule考虑: ​​     2. 实例化过程   1) 执行NullIntSource的构造方法,首先要逐层向上执行各个父类的构造方法:   a. 最开始执行LazyModule类的构造方法:用于构造LazyModul…
https://mp.weixin.qq.com/s/FBU8fE4u9-UK6mRGQOlvbQ   介绍LazyModule的实现.     ​​   1. children   LazyModule内部的LazyModule,说明LazyModule是可以嵌套的.   在如下位置添加: ​​     2. nodes   LazyModule内部的Node.   相较之下,Node不能嵌套,内部没有其他Node.   在BaseNode中添加: ​​     3. parent   记录父…
https://mp.weixin.qq.com/s/so-2x5KLfYF0IMCCqNThwQ   简单调试ValName实现:   1. 使用     ​​   Desugar之后如下: ​​   这里补上了省略掉的implicit parameter,如下: ​​     2. 实现   ValName的实现如下: ​​   ValNameImpl的实现如下: ​​     3. 提取   ValName和ValNameImpl实现相对独立,可以提取出来单独调试.   新建一个项目.因为…
https://mp.weixin.qq.com/s/GWL41P1G1BXm2sTeLmckdA   介绍NodeHandle相关的类.     ​​   1. NoHandle   顶层类(trait),作为所有NodeHandle的父类型,没有定义特别操作.     2. InwardNodeHandle   ​​   主要用于实现节点绑定逻辑.   1) bind方法   委托给InwardNode.bind()实现:   2) 与NodeHandle连接   ​​   a. 连接  …
https://mp.weixin.qq.com/s/9PEEpe1pkQDN9RWpOGSUCQ   介绍DUEB参数模型的设计,不包含实现(实现对设计做了简化).     1. DUEB   diplomacy的DUEB参数模型包含了4组参数,分别是: a. DI/DO b. UI/UO c. EI/EO d. BI/BO   每一个参数类型的定义如下: ​​   参数模型图如下: ​​     下面主要以DI/DO为例,来做解释.   2. the node   DI = Downward…
https://mp.weixin.qq.com/s/cTRxXwWNEeb4-XX_t4bRcg   讨论模块结构信息的来源及使用方式.     ​​   1. diplomacy   diplomacy:外交,谈判的意思.主要用于模块之间的协商参数.   基本思想是首先把模块结构(module hierarchy)抽象为DAG: a. 把模块抽象为点(Node),把模块之间的连接抽象为边(Edge); b. 边是有方向的,上游节点为SourceNode,下游节点为SinkNode: c. N…
https://mp.weixin.qq.com/s/poCJBcx45clXHm6Uuv8M6w 介绍AddressSet.misaligned的实现.之前介绍的比较概括,也有偏差.这里根据实际执行结果,分析总结其功能. 1. 提取执行 misaligned功能比较独立,可以单独提取出来.执行观察运行结果,或者调试跟踪来观察其功能. 其中,需要解决的依赖是log2Floor. 执行结果如下: 2. 基本功能 misaligned的基本功能是把从base开始的size个地址,按照对齐原则,使用最…