gem5学习(9):构建gem5——Building gem5

目录

一、Requirements for gem5

二、Getting the code

三、Your first gem5 build

1、gem5 binary types

四、Common errors

1、gcc版本过低

2、使用非默认版本的python

3、未安装M4宏处理器

4、Protobuf版本过低


前面的gem5学习(3)—(8)是gem5官网的learning_gem5中的Modifying/Extending章节的,但是后续对源码进行更改的时候发现有些基础教程由于看的时间太久已经忘了,英文阅读又太麻烦,不如重新整理成中文版学习笔记,供后续学习。

官方教程:gem5: Building gem5

这个j教程是最基础的设置gem5开发环境并构建gem5。

一、Requirements for gem5

在Ubuntu上,使用以下命令安装所有必需的依赖项。

sudo apt install build-essential git m4 scons zlib1g zlib1g-dev libprotobuf-dev protobuf-compiler libprotoc-dev libgoogle-perftools-dev python-dev python

下面这部分就是对相关依赖版本的要求。

  • gcc 7+(GCC Versions >=7, up to GCC 11
  • SCons 3.0+
  • Python 3.6+
  • prptobuf 2.1+ (Optional)【使用protobuf进行跟踪生成和回放时,需要安装该依赖项】
  • Boost (Optional)

二、Getting the code

下载gem5仓库。

git clone https://github.com/gem5/gem5

三、Your first gem5 build

从构建一个基本的x86系统开始。

必须为每个想模拟的ISA单独编译gem5。

注意:如果使用了ruby-intro-chapter,还必须为每个缓存一致性协议分别进行编译。

模拟器使用SCons来构建gem5。SCons使用SConstruct文件(gem5/SConstruct)设置了一些变量,然后使用每个子目录中的SConscript文件来查找和编译所有的gem5源代码。

当首次执行时,SCons会自动创建一个gem5/build目录。在这个目录中,可以找到SCons生成的文件、编译器等。每个用于编译gem5的选项集(ISA和缓存一致性协议),都有一个单独的目录。

build_opts目录中有一些默认的编译选项。这些文件指定了在初始构建gem5时传递给SCons的参数。示例中使用X86的默认值,并指定要编译所有的CPU模型。

可以通过查看build_opts/X86文件,了解SCons选项的默认值。也可以在命令行上指定这些选项,用来覆盖任何默认值。

python3 `which scons` build/X86/gem5.opt -j9
  • python3是指使用Python 3解释器来运行后续的命令。
  • which scons用于查找系统中安装的SCons构建工具的路径。这个命令返回SCons可执行文件的完整路径。
  • build/X86/gem5.opt指定了gem5的构建目标。在这种情况下,它表示要构建gem5的优化版本(gem5.opt)。构建目标的路径相对于gem5源代码根目录。
  • -j9选项表示要使用9个并行作业来加速构建过程。这允许同时运行多个编译任务,加快构建速度。具体可以根据系统配置和可用的处理器核心数量来调整并行作业的数量。

因此,命令的意思是使用Python 3解释器运行SCons构建工具,并使用9个并行作业来构建gem5的优化版本。

1、gem5 binary types

在gem5中,SCons脚本目前支持构建5个不同的gem5二进制文件,分别是debug、opt和fast。

  • debug(调试):Debug版本是为了方便调试和排除错误而构建的。它包含了用于调试目的的符号表和调试信息,可以在调试器中进行逐步调试,并提供更详细的日志和错误报告。但是,由于包含了额外的调试信息,Debug版本的gem5可能会比其他版本稍微慢一些。

  • opt(优化):Opt版本是经过优化的版本,旨在提供更高的性能和执行速度。它在编译过程中进行了各种优化,例如代码优化和编译器优化,以提高gem5的运行效率。Opt版本通常用于正式的性能评估和实际使用场景。

  • fast(快速):Fast版本是为了快速原型设计和快速验证而构建的。它在编译过程中进行了更多的优化,以追求更快的构建速度,而不是运行时的最佳性能。Fast版本可能会牺牲一些性能,但可以更快地进行实验和快速迭代。

传递给SCons的主要参数是我们上述命令行要构建的目标,即build/X86/gem5.opt。在本例中,我们正在构建gem5.opt(带有调试符号的优化二进制文件,如果不需要优化的话可以直接构建gem5.debug版本)。

命令行希望将gem5构建在build/X86目录中。由于该目录当前不存在,SCons将在build_opts中查找X86的默认参数(注意:在这里使用了-j9,通常是核心数加1)。

最后没有报错,同时出现:scons: done building targets.表示构建成功。

四、Common errors

问题都比较简单,只列不改,教程中有详细的解决办法。

1、gcc版本过低

2、使用非默认版本的python

3、未安装M4宏处理器

M4是一个宏处理器,通常用于生成复杂的代码或配置文件。

4、Protobuf版本过低

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Java SSM框架实现游戏论坛平台系统项目【项目源码+论文说明】

基于java的SSM框架实现游戏论坛平台系统演示 摘要 本论文主要论述了如何使用java语言开发一个游戏论坛平台的设计,本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构、ssm 框架和 java 开发的 Web 框架,基于Werkzeug WSGI工具箱和…

react antd EditableProTable - 可编辑表格

与编辑表格外的内容联动 value 同 dataSource,传入一个数组,是 table 渲染的元数据 T[] undefined onChange dataSource 修改时触发,删除和修改都会触发,如果设置了 value,Table 会成为一个受控组件。 (value:T[])>void undefined recordC…

Hello 2024(A~D,F1)

新年坐大牢 A - Wallet Exchange 题意:共有俩钱包,每回合从其中一个钱包中拿走一块钱,谁拿走最后一块钱谁赢。 思路:奇偶讨论即可。 // Problem: A. Wallet Exchange // Contest: Codeforces - Hello 2024 // URL: https://cod…

BERT 模型是什么

科学突破很少发生在真空中。相反,它们往往是建立在积累的人类知识之上的阶梯的倒数第二步。要了解 ChatGPT 和 Google Bart 等大型语言模型 (LLM) 的成功,我们需要回到过去并谈论 BERT。 BERT 由 Google 研究人员于 2018 年开发&…

用通俗易懂的方式讲解:如何提升大模型 Agent 的能力?

大型语言模型(LLM)的出现带火了Agent。利用LLM理解人类意图、生成复杂计划并且能够自主行动的能力。Agent具有无与伦比的能力,能够做出类似于人类复杂性的决策和完成一些复杂的工作。 目前市面上已经出现非常多得Agent框架:XAgen…

MongoDB复制集原理

复制集高可用 复制集选举 MongoDB 的复制集选举使用 Raft 算法(https://raft.github.io/)来实现,选举成功的必要条件是大多数投票节点存活。在具体的实现中,MongoDB 对 raft 协议添加了一些自己的扩展,这包括&#x…

Mysql大数据量下流式查询优化:Jdbc中的useFetchSize参数及其原理解析

前言 最近我朋友公司有个需求场景:查询千万级数据量并写入txt文件的程序优化需求。 朋友找到我对程序进行优化, 不然饭碗不保......💦 下面就分享一下解决这个优化问题的过程和思路,并总结一下,在以后不要在踩同样的坑…

[算法]使用aes进行数据加密

一、需求 有一段信息需要进行安全加密。 二、方案 对称加密和非对称加密两种方案,其中由于公钥密钥的管理还未形成规范,因此考虑使用对称加密。其中,对称加密算法使用openssl中,关于aes的部分,输出结果为128位数据。…

oracle-undo

tips:串行化隔离级别:事务开始后,对一张表不会被别人影响,对于审计工作比较有用,避免了幻读。 undo表空间:自动生成段,自动生成区,自动维护的,不像一般的表空间&#xff…

独立式键盘控制的4级变速流水灯

#include<reg51.h> // 包含51单片机寄存器定义的头文件 unsigned char speed; //储存流水灯的流动速度 sbit S1P1^4; //位定义S1为P1.4 sbit S2P1^5; //位定义S2为P1.5 sbit S3P1^6; //位定义S3为P1.6 sbit S4P1^7; //位…

泽攸科技完全自主研制的电子束光刻机取得阶段性成果

国产电子束光刻机实现自主可控&#xff0c;是实现我国集成电路产业链自主可控的重要一环。近日&#xff0c;泽攸科技联合松山湖材料实验室开展的全自主电子束光刻机整机的开发与产业化项目取得重大进展&#xff0c;成功研制出电子束光刻系统&#xff0c;实现了电子束光刻机整机…

rime中州韵小狼毫 生字注音滤镜 汉字注音滤镜

在中文环境下&#xff0c;多音字是比较常见的现象。对于一些不常见的生僻字&#xff0c;或者一些用于地名&#xff0c;人名中的常见字的冷门读音&#xff0c;如果不能正确的阅读&#xff0c;例如把 荥阳 读成了 miāo yng&#xff0c;则会怡笑大方。 今天我们在rime中州韵小狼…

python自动化运维管理拓扑

目录 1、简介 2、实验环境 3、拓扑图 4、需求及其代码 4.1、测试连通性 4.2、远程登陆 4.3、配置loopback 4.4、监控内存使用率 4.5、自动化巡检内存使用率 4.6、自动化配置snmp服务 4.7、提取分析字符串 &#x1f343;作者介绍&#xff1a;双非本科大三网络工程专业…

网络流量分析与故障分析

1.网络流量实时分析 网络监控 也snmp协议 交换机和服务器打开 snmp就ok了 MRTG或者是prgt 用于对网络流量进行实时监测&#xff0c;可以及时了解服务器和交换机的流量&#xff0c;防止因流量过大而导致服务器瘫痪或网络拥塞。 原理 通过snmp监控 是一个…

外汇网站主要业务逻辑梳理

上图为工行ICBC的外汇保证金交易界面。 当需要买入帐户欧元&#xff08;欧元人民币&#xff09;时&#xff0c;买入100欧元&#xff0c;因为没有杠杆&#xff0c;虽然欧元中间价是782.34&#xff0c;但实际需要支付783.14元人民币的保证金&#xff0c;这个兑换不是真实的外汇兑…

2.8 EXERCISES

如果我们想使用每个线程来计算向量加法的一个输出元素&#xff0c;那么将线程/块索引映射到数据索引的表达式是什么&#xff1f; 答&#xff1a;C 假设我们想用每个线程来计算向量加法的两个&#xff08;相邻&#xff09;元素。将线程/块索引映射到i&#xff08;由线程处理的…

[MySQL] 数据库的主从复制和读写分离

一、mysql主从复制和读写分离的相关知识 1.1 什么是读写分离? 读写分离&#xff0c;基本的原理是让主数据库处理事务性增、改、删操作( INSERT、UPDATE、DELETE) &#xff0c;而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。…

Windows11下载安装nacos(2.3.0)详解

一、环境要求 windows7以上 jdk8及以上版本&#xff0c;并且配置了JAVA_HOME环境变量 二、nacos下载解压 release版本地址:Releases alibaba/nacos GitHub 下载后解压即可&#xff0c;上面的tar.gz是linux版本 解压后如下 nacos自己内置有数据库derby&#xff0c;我用的是…

使用 matlab 求解最小二乘问题

有约束线性最小二乘 其标准形式为&#xff1a; min ⁡ x 1 2 ∥ C x − d ∥ 2 2 \mathop {\min }\limits_x \quad \frac{1}{2}\left\| Cx-d \right\|_2^2 xmin​21​∥Cx−d∥22​ 约束条件为&#xff1a; A ⋅ x ≤ b A e q ⋅ x b e q l b ≤ x ≤ u b \begin{aligned} …

RAG 全链路评测工具 —— Ragas

RAG是目前比较火热的一个概念。对应的应用如雨后春笋般涌出。我们在实际的探索中&#xff0c;可能会有各种各样的优化方案。但是优化是否有用呢&#xff1f;模型影响会有多大呢&#xff1f; 我们需要一把尺子&#xff0c;来做全链路的衡量。才能够得出&#xff0c;到底应该朝哪…