GEM5 McPAT NoC教程: xml设置汇总-2023版

简介

McPAT的xml有一些参数需要设置,noc的部分很多Gem5ToMcpatparser没有设置,也没有给出如何设置的条件。尤其是和活动相关的total access,不知道具体怎么设置,也不知道如何从gem5 stats.txt中导出。本文提供了2023年的收集到getech的教程和设置汇总。最重要的一句话是,system.Noc0:total_accesses = (all cores’) l2_demandaccess*2。

需要调整的部分

一共大概30行左右,是system.noc这个组件。其中total access
在这里插入图片描述

乔治亚理工 total access = 4 times of number of memory accesses,

在乔治亚理工的网站:https://faculty.cc.gatech.edu/~hyesoon/fall11/prog5.html,有一个mcpat手动设置的作业,需要手动改写mcpat的xml,其中给的system.Noc0:total_accesses 原文如下:
Number of memory accesses (McPAT: system.Noc0:total_accesses = 4 times of number of memory accesses, system.mem.Memory accesses, system.mem.memory_reads, system.mem.memory_writes, (system.mc.memory_accesses, = 4 times of number of memory accesses system.mc.memory_reads = system.mc.memory_writes = 2 times of number of memory accesses))
在这里插入图片描述

剑桥大学的 perl 脚本

用于获取 m5 的输出并为 mcpat 创建输入文件的 Perl 脚本:m5-mcpat.pl。用法:perl m5-mcpat.pl [m5out/stats.txt] [m5out/config.ini] [mcpat-template.xml] >输出.xml
这个版本应该是相对最权威的,可惜是perl的格式而且是2011年的版本。
用的参数是l2 demand×2 。
在这里插入图片描述
在2023年的版本中,我有四个l2 demand_access,虽然名字和l2.demand_accesses有所差异。我的结果里有四个,推测是因为这个文件里我有四个核。
system.ruby.l1_cntrl0.L2cache.m_demand_accesses 21462729
system.ruby.l1_cntrl1.L2cache.m_demand_accesses 17043475
system.ruby.l1_cntrl2.L2cache.m_demand_accesses 20771998
system.ruby.l1_cntrl3.L2cache.m_demand_accesses 22050985
在这里插入图片描述
剑桥给的noc access是在l2 demand的基础上×2,推测是一个l2 demand,是需要noc发一个request和noc发一个response,也就是一次访问内存需要使用noc两次。

2023 可用的parser,最好是python

我们已经知道了,但最好有个(别人已经用过,可用的)自动化工具来做这个事情。乔治亚理工的版本是手动输入,剑桥的版本是perl代码而且是2011年的。我们需要一步步看过去2023年有那些可用于noc的mcpat parser 代码。

在2023年12月15看来,没有可用的gem5 noc mcpat库,还是手动计算n个core 的l2 demand 再x2

其他的itlb access很多人做了,noc很多人没做应该是没用garnet的缘故。好在是也不难,只用读l2 demand 然后sum x2就好。但是在2023年12月15日为止,没有找到自动化的python。

2020 EU COSSIM cMcPAT 提出更准的cMcPAT 和 total_accesses = l2.demand_accesses::total * 2

https://github.com/H2020-COSSIM/cMcPAT/tree/master 。 比较新,维护比较好,资料多,
COSSIM是一个很大的项目,其中cMcPAT 被修改来处理这些情况(针对gem5优化)。最重要的是,它添加了两个处理器描述模板,可以在尝试从 gem5 建模 ARM 和 x86 simpleCPU 模型时使用。
但对于noc来说,转换脚本是dskhudia bitbucket的库改进版,但是stats.testsys.l2.demand_accesses::total 是一般的gem5stats没有的,需要对gem5进行改源代码并且编译才能在stats.txt 输出这个文件。对我们只关心noc access的人来说,初始阶段不如用默认的输出文件,然后手动更改。


好处是他再次确认了,total_access 是两倍的l2.demand_accesses。
在这里插入图片描述
同一个文件内设置了其他access。
在这里插入图片描述

dskhudia bitbucket的库: 没有设置noc access

https://bitbucket.org/dskhudia/gem5tomcpat/src/master/template-xeon.xml

saideeptiku 没有noc access

https://github.com/saideeptiku/Gem5McPatParser/blob/master/templates/template_x86.xml。好处是他声明了用的mcpat 1.3和python 3.6,是相对新的版本了。其他有的用的是python 2.7和mcpat1.0。

2022年的csdn 帖子

2022年的 Mcpat与gem5联合 csdn帖子用的 https://blog.csdn.net/ffriend/article/details/127114214?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522170263778216800182144970%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=170263778216800182144970&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2allfirst_rank_ecpm_v1~rank_v31_ecpm-2-127114214-null-null.142v96pc_search_result_base7&utm_term=mcpat%20parser&spm=1018.2226.3001.4187 这一篇用的 https://github.com/Dhruv-Acharya/Gem5ToMcPAT-Parser 作者Dhuruv的github代码,但他的noc total_accesses 没有从gem5里的stats.txt读取。无效。
在这里插入图片描述

hardik44 Gem5toMcPat_parser 一样没有noc access

hardik44 https://github.com/Hardik44/Gem5toMcPat_parser 里也没有从没有从gem5里的stats.txt读取。无效。
在这里插入图片描述

zhenwen404 gem5tomcpat 没有读取noc access

https://github.com/zhewen404/gem5tomcpat/blob/main/template-xeon.xml 一样没有noc total_access. 不过他有设置itlb和dtlb读取。

takakeya gem5tomcpat 没有读取noc access

https://github.com/TAKAKEYA/gem5tomcpat/blob/master/template-xeon.xml 没有。

JuninhoCarlos gem5ToMcPAT 没有读取noc access

https://github.com/JuninhoCarlos/gem5ToMcPAT/blob/master/template-xeon.xml

UDC-GAC 用的C,不方便用和读, 不知道有没有noc access

https://github.com/UDC-GAC/gem5McPATparse/blob/master/template.xml 还说明了他们专注x86.其他的isa可能会有问题?

其他资料

有gem5 user email 提到有parser会统计total access

在这里插入图片描述
这个link提到了,有的parser会给关于total_access 的警告,意外着这个parser会查找total access。可惜他的问题没有回复也没有po出用的哪个parser。
在这里插入图片描述

有例子给出转换过的noc total_access

https://www.mail-archive.com/gem5-users@gem5.org/msg17699.html 提到了他的xml文件,其中noc access 是一个复杂的值,应该来自与gem5的stats.txt转化。 他用的文件是 Gem5tomcpat 和 mcpat-template.xml。

https://www.teraflux.eu/sites/teraflux.eu/files/TERAFLUX-D73-v7.pdf
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/70b584c82e84438ab4c9e0f8af844b3a.png)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/250308.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

听GPT 讲Rust源代码--src/tools(14)

File: rust/src/tools/rust-analyzer/crates/cfg/src/lib.rs 在Rust源代码中,rust/src/tools/rust-analyzer/crates/cfg/src/lib.rs这个文件是Rust语言分析器(Rust Analyzer)的一部分,用于处理和管理条件编译指令(Cond…

debug点f8step over会进入class文件

File->settings->Bulid.Executiong.Deployment->Debugger->Stepping 取消如图对钩即可

python 实现PC、app自动化全过程(包括CI\CD)

python main.py allure generate C:\devlopePath\new_nergeryApp_auto\reports -o C:\devlopePath\new_nergeryApp_auto\result --clean allure open C:\devlopePath\new_nergeryApp_auto\result

Qt实现中英文切换步骤

本demo的开发环境是vs2015qt5.9.4。以下是已有的工程下,增加中英文切换的功能(当然还可以多语言切换)。 1,选中工程(记得一定要选中,否则Create New Translation File 是灰色的)。点击Create N…

2024中国国际大数据产业博览会年度主题征集公告

2024中国国际大数据产业博览会年度主题征集公告 中国国际大数据产业博览会(以下简称数博会),是全球首个以大数据为主题的国家级博览会,由国家发展和改革委员会、工业和信息化部、国家互联网信息办公室和贵州省人民政府共同主办&am…

用代码写uml并在线生成uml图

可以用PlantUml写uml,并在线生成uml图。 startuml start:登录系统; if (用户名和密码正确?) then (yes):进入系统首页;:展示主菜单; else (no):显示登录错误;stop endif:选择模块; partition "课程信息" {:查看课程列表;:查看课程详情; } partition "课程签到…

vue整个页面可以拖拽导入文件

效果图 原理与源码 我们这里的思路是用ant组件库的upload组件,就是如下这个 用这个包裹住所有页面,你可以是包裹住App.vue,或者是你的homepage。但是这个涉及到一个问题,就是我们现在确实是可以拖拽导进来文件了,但是…

vscode报错cnpm : 无法加载文件 C:\Program Files\nodejs\cnpm.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅

报错 打开powershell 执行 Start-Process powershell -Verb runAs set-ExecutionPolicy RemoteSigned 选择 Y 完成

基于ssm旅游景点管理系统设计论文

摘 要 现代经济快节奏发展以及不断完善升级的信息化技术,让传统数据信息的管理升级为软件存储,归纳,集中处理数据信息的管理方式。本旅游景点管理系统就是在这样的大环境下诞生,其可以帮助管理者在短时间内处理完毕庞大的数据信息…

统一大语言模型和知识图谱:如何解决医学大模型-问诊不充分、检查不准确、诊断不完整、治疗方案不全面?

统一大语言模型和知识图谱:如何解决医学大模型问诊不充分、检查不准确、诊断不完整、治疗方案不全面? 医学大模型问题如何使用知识图谱加强和补足专业能力?大模型结构知识图谱增强大模型的方法 医学大模型问题 问诊。偏离主诉和没抓住核心。…

电商淘宝爬虫API与淘宝官方开放平台API的区别以及如何选择适合自己的API接口

随着数字化时代的到来,数据已经成为企业竞争力的重要因素。为了获取数据,企业或个人常常需要使用API接口。常见的API接口包括爬虫API和官方开放平台API。本文将详细介绍这两种API接口的区别以及如何选择适合自己的API接口。 一、爬虫API与官方开放平台A…

Leetcode—2415.反转二叉树的奇数层【中等】

2023每日刷题(六十) Leetcode—2415.反转二叉树的奇数层 BFS的C实现代码 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(n…

Day62力扣打卡

打卡记录 统计区间中的整数数目(动态开点线段树) 链接 class CountIntervals:__slots__ left, right, l, r, cntdef __init__(self, l1, r10 ** 9):self.left self.right Noneself.l, self.r, self.cnt l, r, 0def add(self, l: int, r: int) ->…

手机号格式校验

这种写法不仅可以用于手机号格式校验,还可以用于身份证、邮编等等字段输入编辑校验,只需要更换对应的正则表达式 文章目录 phoneNum:手机号码实体类字段 ^1[3|4|5|7|8|9][0-9]\d{8}$:手机号正则表达式(匹配以1开头&am…

编译 pywinhook v1.6.2 的环境设置和步骤

准备做一个鼠标事件响应程序。 查了一下相关python的第三方类库,发现有 pyhook。 一、起源 pyhook 1、pyhook是最早的版本 pyhook支持的python版本比较低,代码在 https://sourceforge.net/projects/pyhook/ 2、之后产生了两个并行版本 pyHook3 和 p…

从0创建并部署一个网页到服务器

创建一个页面 1 下载node.js 下载VScode 2 在Windows下找一个路径新建一个文件夹 例如:D:\study_project\PersonalWeb 3 VSCodee中打开文件夹 4 Windows下 管理员身份打开命令提示符,执行npm install -g vue/cli 5 VSCode下打开终端,执…

Winform高效获取控件(Control)方法 + 源码分析

背景:风好大,睡觉有点怕,起床敲代码了 之前学的都是都是通过遍历控件(Controls),判断控件名是否相等来获取Control 其实直接通过:Controls["控件名"],就可以获得需要的控件 为什么呢…

SQL错题集3

1.薪水第二多的员工的emp_no以及其对应的薪水salary limit a,b 其中a表示查询数据的起始位置,b表示返回的数量。 (MySQL数据库中的记录是从0开始的) 注意从0开始 2.员工编号emp_no为10001其自入职以来的薪水salary涨幅值growth 聚合函数不能…

java简易制作-王者荣耀游戏

一.准备工作 首先创建一个新的Java项目命名为“王者荣耀”,并在src下创建两个包分别命名为“com.sxt"、”com.stx.beast",在相应的包中创建所需的类。 创建一个名为“img”的文件夹来储存所需的图片素材。 二.代码呈现 package com.sxt; import javax…

Spring cloud - 断路器 Resilience4J

其实文章的标题应该叫 Resilience4J,而不是Spring Cloud Resilience4J,不过由于正在对Spring cloud的一系列组件进行学习,为了统一,就这样吧。 概念区分 首先区分几个概念 Spring cloud 断路器:Spring Cloud的官网对…