Rocket - diplomacy - LazyModule实例:Buffer
2024-08-31 11:17:49
https://mp.weixin.qq.com/s/j1M9ZOTtqvc1Fv9T6dy9kg
以tilelink下的Buffer为例,介绍LazyModule如何组织内部的节点和模块。
1. TileLink Channels
参考TileLink总线的规范文档。
2. BufferParams
BufferParams包含了定义一个Buffer需要用到的3个参数:
a. depth;
b. flow;
c. pipe;
3. TLBufferNode
TLBufferNode是TLAdapterNode的子类。其构造方法包含分别对应TileLink总线a/b/c/d/e 5个channel的BufferParams参数。
4. TLBuffer
TLBuffer继承自LazyModule。他内部包含一个节点(node),包含一个LazyModuleImp匿名子类的lazy实例module,作为其内部实现。
5. TLBuffer.node
TLBuffer.node是TLBufferNode的一个实例。他包含了TLBuffer实例的in/out接口信息。
6. TLBuffer.module
TLBuffer.module是TLBuffer的内部实现。
TLBuffer这个LazyModule的输入输出接口的信息在node中,所以TLBuffer.module要从TLBuffer.node中取出输入接口,实现内部逻辑,最后连接到输出接口上。
这里的内部逻辑就是使用BufferParams中的参数生成的Queue。
7. 外部连接
以Channel in.a为例,TLBuffer.module把in.a输出到out.a,那么:
a. 谁输出到in.a?
b. out.a输出到哪里?
这些都是TLBuffer作为一个模块,与其他模块之间的连接关系。这些连接是使用TLBuffer.node代替TLBuffer这个模块,与其他LazyModule.node进行连接的。
可以看到TLBuffer的伴生对象,返回的都是buffer.node,以与其他模块连接:
8. 附录
略
最新文章
- Java 浅析内部类
- 架构验证过程发现非数据类型错误 validation found non-data type errors
- Eclipse+Qt开发环境设置(Linux和Win)
- IOS异步和多线程操作&;&;在sqlite3中的应用
- python中提示invalid syntax 总结
- Python PIL库之Image注解(API)
- apache、mod_jk负载均衡与tomcat集群
- git和GItHub的区别
- 测试DOM0级事件和DOM2级事件的堆叠
- B-JUI 实践 之 带搜索与编辑的Datagrid
- JVM垃圾收集(GC)算法
- MySql按每日、每周、每月分组统计数据
- java项目中通过添加filter过滤器解决ajax跨域问题
- NSL:CPK_NN神经网络实现预测哪个样本与哪个样本处在同一层,从而科学规避我国煤矿突水灾难—Jason niu
- 【转】android笔记--保存和恢复activity的状态数据
- python全栈开发day27-网络编程
- 输入两棵二叉树A,B,判断B是不是A的子结构(c++实现)
- Android: INSTALL_FAILED_UPDATE_INCOMPATIBLE错误解决措施
- 《转载》脚本实现从客户端服务端HTTP请求快速分析
- 什么是adb命令?以及如果高效使用他们?
热门文章
- jQuery中bind()与on()绑定事件的区别
- LeetCode--Unique Morse Code Words &;&; Flipping an Image (Easy)
- ubuntu文件系统修改( for arm)
- Altium Designer PCB封装bug,元件焊盘位置偏移解决方法
- C语言进阶_goto与void解析
- zabbix-agent客户端安装与配置
- [hdu5313]二分图性质,dp
- 【疑问】SQLServer_DNS注入数据库因为点号不能显示数据库的库名的方法[语音和音乐]
- Web_php_unserialize
- Python 常用编码规范