ARM64安全特性之SMAP

ARM64 SMAP(Supervisor Mode Access Prevention)是一种安全扩展,用于在ARM64架构中限制特权模式下的内存访问。它的目的是防止特权模式下的恶意软件或漏洞利用程序访问受限内存区域,从而提高系统的安全性。

SMAP的主要原理是通过设置特殊的访问权限位(AP位)来限制特权模式下的内存访问。在ARM64架构中,每个物理内存页都有对应的访问权限位,用于控制不同模式下的内存访问。SMAP通过将特权模式下的AP位设置为只读或禁止访问,可以防止特权软件访问受保护的内存区域。

具体来说,SMAP通过以下步骤实现内存保护:

1. 特权级别设置

在SMAP启用的系统中,特权级别分为EL0(用户模式)和EL1(特权模式),其中EL1包括操作系统内核和驱动程序。SMAP只对EL1级别的访问进行限制。

2. 内存访问权限

每个物理页都有一个AP位来标识访问权限。对于EL0级别的访问,AP位控制传统的访问权限(读、写、执行),而对于EL1级别的访问,AP位表示SMAP访问权限。

3. 控制内存访问

在EL1级别下,SMAP通过将AP位设置为只读或禁止访问,来限制内核和驱动程序访问特定内存区域。这样,即使内核或驱动程序存在漏洞或受到恶意软件的攻击,也无法将数据写入或执行受保护的内存区域。

与PAN的区别

SMAP(Supervisor Mode Access Prevention)和PAN(Privileged Access Never)都是ARM64架构中的安全扩展,用于提高系统的安全性。虽然它们都与特权模式下的内存访问有关,但它们有一些不同之处:

1. 功能
   - SMAP:SMAP主要用于限制特权模式下的内存访问。它通过设置特殊的访问权限位来禁止或限制特权模式下访问受限内存区域。
   - PAN:PAN用于防止特权模式下的空指针解引用。它通过编译器和硬件的配合,检测和阻止特权模式下对空指针的解引用操作。

2. 应用范围
   - SMAP:SMAP适用于EL1特权级别,即特权模式下的操作系统内核和驱动程序。
   - PAN:PAN适用于所有特权级别,包括EL0用户模式和EL1特权模式。

3. 实施方式
   - SMAP:SMAP通过设置特殊的访问权限位(AP位)来限制特权模式下的内存访问。AP位可以将指定内存区域设置为只读或禁止访问。
   - PAN:PAN通过编译器和硬件的配合来检测和阻止特权模式下的空指针解引用操作。编译器在编译时插入相关的检查代码,然后硬件在执行时检测并触发异常。

4. 依赖关系
   - SMAP:SMAP不依赖于其他安全扩展,可以独立使用。
   - PAN:PAN通常与SMAP一起使用,但它也可以作为独立的功能。PAN依赖于相关的硬件支持和编译器插件。如果硬件和编译器都不支持PAN,那么PAN将无法实施。

总的来说,ARM64 SMAP主要用于限制特权模式下的内存访问,而PAN用于防止特权模式下的空指针解引用。它们在功能、应用范围、实施方式和依赖关系上都有所不同,但都旨在提高系统的安全性。

如何配置

配置ARM64 SMAP需要在启动ARM64设备时或者操作系统的配置中进行。具体步骤如下:

1. 确保硬件支持

首先需要确保ARM64设备的处理器支持SMAP功能。通常,SMAP是在ARMv8.4-A架构及更高版本中引入的。如果处理器不支持SMAP,那么无法进行SMAP的配置和启用。

2. 修改启动配置

在启动ARM64设备时,可以通过修改启动配置来启用SMAP。具体来说,需要在设备固件(例如UEFI)或者操作系统的启动参数中添加相关选项。

    - 对于UEFI固件:在启动时,可以在启动加载器(例如GRUB)的配置文件中添加`smep/smap=1`参数来启用SMAP。

    - 对于操作系统启动参数:在Linux系统中,可以在启动项的命令行中添加`smep`或`nosmap`参数来启用或禁用SMAP。

3. 编译器选项

如果要在编译应用程序时使用SMAP,还可以使用编译器选项来启用相关优化。

    - 在GCC编译器中,可以使用`-march=armv8.4-a+smap`选项来指定编译针对支持SMAP的ARMv8.4-A架构。

    - 在Clang编译器中,可以使用`-target arm64-armv8.4a+nosmap`选项来指定编译针对不支持SMAP的ARMv8.4-A架构。

4. 测试和验证

一旦配置完成,可以测试应用程序的兼容性和正确性。通过运行针对SMAP配置的应用程序,并观察是否受到了SMAP的限制和保护来验证配置的有效性。

请注意,具体的配置方法可能因设备和操作系统的不同而有所差异。因此,在进行配置时最好参考相关的设备文档或操作系统文档来了解具体的配置选项和方法。

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

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

相关文章

new Promise用法

promise要解决的问题 回调函数问题 问题一:回调函数多层嵌套调用(回调地狱) 问题二:每次回调的结果存在成功或失败的可能性 使用 promise 解决 解决问题一:promise 通过 .then 实现链式调用 解决问题二:p…

Python的海龟 turtle 库使用详细介绍(画任意多边形,全网最详细)

学Turtle库,其实就是学数学,而且还能提高对数学和学习的兴趣。Turtle库还能够帮助孩子更好地理解几何学和数学概念,比如角度、比例、几何图形的性质等等,是Python中一个很有趣的库。 前言 Turtle库是Python中一个很有趣的库&…

Web开发-问题-前后端交互数据不一致

0x01 问题描述 所用的技术:VueSpring Boot后端传给前端数据: [Student(studentId1, personorg.fatmansoft.teach.models.Person4abe6020, major软件工程, className一班, grade一年级), Student(studentId2, personorg.fatmansoft.teach.models.Person…

百元开放式蓝牙耳机哪款好、热门高性价比开放式推荐

在众多耳机类型中,开放式耳机正逐渐崭露头角。它们融合了音质和佩戴舒适性,能给你带来全新的佩戴感受。这些耳机不仅提供高品质的音响体验,还让你能够在户外佩戴欣赏音乐的同时保持对周围环境的感知,更加安全、保障。 在本文中&a…

字符数组和字符串例题2

1、回文字符串 题目描述 给定一个字符串,长度不超过100,判断它是否是回文串。例如: aba, abcba是回文, abc, xyy 不是回文。 输入要求 输入一个字符串,由小写字母组成 输出要求 若是回文输出Yes,否则输出No 输入样例 abcb…

IDEA版SSM入门到实战(Maven+MyBatis+Spring+SpringMVC) -Mybatis核心配置详解

第一章 Mybatis核心配置详解【mybatis-config.xml】 1.1 核心配置文件概述 MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。 1.2 核心配置文件根标签 没有实际语义,主要作用:所有子标签均需要设置在跟标签内部 1.3 核心配置文件…

Lambda表达式与方法引用

作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO 联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬 引子 先来看一个案例 …

RPC基础

RPC基础知识 RPC 是什么? RPC(Remote Procedure Call) 即远程过程调用,通过名字我们就能看出 RPC 关注的是远程调用而非本地调用。 为什么要 RPC ? 因为,两个不同的服务器上的服务提供的方法不在一个内存空间&…

Hadoop学习笔记(HDP)-Part.07 安装MySQL

目录 Part.01 关于HDP Part.02 核心组件原理 Part.03 资源规划 Part.04 基础环境配置 Part.05 Yum源配置 Part.06 安装OracleJDK Part.07 安装MySQL Part.08 部署Ambari集群 Part.09 安装OpenLDAP Part.10 创建集群 Part.11 安装Kerberos Part.12 安装HDFS Part.13 安装Ranger …

无人机停机坪的主要功能有哪些

随着无人机行业领域的不断完善,无人机停机坪作为一项关键基础设施,正发挥着越来越重要的作用。无人机停机坪也叫无人机机巢、无人机机库、无人机机场。无人机停机坪不仅是无人机的“家”,更是其高效运行的关键环节。让我们一同探索无人机停机…

1+X Web 前端开发职业技能等级证书模拟题(中级)理论知识

1X Web 前端开发职业技能等级证书模拟题(中级)理论知识 一、单项选择题 在 Bootstrap 中,可以使用 navbar-header 类的情况是() A 为整个页面添加一个标题 B 为导航栏添加一个标题 C 为导航栏 添加头部 D 为整个页面添…

js对象转换为数组的两种方法

第一种方法: Object.values(obj) 示例: var obj { name: 张三, age: 18}; console.log( Object.values(obj) ); // [张三, 18]第二种方法: for-in循环 示例: var obj { name: 张三, age: 18}; var arr []; for(let i in obj) …

探讨电能质量监测与治理解决方案在半导体行业的设计与应用-安科瑞 蒋静

摘要:在国家鼓励半导体材料国产化的政策导向下,本土半导体材料厂商不断提升半导体产品技术水平和研发能力,逐渐打破了国外半导体厂商的垄断格局,推进中国半导体材料国产化进程。半导体产品的制造使用到的设备如单晶炉、多晶炉等都…

Isaac Sim教程01 Isaac Sim介绍

Isaac Sim 介绍 版权信息 Copyright 2023 Herman YeAuromix. All rights reserved.This course and all of its associated content, including but not limited to text, images, videos, and any other materials, are protected by copyright law. The author holds all…

【MySQL】基本安装配置

1 基础知识 1.1 MySQL安装 下载地址:https://dev.mysql.com/downloads/mysql/ 1.1.1 安装过程 配置环境变量(和配置Java8的环境变量如出一辙)在MySQL解压文件夹下,导入my.ini文件,与bin目录同级,具体文…

流程编排-java

传统编码方式的缺陷 1:做应用开发,传统的编码方式太过僵硬,复用性差,熟悉成本高,无法高速的满足企业的快速发展。 2:当系统做到一定的程度,大多的系统的代码,维护成本,居…

前端并发多个请求并失败重发

const MAX_RETRIES 3;// 模拟请求 function makeRequest(url) {return new Promise((resolve, reject) > {setTimeout(() > {Math.random() < 0.75 ? resolve(${url} 成功) : reject(${url} 失败); // 随机决定请求是否成功}, Math.random() * 2000); // 随机延时执…

oracle sql 把2023/05/06格式化为20230506

oracle sql 把2023/05/06格式化为20230506 在 Oracle SQL 中&#xff0c;你可以使用 TO_CHAR 函数将日期格式化为指定的字符串格式。要将日期 ‘2023/05/06’ 格式化为 ‘20230506’&#xff0c;你可以使用以下查询&#xff1a; SELECT TO_CHAR(TO_DATE(2023/05/06, YYYY/MM/…

七、Linux服务器集群搭建

详见《Linux服务器集群搭建》 【往期回顾】 一、Linux系统概述和安装 二、Linux基础命令 三、Linux高级命令 四、虚拟机网络配置 五、Linux基础软件安装 六、shell编程

vivado时序方法检查1

TIMING-1 &#xff1a; 时钟修改块上的时钟波形无效 在 <cell_type> 输出 <pin_name> 上指定的时钟 <clock_name> 的时钟波形无效 &#xff0c; 与时钟修改块 (CMB) 设置不匹配。该时钟波形为 <VALUE> 。期望的波形为 <VALUE> 。 描述…