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.rhkb.cn/news/233871.html

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

相关文章

SparkStreaming基础解析(四)

1、 Spark Streaming概述 1.1 Spark Streaming是什么 Spark Streaming用于流式数据的处理。Spark Streaming支持的数据输入源很多,例如:Kafka、Flume、Twitter、ZeroMQ和简单的TCP套接字等等。数据输入后可以用Spark的高度抽象原语如:map、…

差分信号,光耦介绍

差分信号 原理 差分信号是由双绞线进行通讯的,为什么选择双绞线呢?因为这其中有个电磁学的原理,在通讯过程中噪声一般来自外界天气或其它元器件的电磁干扰导致导线中的电流变得不稳定,如2.3v是低电平突然被噪声干扰会造成信号增…

IOS:Safari无法播放MP4(H.264编码)

一、问题描述 MP4使用H.264编码通常具有良好的兼容性,因为H.264是一种广泛支持的视频编码标准。它可以在许多设备和平台上播放,包括电脑、移动设备和流媒体设备。 使用caniuse查询H.264兼容性,看似确实具有良好的兼容性: 然而…

【设计模式之美】面向对象分析方法论与实现(二):需求到接口实现的方法论

文章目录 一. 进行面向对象设计1. 划分职责>需要有哪些类2. 定义类及其属性和方法3. 定义类与类之间的交互关系4. 将类组装起来并提供执行入口 二. 如何进行面向对象编程?1. 接口实现2. 辩证思考与灵活应用 【设计模式之美】面向对象分析方法论与实现&#xff08…

window mysql5.7 搭建主从同步环境

window 搭建mysql5.7数据库 主从同步 主节点 配置文件my3308.cnf [mysql] # 设置mysql客户端默认字符集 default-character-setutf8mb4[mysqld] server-id8 #server-uuidbc701be9-ac71-11ee-9e35-b06ebf511956 log-binD:\mysql_5.7.19\mysql-5.7.19-winx64\mysql-bin binlog-…

jvm虚拟机初识

JVM Java虚拟机就是二进制字节码的运行环境,负责装载字节码到其内部,解释/编译为对应平台上的机器指令执行。每一条Java指令,Java虚拟机规范中都有详细定义,如怎么取操作数,怎么处理操作数,处理结果放在哪…

云解析迁移【腾讯云到阿里云】

一、关闭 DNSSEC 域名如有配置DNSSEC,请先到域名注册商处关闭DNSSEC,等迁移完成后,再参考DNSSEC设置方法进行配置。如域名未配置DNSSEC,则忽略此步骤。 解析数据准备: 请在原DNS服务商处导出解析记录,并按…

眼镜用超声波清洗机洗会有伤害吗?这些超声波清洗机适合清洗眼镜

用超声波清洗机洗眼镜是一种非常好的选择,超声波清洗机通过高频振动,将眼镜上的污渍、灰尘等清洗干净,比手洗更彻底、更高效。然而,有些人担心超声波清洗机会对眼镜造成伤害。实际上,这种担心是多余的。超声波清洗机在…

Java版直播商城:电商源码、小程序、三级分销及 免 费 搭 建 方案

一、技术选型 java开发语言:java是一种跨平台的编程语言,适用于大型企业级应用开发。使用java开发直播商城可以保证系统的稳定性和可扩展性。 spring boot框架:spring boot是一个快速构建spring应用的框架,简化了开发过程&#xf…

SpringBoot集成Camunda

一&#xff1a;pom.xml 因camunda集成SpringBoot对SpringBoot的版本和JDK的版本都有一定的要求&#xff0c;所以这里贴个完整的依赖。可以去官网找每个SpringBoot的版本对应的camunda版本。 <?xml version"1.0" encoding"UTF-8"?> <project x…

一分钟带你了解深度学习算法

深度学习是一种受到生物学启发的机器学习方法&#xff0c;其目标是通过构建多层神经网络来模拟人脑的工作原理。它在过去几十年来取得了巨大的进展&#xff0c;并在图像识别、语音识别、自然语言处理等领域取得了突破性的成果。 深度学习的核心思想是模仿人脑的神经网络。人脑中…

flex弹性盒子常用的布局属性详解

想必大家在开发中经常会用到flex布局。而且还会经常用到 justify-content 属性实现分栏等等 接下来给大家分别讲一下 justify-content 的属性值。 以下是我敲的效果图大家可以清晰看出区别 space-between 属性值可以就是说两端对齐 space-evenly 属性值是每个盒子之间的…

欧洲编程语言四巨头

从左往右&#xff0c;依次是 尼克劳斯沃斯 (Niklaus Wirth)&#xff0c;迪杰斯特拉&#xff08;Edsger Dijkstra&#xff09;&#xff0c;霍尔&#xff08;Tony Hoare&#xff09; 尼克劳斯沃斯 (Niklaus Wirth) 瑞士人&#xff0c;一生发明了8种编程语言&#xff0c;其中最著…

大数据深度学习长短时记忆网络(LSTM):从理论到PyTorch实战演示

文章目录 大数据深度学习长短时记忆网络&#xff08;LSTM&#xff09;&#xff1a;从理论到PyTorch实战演示1. LSTM的背景人工神经网络的进化循环神经网络&#xff08;RNN&#xff09;的局限性LSTM的提出背景 2. LSTM的基础理论2.1 LSTM的数学原理遗忘门&#xff08;Forget Gat…

PHP入门指南:从小白到编程达人

推荐阅读 智能化校园&#xff1a;深入探讨云端管理系统设计与实现&#xff08;一&#xff09; 智能化校园&#xff1a;深入探讨云端管理系统设计与实现&#xff08;二&#xff09; 文章目录 推荐阅读PHP语法注释变量输出定界符数据类型var_dump() 方法 PHP弱类型弱类型比较内置…

Python自动化办公之PDF拆分

今天我们继续分享真实的自动化办公案例&#xff0c;希望各位 Python 爱好者能够从中得到些许启发&#xff0c;在自己的工作生活中更多的应用 Python&#xff0c;使得工作事半功倍&#xff01; 需求 需要从 PDF 中取出几页并将其保存为新的 PDF&#xff0c;为了后期使用方便&a…

关于车规级齐纳二极管MMBZ5V6ALT1G 它又有什么作用?

MMBZ5V6ALT1G是一款双单片硅齐纳二极管专为需要瞬态过电压保护能力的应用而设计&#xff0c;它们适用于电压和ESD敏感设备&#xff0c;如计算机、打印机、商用机器、通信系统、医疗设备和其他应用。它们的双结共阳极设计仅使用一个封装即可保护两条独立的线路&#xff0c;该器件…

rtu水文专用(支持SL/T427-2021等大部分协议)

SRTU200 系列是一款集数据采集与 4G/NB-IoT、LoRa、GPS 等多种通信功能于一体的 多功能遥测终端机&#xff0c;该设备搭配丰富的采集控制接口&#xff0c;提供 RS232、RS485、以太网、模拟量 输入、开关量输入、开关量输出和继电器等。产品设计人性化&#xff0c;功能丰富&…

Mysql文件-笔记

我们小组技术分享mysql&#xff0c;给我表这块&#xff0c;这个知识呀 只要你想学 源源不断 源源不断&#xff0c;我其实想把我们组的分享都弄出来&#xff0c;偷偷的 嘘~ 表是特定实体的数据集合&#xff0c;关系型数据库模型核心&#xff0c;表逻辑存储和实现&#xff0c;物理…

WPF 导航界面悬浮两行之间的卡片 漂亮的卡片导航界面 WPF漂亮渐变颜色 WPF漂亮导航头界面 UniformGrid漂亮展现

在现代应用程序设计中&#xff0c;一个漂亮的WPF导航界面不仅为用户提供视觉上的享受&#xff0c;更对提升用户体验、增强功能可发现性和应用整体效率起到至关重要的作用。以下是对WPF漂亮导航界面重要性的详尽介绍&#xff1a; 首先&#xff0c;引人入胜的首页界面是用户与软…