1、
garent2.0是gem5内部一个详细的互连网络模型。它正在积极开发中,具有更多功能的补丁将定期推送到gem5中。 其他与Garnet相关的补丁和正在开发的工具支持(不是回购协议的一部分)可以在Garnet page at Georgia Tech找到。
Gernet2.0建立在发表于GARNET: A detailed on-chip network model inside a full-system simulator
之上
如果您对Garnet的使用有助于发表论文,请引用以下论文:
@inproceedings{
garnet,
title={
GARNET: A detailed on-chip network model inside a full-system simulator},
author={
Agarwal, Niket and Krishna, Tushar and Peh, Li-Shiuan and Jha, Niraj K},
booktitle={
Performance Analysis of Systems and Software, 2009. ISPASS 2009. IEEE International Symposium on},
pages={
33--42},
year={
2009},
organization={
IEEE}
}
2、
Garent2.0提供了一个片上网络路由器的周期精确微架构实现。它利用了gem5的ruby内存系统模型提供的拓扑结构和路由基础设施。默认路由器是最先进的单周期管道。通过在拓扑中指定,支持在任何路由器中添加任何数量的周期的额外延迟。
3、
Garent2.0还可以通过在路由器和链路中设置适当的延迟来模拟片外互连网络。
4、
相关的文件:
src/mem/ruby/network/Network.py
src/mem/ruby/network/garnet2.0/GarnetNetwork.py
src/mem/ruby/network/Topology.cc
可以通过添加–network=garent2.0来启用Gernet网络。
Garnet2.0使用 Network.py中的通用网络参数:
1、
(1)number_of_virtual_networks
:这是虚拟网络的最大数目。活动虚拟网络的实际数量由协议决定。
(2)control_msg_size
:控制消息的大小(字节)。默认值为8。Network.cc中的m_data_msg_size设置为以字节为单位的块大小+control_msg_size。
2、其他参数在garnet2.0/GarnetNetwork.py中指定:
(1)ni_flit_size
:flit大小(字节)。flit是信息从一个路由器发送到另一个路由器的粒度。默认值为16(=>128位)。[此默认值16导致控制消息适合1个flit,数据消息适合5个flit]。Garnet要求ni_flit_size与带宽因子(在network/BasicLink.py中)相同,因为它不模拟网络中的可变带宽。这也可以从命令行使用–link-width-bits设置。
(2)vcs_per_vnet
:每个虚拟网络的虚拟信道(VC)的数目。默认值为4。这也可以从命令行使用–vcs-per-vnet设置。
(3)buffers_per_data_vc
:数据消息类中每个VC的flit缓冲区数。由于数据消息占用5个flit,因此该值可以介于1-5之间。默认值为4。
(4)buffers_per_ctrl_vc
:控制消息类中每个VC的flit缓冲区数。由于控制消息占用1个flit,并且VC一次只能保存一个消息,因此该值必须为1。默认值为1。
(5)routing_algorithm
:0:基于权重的表格(默认值),1:XY,2:自定义。更多细节如下。
garent2.0利用了gem5的ruby内存系统模型提供的拓扑结构。任何异构拓扑都可以建模。拓扑文件中的每个路由器都可以被赋予独立的延迟,这将覆盖默认值。此外,每个链路有两个可选参数:src_outport和dst_inport,它们是每个链路的源和目标路由器的输出和输入端口的名称字符串。这些可以在garent2.0中使用,以实现自定义路由算法,如下所述。例如,在网格中,西向东链接的src_outport设置为“west”,dst_inport设置为“east”。
(1)GarnetNetwork
:这是实例化所有网络接口、路由器和链接的顶级对象。Topology.cc调用在NIs和路由器之间添加“外部链接”和在路由器之间添加“内部链接”的方法。
(2)NetworkInterface
:每个NI通过一侧的MsgBuffer接口连接到一个相干控制器。它有一个到另一个路由器的链接。每个协议消息被放入一个单flit控件或多个(默认值为5)flit数据(取决于它的vnet),并注入到路由器中。多个NIs可以连接到同一个路由器(例如,在Mesh拓扑中,缓存和dir控制器通过单个NIs连接到同一个路由器)。
(3)Router
:路由器管理输出链路的仲裁和路由器之间的流控制。
(4)NetworkLink
:网络链接携带flits。它们可以是三种类型之一:EXT_OUT_(路由器到NI)、EXT_IN_(NI到路由器)和INT_(内部路由器到路由器)
(5)CreditLink
:信用链路在路由器之间携带VC/缓冲信用,用于流量控制。
(1)
garent2.0利用了gem5的ruby内存系统模型提供的路由基础设施。默认的路由算法是基于表的最短路径确定路由算法。链接权重可用于将某些链接优先于其他链接。有关如何填充路由表的详细信息,请参阅src/mem/ruby/network/Topology.cc。
(2)
自定义路由:
为了对自定义路由算法进行建模,比如说自适应路由算法,我们提供了一个框架,用src_outport和dst_inport 方向命名每个链路,并使用这些内部garnet实现路由算法。例如,在Mesh中,West-first可以通过沿“west”出口链路发送flit来实现,直到flit不再有任何剩余的X跳,然后随机(或基于下一个路由器VC可用性)选择剩余的链路之一。请参阅如何在src/mem/ruby/network/garent2.0/RoutingUnit.cc中实现outportComputeXY()。类似地,outportComputeCustom()可以实现,并通过在命令行中添加–routing-algorithm=2来调用。
(3)
多播消息:
所建模的网络在网络中没有硬件多播支持。多播消息在网络接口处被分解为多个单播消息。
设计中采用了虚拟通道流量控制。每个VC可以容纳一个数据包。VCs的设计分为控制和数据两种。每个缓冲区的深度可以独立于GarnetNetwork.py进行控制。默认值为1-flit deep control VCs和4-flit deep data VCs。控制包的默认大小为1-flit,数据包的默认大小为5-flit。
garnet2.0路由器执行以下操作:
传入的flit在其VC中得到缓冲。
缓冲flit计算其输出端口,该信息存储在其VC中。
所有缓冲的flit都试图为下一个周期保留交换机端口。[分配以可分离的方式进行:首先,每个输入使用输入仲裁器选择一个输入VC,该仲裁器放置一个开关请求。然后,每个输出端口通过输出仲裁器中断冲突]。有序虚拟网络中的所有仲裁器都在排队以保持点到点的顺序。所有其他仲裁人都是循环赛。
SA的获胜者从其输出端口选择一个免费的VC(如果HEAD/HEAD_TAIL flit)。
从横杆上飞过连接到达下一个路由器。
在默认设计中,BW、RC、SA、VS都在一个周期内发生。LT发生在下一个周期。
通过在拓扑文件中指定每个路由器的延迟,或者在src/mem/ruby/network/BasicRouter.py中更改默认路由器延迟,可以对多周期路由器进行建模。这是通过使缓冲flit在路由器中等待(延迟-1)个周期,然后才符合SA的要求来实现的。
每个路由器输入端口都有number_of_virtual_networks Vnets,每个都有vcs_per_vnet VCs。控制Vnets中的VCs具有buffers_per_ctrl_vc的深度(默认值=1),数据Vnets中的VCs具有buffers_per_data_vc的深度(默认值=4)。信用证用于中继有关免费VCs的信息,以及每个VC中的缓冲区数量。
(1)
每个NI一端连接一个相干协议控制器,另一端连接一个路由器
(2)
从适当的vnet中的一致性协议缓冲区接收消息,并将其转换为网络包并将其发送到网络中。 (garent2.0增加了在此时捕获网络跟踪的能力[开发中] )
(3)
接收来自网络的flit,提取协议消息并将其发送到相应vnet中的一致性协议缓冲区
(4)
使用附加的路由器管理流控制(即信用卡)
(5)
NI的消费flit/credit输出链接被放入全局事件队列,时间戳设置为next cycle。eventqueue调用消费者中的唤醒函数
(1)
接收来自NI/路由器的flits,并在 m_latency延迟后将其发送到NI/路由器
(2)
可以从命令行设置每个链接的默认延迟值(请参阅 configs/network/Network.py)
(3)
每链路延迟可以在拓扑文件中覆盖
(4)
链路的使用者(NI/路由器)被放入全局事件队列中,在m_latency周期之后设置时间戳。eventqueue调用消费者中的唤醒函数。
(1)
遍历所有输入单元并调用它们的wakeup()
(2)
遍历所有输出单元并调用它们的wakeup()
(3)
调用SwitchAllocator的wakeup()
(4)
呼叫CrossbarSwitch的wakeup()
(5)
只要路由器的任何模块(InputUnit、OutputUnit、SwitchAllocator、CrossbarSwitch)有一个就绪的flit/credit来执行这个周期,就会调用路由器的唤醒功能。
(1)
从上游路由器读取输入flit(如果已准备好进行此循环)
(2)
对于HEAD/HEAD_TAIL flits,执行路线计算,并在VC中更新路线。
(3)
将flit缓冲(m_latency-1)个周期,并将其标记为有效,以便开始该周期的SwitchAllocation。
可以从命令行设置每个路由器的默认延迟(请参阅configs/network/Network.py)
每个路由器延迟(即num pipeline stages)可以在拓扑文件中设置。
(1)
从下游路由器读取输入信用(如果已准备好进行此循环)
(2)
在适当的输出VC状态下增加信用。
(3)
如果信用携带的是“自由”信号,则将输出VC标记为“自由”
(1)
注意:SwitchAllocator在其中执行VC仲裁和选择。
(2)
SA-I(或SA-i):循环遍历每个输入端口上的所有输入VCs,并以循环方式选择一个。
对于HEAD/HEAD_TAIL flits,只选择其输出端口至少有一个空闲输出VC的输入VC。
对于BODY/TAIL flits,只选择在其输出VC中包含credits的输入VC。
(3)
从这个VC请求输出端口。
(4)
SA-II(或SA-o):循环遍历所有输出端口,并以循环方式选择一个输入VC(在SA-I期间发出请求)作为此输出端口的赢家。
对于HEAD/HEAD_TAIL filts,执行outvc分配(即,从输出端口选择一个空闲的VC)。
对于BODY/TAIL flits,减少输出vc中的信用。
(5)
从输入VC读取flit,并将其发送到CrossbarSwitch
(6)
为这个输入VC向上游路由器发送一个增量信用信号。
对于HEAD_TAIL/TAIL flits,标记是“自由”的信号在信用证中是正确的。
输入单元通过信用链路将信用发送到上游路由器。
(7)
重新安排路由器在下一个周期唤醒任何准备好SA下一个周期的 filt 。
(1)循环通过所有输入端口,并将获胜的flit从其输出端口发送到输出链路。
(2)路由器的消耗flit输出链路被放入全局事件队列,时间戳设置为next cycle。eventqueue调用消费者中的唤醒函数。
(1)接收来自NI/路由器的flits,并在m_latency周期延迟后将其发送到NI/路由器
(2)可以从命令行设置每个链接的默认延迟值(请参阅configs/network/Network.py)
(3)每链路延迟可以在拓扑文件中覆盖
(4)链路的使用者(NI/路由器)被放入全局事件队列中,在m_latency周期之后设置时间戳。eventqueue调用消费者中的唤醒函数。
文章浏览阅读3.2k次。本文研究全球与中国市场分布式光纤传感器的发展现状及未来发展趋势,分别从生产和消费的角度分析分布式光纤传感器的主要生产地区、主要消费地区以及主要的生产商。重点分析全球与中国市场的主要厂商产品特点、产品规格、不同规格产品的价格、产量、产值及全球和中国市场主要生产商的市场份额。主要生产商包括:FISO TechnologiesBrugg KabelSensor HighwayOmnisensAFL GlobalQinetiQ GroupLockheed MartinOSENSA Innovati_预计2026年中国分布式传感器市场规模有多大
文章浏览阅读1.1k次,点赞2次,收藏12次。常用组合逻辑电路结构——为IC设计的延时估计铺垫学习目的:估计模块间的delay,确保写的代码的timing 综合能给到多少HZ,以满足需求!_基4布斯算法代码
文章浏览阅读3.3k次,点赞3次,收藏5次。OpenAI Manager助手(基于SpringBoot和Vue)_chatgpt网页版
文章浏览阅读2.2k次。USACO自1992年举办,到目前为止已经举办了27届,目的是为了帮助美国信息学国家队选拔IOI的队员,目前逐渐发展为全球热门的线上赛事,成为美国大学申请条件下,含金量相当高的官方竞赛。USACO的比赛成绩可以助力计算机专业留学,越来越多的学生进入了康奈尔,麻省理工,普林斯顿,哈佛和耶鲁等大学,这些同学的共同点是他们都参加了美国计算机科学竞赛(USACO),并且取得过非常好的成绩。适合参赛人群USACO适合国内在读学生有意向申请美国大学的或者想锻炼自己编程能力的同学,高三学生也可以参加12月的第_usaco可以多次提交吗
文章浏览阅读394次。1.1 存储程序1.2 创建存储过程1.3 创建自定义函数1.3.1 示例1.4 自定义函数和存储过程的区别1.5 变量的使用1.6 定义条件和处理程序1.6.1 定义条件1.6.1.1 示例1.6.2 定义处理程序1.6.2.1 示例1.7 光标的使用1.7.1 声明光标1.7.2 打开光标1.7.3 使用光标1.7.4 关闭光标1.8 流程控制的使用1.8.1 IF语句1.8.2 CASE语句1.8.3 LOOP语句1.8.4 LEAVE语句1.8.5 ITERATE语句1.8.6 REPEAT语句。_mysql自定义函数和存储过程
文章浏览阅读188次。半导体二极管——集成电路最小组成单元。_本征半导体电流为0
文章浏览阅读2.8k次,点赞3次,收藏18次。游戏水面特效实现方式太多。咱们这边介绍的是一最简单的UV动画(无顶点位移),整个mesh由4个顶点构成。实现了水面效果(左图),不动代码稍微修改下参数和贴图可以实现岩浆效果(右图)。有要思路是1,uv按时间去做正弦波移动2,在1的基础上加个凹凸图混合uv3,在1、2的基础上加个水流方向4,加上对雾效的支持,如没必要请自行删除雾效代码(把包含fog的几行代码删除)S..._unity 岩浆shader
文章浏览阅读5k次。广义线性模型是线性模型的扩展,它通过连接函数建立响应变量的数学期望值与线性组合的预测变量之间的关系。广义线性模型拟合的形式为:其中g(μY)是条件均值的函数(称为连接函数)。另外,你可放松Y为正态分布的假设,改为Y 服从指数分布族中的一种分布即可。设定好连接函数和概率分布后,便可以通过最大似然估计的多次迭代推导出各参数值。在大部分情况下,线性模型就可以通过一系列连续型或类别型预测变量来预测正态分布的响应变量的工作。但是,有时候我们要进行非正态因变量的分析,例如:(1)类别型.._广义线性回归模型
文章浏览阅读69次。环境保护、 保护地球、 校园环保、垃圾分类、绿色家园、等网站的设计与制作。 总结了一些学生网页制作的经验:一般的网页需要融入以下知识点:div+css布局、浮动、定位、高级css、表格、表单及验证、js轮播图、音频 视频 Flash的应用、ul li、下拉导航栏、鼠标划过效果等知识点,网页的风格主题也很全面:如爱好、风景、校园、美食、动漫、游戏、咖啡、音乐、家乡、电影、名人、商城以及个人主页等主题,学生、新手可参考下方页面的布局和设计和HTML源码(有用点赞△) 一套A+的网_垃圾分类网页设计目标怎么写
文章浏览阅读614次,点赞7次,收藏11次。之前找到一个修改 exe 中 DLL地址 的方法, 不太好使,虽然能正确启动, 但无法改变 exe 的工作目录,这就影响了.Net 中很多获取 exe 执行目录来拼接的地址 ( 相对路径 ),比如 wwwroot 和 代码中相对目录还有一些复制到目录的普通文件 等等,它们的地址都会指向原来 exe 的目录, 而不是自定义的 “lib” 目录,根本原因就是没有修改 exe 的工作目录这次来搞一个启动程序,把 .net 的所有东西都放在一个文件夹,在文件夹同级的目录制作一个 exe._.net dll 全局目录
文章浏览阅读1.5k次。本文为转载,原博客地址:http://blog.csdn.net/hujingshuang/article/details/46910259简介 BRIEF是2010年的一篇名为《BRIEF:Binary Robust Independent Elementary Features》的文章中提出,BRIEF是对已检测到的特征点进行描述,它是一种二进制编码的描述子,摈弃了利用区域灰度..._breif description calculation 特征点
文章浏览阅读4.1k次,点赞21次,收藏79次。本文是《基于SpringBoot的房屋租赁管理系统》的配套原创说明文档,可以给应届毕业生提供格式撰写参考,也可以给开发类似系统的朋友们提供功能业务设计思路。_基于spring boot的房屋租赁系统论文