ARM Linux 如何模拟X86 PTE中的Present Young和Dirty标志位

2023-10-28 20:09

本文主要是介绍ARM Linux 如何模拟X86 PTE中的Present Young和Dirty标志位,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ARM Linux 如何模拟X86 PTE中的Present Young和Dirty标志位

原创文章,转载请注明出处.转载自: Li Haifeng's Blog
本文链接地址: ARM Linux 如何模拟X86 PTE中的Present Young和Dirty标志位


注:本文是参考Kernel的代码并加上个人揣测,欢迎指正
X86 MMU Page table entry中,有三个标志位在ARM 的MMU硬件所规定的Page table entry中不提供。这三个标志位的作用如下:
  • PTE_DIRTY的作用:CPU在写操作的时候,处理器会将改位置位。说明对应的页被写过,是脏的。
  • PTE_YOUNG的作用是:MMU 寻址是将该标志置位(在换出的时候,如果此标志位被置位,说明该地址刚刚被使用过,暂时不换出此pte对应的页,同时清除该标志位)。
  • PTE_PRESENT的作用是:MMU在访问PTE的时候,若PTE_PRESENT0,则将地址放在CR2寄存器中,同时触发Pagefault异常。

下图抓自:《Linux内核情景分析》

由于Linux最早是buildX86平台上的,因此移植到ARM后,也需要遵从X86的内存管理框架,模拟ARM MMU没有提供的PTE_PRESENT PTE_YOUNG PTE_WRITE

下面的分析,参考了arch/arm/include/asm/pgtable-2level.h中的注释

Q:如何模拟PTE_DIRTY ?

A:
ARM Linux是通过dirty去标识某个页是否是可以PTE_WRITE的。
对于新分配的页,如果Linux版本的PTE没有dirty标识,对其进行写操作,会触发MMU异常。该异常会被handle_pte_fault处理

Q:如何模拟PTE_YOUNG?

A:这个PTE_YOUNG在内存被分配的时候置上,当解除映射的时候,将清掉该位。如果Linux版本的PTEyoung位被清除了,MMU使用的PTE版本的value是要清除的,但TLB并不刷新。

Q:如何模拟present

A:
ARM的MMU在访问的时候,不像X86MMU那样(只要看到*pte0,就判断该页压根没有被加载到内存中;若*pte不为0PTE_PRESENT位为0,就能判断该被swap out),那么ARM MMU是如何判断某页是swap out了,还是压根就没有被加载到memory中呢?在ARM Linux中,若换出某页,会置位Linux版本中的PTE_YOUNG,清掉Linux版本中的PTE_PRESENT(在ARM Linux中,每一个页表项是有两份的)。如果被换出,那么Linux Version中的值非0,而Hardware值被置为0
arch/arm/mm/proc-v7-2level.S
103         tst     r1, #L_PTE_YOUNG
104         tstne   r1, #L_PTE_PRESENT
105         moveq   r3, #0

From Li Haifeng's Blog, post ARM Linux 如何模拟X86 PTE中的Present Young和Dirty标志位

这篇关于ARM Linux 如何模拟X86 PTE中的Present Young和Dirty标志位的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/295636

相关文章

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

基于Linux的ffmpeg python的关键帧抽取

《基于Linux的ffmpegpython的关键帧抽取》本文主要介绍了基于Linux的ffmpegpython的关键帧抽取,实现以按帧或时间间隔抽取关键帧,文中通过示例代码介绍的非常详细,对大家的学... 目录1.FFmpeg的环境配置1) 创建一个虚拟环境envjavascript2) ffmpeg-py

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变