Linux内存从0到1学习笔记(8.16 SMMU详解)---更新中

server/2024/10/8 21:11:29/

写在前面

前面博客已经了解过。SMMU是IOMMU在ARM架构上的实现。主要为了解决虚拟化环境中,GuestOS无法直接将连续的物理地址分配给硬件的问题。对于Hypervisor/GuestOS的虚拟化系统来说,所有的VM都运行在Hypervisor上,每一个VM独立运行一个OS(GuestOS),Hypervisor完成硬件的共享,隔离和切换。那么由于虚拟化系统中,GuestOS看到的内存并非实际的物理内存,因此需要SMMU对DMA设备发出的请求进行翻译,以确保正确的数据传输。所以SMMU实际上就是一个为外设提供的MMU子系统,它主要的作用就是对虚拟地址的管理,映射和翻译,以确保DMA设备能够在虚拟化环境中正常工作。

再来说说DMA?

DMA(Direct Memory Access),即直接内存存取,是一种外部设备与系统内存直接交换数据的接口技术。它允许外设将数据批量传输到内存,然后再发送一个中断通知CPU去处理,这个过程并不经过CPU,从而降低了算力负载。但是,DMA需要连续的物理内存来进行数据传输,应为它不能像CPU一样通过MMU来操作虚拟地址。我们可以把它理解为使外设和内存之间的桥梁(硬件),这样外设可以绕过CPU直接通过DMA将批量数据传输到内存。

一,QSMMU

本文基于QCOM平台的SoC进行拆解。在QCOM平台下,SMMU作为一个子系统负责将虚拟地址转换为物理地址并检查访问权限。SMMU在SoC中执行两个主要功能:内存碎片整理(使用虚拟内存)和访问控制。


http://www.ppmy.cn/server/48935.html

相关文章

Docker快速部署springboot项目

本文概述 本文主要介绍了怎么将springboot项目打包为docker镜像,并如何在后端服务器上使用docker快速部署springboot应用和nginx应用。 一、打包springboot项目 1、复制原来的application.yml文件然后重命名为application-pro.yml文件,将application-pro…

8个常用的辅助函数!!

在开发各种项目时,我们会发现经常需要一些辅助函数来帮助我们实现一些需求,并且这些函数是在很多项目里都可以进行复用的。下面我就列出我们一些常用的辅助函数,来帮助大家在开发项目时,进行复用。 1. 首字母大写 将字符串的第一…

web前端翻页:技术探秘与未来趋势

web前端翻页:技术探秘与未来趋势 Web前端翻页,作为网页交互体验的重要组成部分,始终吸引着开发者的关注。其设计原理、实现技巧以及未来趋势,都是我们在探索前端技术时不可忽视的方面。本文将从四个方面、五个方面、六个方面和七…

另辟蹊径的终端防病毒

在数字时代的浪潮中,网络安全问题愈发凸显,防病毒成为了保护信息安全的重要一环。而白名单作为一种有效的安全策略,在防病毒方面发挥着不可或缺的作用。 首先,我们需要明确白名单的概念。白名单是一种管理和安全实践,用…

2024-06-14 ubuntu 简单易用的文本编辑器nano 一些常用方法

一、在嵌入式ubuntu系统下使用vm命令乱码,不得不用nano。 二、Nano 一词源自“纳米”,是一个前缀,用于表示十亿分之一 (10^-9) 的数量级,强调了编辑器的轻量和简洁性质。 三、Nano 是一个简单易用的文本编辑器,适用于…

【机器人和人工智能——自主巡航赛项】基础篇

文章目录 基础培训模块安装电池、接口使用使用注意事项ROS基础培训 功能测试实践运动控制测试激光雷达建图测试导航测试视觉功能测试 讲解视频其余篇章 基础培训 模块安装 安装视频 电池、接口使用 使用注意事项 1、在箱子里取机器时双手请放在前后轮胎间位置抬起&#xff…

海外仓系统选择指南:中小海外仓选择海外仓系统要考虑的5件事

对中小型海外仓来说,选择海外仓管理系统是一项重要的决定,不应该掉以轻心。所选择的海外仓系统是否合适,直接决定了后续海外仓运营效率是否能得到有效的提升。 今天我们会重点讨论中小型海外仓在选择海外仓系统时的一些注意事项,…

C# WPF入门学习主线篇(十三)—— StackPanel布局容器

C# WPF入门学习主线篇(十三)—— StackPanel布局容器 欢迎来到C# WPF入门学习系列的第十三篇。在前一篇文章中,我们探讨了 Canvas 布局容器及其使用方法。本篇博客将介绍另一种常用的布局容器——StackPanel。通过本文,您将学习如…