模拟神器之QEMU

1. 简介

QEMU(quick emulator)是一款由法布里斯·贝拉(Fabrice Bellard)等人编写的免费的可执行硬件虚拟化的(hardware virtualization)开源托管虚拟机(VMM)。

QEMU 是一个托管的虚拟机镜像,它通过动态的二进制转换,模拟CPU,并且提供一组设备模型,使它能够运行多种未修改的客户机OS,可以通过与KVM一起使用进而接近本地速度运行虚拟机(接近真实电脑的速度)。

QEMU还可以为user-level的进程执行CPU仿真,进而允许了为一种架构编译的程序在另外一种架构上面运行(借由VMM的形式)。

大致介绍完就不得不介绍编写此软件的作者:法布里斯·贝拉

2. 法布里斯·贝拉

  1. 1972年生于法国格勒诺布尔(Grenoble)。在高中就读期间开发了著名的可执行压缩程序LZEXE,这是当年DOS上第一个广泛使用的文件压缩程序。大学就读于巴黎综合理工学院,后在巴黎高等电信学校攻读。

  2. 1996年,他编写了一个简洁但是完整的C编译器和一个Java虚拟机Harissa。Fabrice Bellard发明的TinyCC是GNU/Linux环境下最小的ANSI C语言编译器,是目前号称编译速度最快的C编译器。

  3. 1997年,他提出了最快速的计算圆周率的算法,是贝利-波尔温-普劳夫公式的变体。在计算圆周率的过程中,Fabrice Bellard使用改良后的查德诺夫斯基方程算法来进行圆周率的计算,并使用贝利-波尔温-普劳夫公式来验证计算的结果。为了纪念他对圆周率算法所作出的杰出贡献,Fabrice Bellard所使用的改良型算法被命名为Fabrice Bellard算法,这种算法是目前所有圆周率算法中最快的一种,这个计算N位PI的公式比传统的BBP算法要快47%。

  4. 1998年,贝拉开发出VReng (虚拟现实引擎),这是一个分布式 3D 应用程序,运用多播技术允许通过 Internet 连接在虚拟世界中导航。之后,贝拉注意到有效的OpenGL后端是基于软件的,比实际需求要慢很多。于是他决定基于 VReng 的代码来编写一个更小和更快的3D光栅。

  5. 2000年,他化名Gérard Lantau,创建了FFmpeg项目。FFmpeg单词中的FF指的是Fast Forward,FFmpeg这个2000年发起著名的开源多媒体播放器项目,是MPlayer的姊妹项目。这是一个如此重要的成就。这个多平台、多功能的多媒体编码解码器由Fabrice Bellard发起并管理,现在是由Michael Niedermayer在进行维护。

    这个项目无比强大,我们今天所熟知的视频播放软件,如暴风影音、QQ影音、YouTube、VLC等都使用了FFmpeg的编解码函数库。FFmpeg易扩展、功能强、速度快、占资源少,支持的音视频格式极其广泛,基本上超越了其他所有同类软件,被誉为处理数字视频和音频的“瑞士军刀”。

  6. 2002 年,贝拉发布了 TinyGL,一个 OpenGL 的子集的小型实现。TinyGL 比 Mesa 和Solaris 的OpenGL 快很多,是平台独立的,并且数量级比后二者小很多,总共才 400KB。这也是他在图像处理领域取得的重要成就。

  7. 2003年,开发了Emacs克隆QEmacs

  8. 2004年,他编写了一个只有138KB的启动加载程序TCCBOOT,可以在15秒内从源代码编译并启动Linux系统。

  9. 2005年,用普通PC和VGA卡设计了一个数字电视系统。

  10. 2005年,发布了QEMU,QEMU是一个处理器仿真,可以用软件来模拟不同处理器体系,允许为一个特定处理器编译的程序通过软件仿真在另外一个体系上运行。QEMU近似于已有的Bochs、PearPC,但具有后两者所不具备的高速及跨平台等特性。

    📢 因为QEMU的速度之快、效率之高,它被包含在许多主要的虚拟化技术中,如 VirtualBox、Xen以及Linux Kernel-based 虚拟机(KVM)。

  11. 2009年12月31日,他声称打破了圆周率计算的世界纪录,算出小数点后2.7万亿位,仅用一台普通个人电脑。他使用的个人PC价格不到2000欧元,仅用了116天,就计算出了PI的小数点后第2.7万亿位,超过了由目前排名世界第47位的T2K Open超级计算机于2009年8月17日创造的世界纪录。新纪录比原纪录多出1200亿位,然而,他使用的这台桌面电脑的配置仅为:2.93GHz Core i7 CPU,6GB内存,7.5TB硬盘。

  12. 2011年,他使用JavaScript写了一个PC虚拟机Jslinux。这个虚拟机仿真了一个32位的x86兼容处理器,一个8259可编程中断控制器,一个8254可编程中断计时器,和一个16450 UART。

  13. 2012年,在PC上用软件实现4G LTE基站。

  14. 2019年,他编写了一款新的Javascript引擎QuickJS

贝拉的产出如此之快,质量如此之高,被誉为:

        世界上最多产的程序员(Super-ProductiveProgrammer)

3. 模式

在 qemu 的术语中,运行整个操作系统的方式,称为 full system emulation, 在 Ubuntu/CentoS 由软件包 qemu-system-xxx (比如qemu-system-ppc, qemu-system-aarch64, qemu-system-arm)提供功能。

运行单个程序文件的方式,称为 user mode emulation,由软件包qemu-user或者qemu-user-static提供功能。

3.1 Full System Emulation

虚拟整个操作系统就需要制作内核镜像和根文件系统镜像 [参考这篇文章]

这篇文章里,提供了两种方法来制作根文件系统,一种是基于busybox的,另一种是基于Ubuntu的rootfs的。我采用的是busybox,比较小巧,当然也比较简陋,很多etc配置都没有。

编译好的内核和根文件系统镜像都以压缩包的形式放在这里了 [下载地址]

可以直接拿来验证。对于根文件系统镜像,可以mount挂载后进行修改,但是对于内核镜像,就不能直接修改了,所以最好还是都自己编译一下。

接下来就是启动虚拟机了。

qemu-system-aarch64 -cpu cortex-a57 -smp 4 -m 2048M -M virt -nographic \-kernel build_arm64/arch/arm64/boot/Image \-append "console=ttyAMA0 root=/dev/vda init=/linuxrc rw" \-drive format=raw,file=../busybox_rootfs/busybox-1.31.1-rootfs_ext4.img
  • 第一行的"cpu"指定了处理器的架构,"smp"指定了处理器的个数,"m"指定了内存的大小。
  • 第二行的"kernel"指定编译生成的内核镜像的存放位置,第三行的"append"是内核启动的附加参数。
  • 第四行的"drive"指定之前制作生成的根文件系统的镜像位置

3.2 User Mode Emulation

可以到下面的网址下载

https://github.com/multiarch/qemu-user-static/releases

在这里插入图片描述
那什么场景会使用这个模式呢?

举一个例子:我想在 PC 上运行 Arm的程序,也就是我的CPU是 X86_64 架构的,但是想运行 arm64 架构的程序。那么就可以通过 qemu 来运行。

$ qemu-aarch64-static hello_world
hello world!

hello_world 是编译好的arm可执行程序。

参考文档

  • QEMU的配置和使用
  • 用 qemu-user 在arm linux机器上运行amd64/x86程序

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

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

相关文章

X86_64平台运行Arm docker容器

QEMU是什么 QEMU是一个通用的开源的跨平台仿真模拟器,提供user和system两种模式。其模拟的作用可是可以模拟在特定的体系结构下的应用的执行或者构建,比如在x86的体系结构的操作系统上运行ARM的应用。 常见问题的场景 在ARM体系结构的硬件环境中安装D…

Go 条件编译

接触过C/C++编程的应该一定知道条件编译。通常为了满足不同环境下使用不同的代码,从而在编译的时候进行选择性的编译,达到最佳的泛用性。 例如: #define WINDOWS #ifdef WINDOWS # include <windows.h> #elif defined LINUX # include <sys/types.h> # includ…

Boost Arm 交叉编译

Boost Arm 交叉编译 1. 源码下载 下载地址&#xff1a;https://sourceforge.net/projects/boost/files/boost/ 这里下载 1.74.0 版本 然后解压。 2. 配置 有些库我们是不需要的&#xff0c;所以就不需要编译&#xff0c;可以通过 -show-libraries 查看库列表 vincentmsi-…

为什么Linux会开机黑屏?

有的童鞋由于工作的需要&#xff0c;或者想体验一把无广告的世界&#xff0c;会去尝试使用Linux的发行版&#xff0c;但是经常被Linux拒之门外&#xff0c;甚至连系统到装不上&#xff0c;当然这个现象也在越来越少&#xff0c;只有更多的人去使用它&#xff0c;它才会变的更好…

Golang跨平台UI框架之Wails(一)

Golang作为后端、脚手架、API服务等很常见,但Go不仅仅局限于此,它的目标是星辰大海!本系列文章就开始讲解如何使用Go来构建现代化的桌面级程序。 1. 初识Wails Wails 是一个框架,可使用 Go 和 Web 技术编写桌面应用程序。我们先来欣赏一下美图: Go官方是不支持写带有GUI…

Linux安装NVIDIA显卡驱动的正确姿势

文章目录Linux安装NVIDIA显卡驱动的正确姿势什么是nouveau驱动&#xff1f;检测NVIDIA驱动是否成功安装集显与独显的切换使用标准仓库进行自动化安装使用**PPA**仓库进行自动化安装使用官方的NVIDIA驱动进行手动安装常见问题解决Linux安装NVIDIA显卡驱动的正确姿势 可能想玩Li…

Linux安装CUDA的正确姿势

Linux安装CUDA的正确姿势 CUDA&#xff08;Compute Unified Device Architecture&#xff0c;统一计算架构&#xff09;是由NVIDIA所推出的一种集成技术&#xff0c;是该公司对于GPGPU的正式名称。 透过这个技术&#xff0c;用户可利用NVIDIA的GeForce 8以后的GPU和较新的Qua…

Linux升级内核的正确姿势

Linux升级内核的正确姿势 很多童鞋在玩耍linux发行版的时候&#xff0c;都会遇到各种各样的问题&#xff0c;比如&#xff1a;网卡不能使用&#xff0c;亮度不能调节&#xff0c;触摸板不能识别&#xff0c;蓝牙不能使用等等&#xff0c;这些关系都和linux的内核有关系。 什么…

Ubuntu 18.04安装NVIDIA(英伟达) RTX2080Ti显卡

Ubuntu 18.04安装NVIDIA&#xff08;英伟达&#xff09; RTX2080Ti显卡 在安装显卡之前请先把ubuntu 18.04系统提前安装好。 需要准备的资料&#xff1a; NVIDIA 驱动 下载驱动 驱动的下载地址&#xff0c;在此下载页面选择合适的显卡&#xff0c;目前最新的显卡驱动版本是…

Ubuntu18.04安装cuDNN和Tensorflow的正确姿势

文章目录Ubuntu18.04安装cuDNN和Tensorflow的正确姿势一、检查NVIDIA驱动是否安装成功二、检查CUDA是否安装成功三、安装cuDNN1. 确定版本2. 下载安装包3. 解压安装4. 安装libcupti四、安装Tensorflow1. 确定版本2. 安装pip3. 安装Tensorflow4. 检查是否正常运行五、错误解决1.…

HttpServletResponse应用 的 简单介绍

HttpServletResponse是专门用于HTTP协议的ServletResponse接口&#xff0c;它用于封装HTTP响应消息&#xff0c;允许操控HTTP协议相关数据&#xff0c;包括响应头和状态码&#xff0c;支持Cookies和session跟踪&#xff0c;HttpServletResponse也定义了一系列用于描述各种HTTP状…

移动站应该尝试百度MIP的五个原因

MIP 是什么&#xff1f;MIP 是百度在 2016 年提出的移动网页加速器项目。 MIP 能做什么&#xff1f;MIP 能帮助站长和网站开发者快速搭建移动端页面。 MIP 怎么加速&#xff1f;MIP 从前端渲染和页面网络传输两方面进行优化&#xff0c;杜绝页面渲染中的阻塞问题&#xff0c;…

Vim从理解到应用

1991 年&#xff0c;来自荷兰的一名工程师 Bram Moolenaar 为了在他的Amiga计算机上复制Vi的功能&#xff0c;正式发布 了Vim的第一个版本。在当时无论谁也没想到&#xff0c;这款软件未来能在技术圈爆发出那么大的威力&#xff0c;为千千万万的工程师节省了无数时间&#xff0…

如何用百度MIP快速搭建体验友好的移动页面

在读这篇文章之前&#xff0c;请确定你已经了解 MIP 定义及加速原理。如果不确定的话&#xff0c;可以到 MIP 官网了解。 改造前期准备和注意事项: 你可以选择直接将原先的移动站点直接改成 MIP 站&#xff0c;也可以单独再做一套 MIP 站点与移动站并存。 复杂的页面暂不建议…

JAVA知识基础(一):数据类型

在我们学习一门编程语言时&#xff0c;最先要了解的就是数据类型&#xff0c;而数据类型又都是抽象的概念&#xff0c;初学者理解起来比较困难&#xff0c;所以我们往往是先应用再理解&#xff0c;但是在本篇文章我决定用先理解再应用的方式尝试一下&#xff0c;试试效果。 1、…

百度MIP移动页面加速——不只是CDN

MIP 是用 CDN 做加速的么&#xff1f;准确答案是&#xff1a;是&#xff0c;但不只是。 MIP 全称 Mobile Instant Pages&#xff0c;移动网页加速器&#xff0c;是百度提出的页面加速解决方案。MIP 从前端渲染和页面网络传输两方面进行优化&#xff0c;杜绝页面渲染中的阻塞问…

JAVA知识基础(二):基本语法

本篇主要介绍JAVA的运算符、循环结构以及条件结构。 1、JAVA运算符 计算机的最基本用途之一就是执行数学运算&#xff0c;作为一门计算机语言的Java也提供了一套丰富的运算符来操纵变量。 JAVA运算符可以大致概括为几类&#xff1a;算术运算符、关系运算符、位运算符、逻辑运…

JAVA知识基础(三):修饰符

JAVA中根据修饰对象的不同可以分为类修饰符、方法修饰符、变量修饰符三类&#xff0c;其中每种修饰符又可以单独分成两类&#xff1a;访问修饰符和非访问修饰符。为了便于理解&#xff0c;本文以访问和非访问的角度展开。 1、访问修饰符 访问修饰符有四个&#xff1a;public、…

百度推出新技术 MIP,网页加载更快,广告呢?

MIP 项目在 2016 年年初正式发布&#xff0c;帮助移动页面加速&#xff08;原理&#xff09;。内测数据表明&#xff0c;MIP 页面在 1s 内加载完成。现在已经有十多家网站加入 MIP 项目&#xff0c;有更多的网站正在加入中。在MIP收到的反馈中&#xff0c;大部分都提到了广告的…

JAVA知识基础(四):深入理解static关键字

1、static存在的主要意义 static的主要意义是在于创建独立于具体对象的域变量或者方法。以致于即使没有创建对象&#xff0c;也能使用属性和调用方法&#xff01; static关键字还有一个比较关键的作用就是 用来形成静态代码块以优化程序性能。static块可以置于类中的任何地方…