首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux-3.14.12内存管理笔记【建立内核(3)

前面已经分析了内核的准备工作以及内核低端内存建立,接着回到init_mem_mapping()中,低端内存建立后紧随着还有一个函数early_ioremap_page_table_range_init...“窗口”映射到内核地址空间,调用kmap_atomic可以搭建起“窗口”到高端内存的关系,即建立临时内核映射。...总的来说就是该临时内核映射区间是为了给各个CPU准备一个指定的窗口空间。由于kmap_atomic()对该区间的使用,所以该区间必须保证其连续性。...为了避免前期可能对固定映射区已经分配了表项,基于临时内核映射区间要求连续性的保证,所以在此重新申请连续的空间将原内容拷贝至此。...至此,内核建立完毕。

1.5K11

Linux-3.14.12内存管理笔记【建立内核(1)】

前面已经分析过了Intel的内存映射和linux的基本使用情况,已知head_32.S仅是建立临时内核还是要建立内核,做到全面映射的。...建立内核前奏,了解两个很关键的变量: max_pfn:最大物理内存页面帧号; max_low_pfn:低端内存区(直接映射空间区的内存)的最大可用帧号; max_pfn 的值来自setup_arch...既然到此,顺便介绍一下内核空间映射情况。 ? 内核空间如上图,分为直接内存映射区(低端内存,线性)和高端内存映射区。...Linux是一个支持多硬件平台的操作系统,各种硬件芯片的分页并非固定的2级(全局目录和),仅仅Intel处理器而言,就存在3级的情况(全局目录、中间目录和),而到了64位系统的时候就成了4...此外还有一个准备操作,在setup_arch()函数中调用的缓冲区申请操作: early_alloc_pgt_buf(): 【file:/arch/x86/mm/init.c】 void __init

1.8K41
您找到你想要的搜索结果了吗?
是的
没有找到

内核调试

一、配置内核 首先配置内核,使其支持导出内核到debugfs下面: Kernel hacking ---> ---> [*] Export kernel pagetable layout to...而为了快速方便找到对应物理而将所有的帧结构体映射到此区域,后续只需使用virt_to_page, phys_to_page等宏实现虚拟地址,物理地址到对应结构体的快速查询。...地址空间port属性说明 第一列 当前的映射范围地址 第二列 代表此映射范围大小 PMD PUD PTE 当标识为PMD PUD表示当前映射为block映射,如当前为4K,则pud的block映射一次性可映射...当标识为PTE表示为映射即PAGE_SIZE大小4K。 USR AP标记,用于标识当前范围是否在用户空间还是内核空间可读可写或者仅读。...x表述当前范围特权级别模式可执行,就是内核的可执行代码段,在内核中这段一般指向内核的text*段 SHD 表示可共享属性,在arm64上表述为多核之间可共享其可见 AF 访问标志,当首次映射时,

13710

内核知识第八讲,PDE,PTE,目录,的内存管理

内核知识第八讲,PDE,PTE,目录,的内存管理 一丶查看GDT....首先我们的CR3寄存器保存了的首地址. 这里有一个目录,还有的关键词. 目录: 也称为PDE,而称之为PTE....CPU会通过虚拟地址,当作下表.去目录中查询.然后查到的结果再去中查询.这样就查到对应的物理地址了....PDE的大小:   目录,存储在一个4K字节的物理中,其中每一项是4个字节.保存了的地址.   而最大是1M个. PTE的大小.   PTE的大小也和PDE一样的....但是通过两个查询.可以映射4G内存.而上面的设计方法不行. 首先前边20位保存了或者物理地址的基地址. 比如我们的目录. 查到了第5项.那么从中取出千20位来,加上000就等于了.

1.4K10

驱动开发:内核解析内存四级

当今操作系统普遍采用64位架构,CPU最大寻址能力虽然达到了64位,但其实仅仅只是用到了48位进行寻址,其内存管理采用了9-9-9-9-12的分页模式,9-9-9-9-12分表示物理地址拥有四级,...9-9-9-9-12的分页模式是一种常见的分页方案,其中物理地址被分成四级:PXE(Page Directory Pointer Table Entry)、PPE(Page Directory Entry...每个级别的都负责将虚拟地址映射到更具体的物理地址。通过这种层次化的结构,操作系统可以更有效地管理和分配内存。...PTE 0即可解析,如下所示,当前地址0位置处的PTE基址是FFFF898000000000,由于PTE的一个大小是0x1000所以当内存地址高于0x1000时将会切换到另一个中,如下FFFF898000000008...则是另一个中的地址。

16630

驱动开发:内核解析内存四级

当今操作系统普遍采用64位架构,CPU最大寻址能力虽然达到了64位,但其实仅仅只是用到了48位进行寻址,其内存管理采用了9-9-9-9-12的分页模式,9-9-9-9-12分表示物理地址拥有四级,...9-9-9-9-12的分页模式是一种常见的分页方案,其中物理地址被分成四级:PXE(Page Directory Pointer Table Entry)、PPE(Page Directory Entry...每个级别的都负责将虚拟地址映射到更具体的物理地址。通过这种层次化的结构,操作系统可以更有效地管理和分配内存。...PTE 0即可解析,如下所示,当前地址0位置处的PTE基址是FFFF898000000000,由于PTE的一个大小是0x1000所以当内存地址高于0x1000时将会切换到另一个中,如下FFFF898000000008...则是另一个中的地址。

51190

Linux内核管理-那些鲜为人知的秘密

,可以将各级放到物理内存的任何地方,无论是硬件遍历还是内核遍历,比一级更复杂,但是为了节省内存,内核选择多级结构。...2)Linux内核 填写,将基地址告诉mmu 内核初始化建立内核,实现缺页异常等机制为用户任务按需分配并映射。 当然,内核也可以遍历,如缺页异常时遍历进程。 10....内核中涉及到的基地址?...填写/切换时机 1)内核填充 内核初始化过程: 物理地址 -> 恒等映射(建立恒等映射和粗粒度内核) ->打开mmu -> paging_init(建立细粒度的内核和内存线性映射...2)用户填充 访问时缺页填充: 用户进程访问已经申请的虚拟内存时,发生缺页,缺页处理程序中为进程分配各级等物理建立映射关系。

1.7K21

深入理解Linux内核映射分页机制原理

而实现虚拟内存的关键就在于建立虚拟地址(Virtual Address,VA)与物理地址(Physical Address,PA)之间的关系,因为无论如何数据终究要存储到物理内存中才能被记录下来。...缺页异常,对于进程申请的内存,并不需要在其申请内存时即建立地址转换映射表,同时分配对应的物理空间,而是在进程真正访问内存地址时,MMU上报缺页异常再分配对应的物理空间。...…… 针对这些话题本文不做深入探讨,可以阅读另一篇为其量身定做的博文《深入Linux内核(内存篇)—TLB》。 1.5 多大合适?...pgd_offset_k(addr) 根据入参虚拟地址address和init_mm,找到address在全局目录中相应表项的线性地址。仅用于内核。...ARMv8采用4KB大小,使用4级时,内存分布如下,内核空间和用户空间大小分别为256TB。

2.9K10

宋宝华: ARM64 Linux内核的块映射

以典型的4K和48位虚拟地址为例,整个内核空间的虚拟地址分布如下: ?...我们看看这种情况下的,我们既可以用最终的【20:12】对应的PTE映射项,以4K为单位,进行虚拟地址到物理地址的映射;又可以以【29:21】对应的PMD映射项,以2M为单位,进行虚拟地址到物理地址的映射...我们把它们全部选中,这样我们可以得到一个debugfs接口: /sys/kernel/debug/kernel_page_tables 来获知内核的情况。...我在内核启动参数加的rodata=0实际上是让rodata_full为false。如果我把这个kernel启动选项去掉,我得到的内核是完全不一样,线性映射区也全部是PTE映射: ?...这个patchset的原理建立在,当内核以4KB分页的时候,每个page需要64字节的page struct。

3.2K10

内核必须懂(七): Linux四级(x64)

目录 前言 Intel四级 实操寻址 获取cr3 获取PGD 获取PUD 获取PMD 获取PTE 获取内容 最后 ---- 前言 Linux四级的作用主要就是地址映射, 将逻辑地址映射到物理地址...很多时候, 有些地方想不明白就可以查看实际物理地址进行分析. ---- Intel 四级 其实很多设计的根源或者说原因都来自于CPU的设计, OS很多时候都是辅助CPU....Linux的四级就是依据CPU的四级来设计的. 这里主要说的就是Intel x64面大小为4KB的情况, 如图所示: ?...在Linux当中, 第一级称为PGD, 当然是有历史原因的, 可以自行google. 所以Linux的四级分别是PGD -> PUD -> PMD -> PTE. ?...---- 最后 当然了, 这次是在用户态下进行从线性地址到物理地址转换的, 如果是内核态有些地方会发生变化. 暂时写到这里, 内核态等后续的更新了.

6.8K40

一文看懂影子和扩展

后引入机制,把虚拟地址送往MMU,MMU查TLB不中的情况下,依次查就可以找到对应的物理地址。...二.影子 (Shadow page table) 影子我用一句话来描述就是:VMM把Guest和Host中的合并成一个,称为影子,来实现GVA->HPA映射。...4, 把GVA -> HPA,这一路的映射关系记录到中,这个就是影子。...虚拟机和影子通过一个哈希建立关联(当然也有其他的关联方式),客户机操作系统把当前进程的基址载入PDBR时而VMM将会截获这一特权指令,将进程的影子基址载入客户机PDBR,使客户机在恢复运行时...硬件层面引入EPTP寄存器,来指向EPT基地址。Guest运行时,Guest被载入PDBR,而 EPT 被载入专门的EPT 指针寄存器 EPTP。

1.5K20

建立uboot,内核的SI工程(1)

建立Uboot的SI工程 1.1首先给uboot打上补丁,然后来生成压缩文件 tar cjf u-boot-1.1.6_jz2440.tar.bz2 u-boot-1.1.6 1.2 编译uboot make...最后点击synchronize files 创建source insight工程 1.9设置si,使能够查看汇编文件 点击Options->Document Options,设置如下: 2 创建内核...source sight 工程 2.1首先给内核打上补丁,然后来生成压缩文件 tar xjf linux-2.6.22.6.tar.bz2 cd linux-2.6.22.6/ patch -p1...cd .. tar -cjf linux-2.6.22.6_jz2440.tar.bz2 linux-2.6.22.6 2.2编译内核 2.2.1 编译内核之前还需要修改.config来配置内核,配置有...uImage) 参考: 第3阶段——内核启动分析之内核编译试验(1) 2.3然后将压缩文件拖到windows里,创建SI工程 2.4 点击 “add all” 添加所有文件,后面再慢慢删去与2440芯片没用的文件

57920

给Excel工作建立目录

有时候我们会在一个工作簿中建立很多工作,怎样才能简单明了的管理工作呢,当然能建一个目录最好了,这里我们就学习一种给工作创建目录的方法。 1、在工作簿中新建一个工作,命名为“目录”。...A1",MID(目录,FIND("]",目录)+1,99)),"") 现在可以看到效果了,单击目录中的工作名称,就会自动跳转到相应工作。...注意:GET.WORKBOOK函数是宏函数,可以提取当前工作簿中的所有工作名,需要先定义名称后使用。...也就是“工作簿名称+后缀名+工作名称”。 T(NOW())部分返回一个空值,目的是让GET.WORKBOOK函数结果能够实时更新。...注意:工作保存时需要选择保存类型为“Excel 启用宏的工作簿(*.xlsm)”,同时需要在Excel选项中将宏安全性设置为中,否则会不能正常使用了。

1.5K40

多级的好处

,如果只使用了一个,一个表项的大小为4byte,32位系统有4GB的物理空间(一个进程看到是4GB大小的虚拟空间),每一个表项对应着物理空间的第xxx(4KB大小的),那么应该有4GB/4KB=...如果是二级,规则就会改变,让二级对应到物理内存上的4KB大小的,一级此时变成映射为物理地址的4MB(这样子是无法定位到具体的(4KB)的,所以二级再去找),这样先找到一级,一级再和二级进行结合...,二级表相当于一级4MB分成了1024个(1KB个)4KB,找完后二级充当了offset的角色,此时定位到具体的4KB的页面,再用一级的offset一结合定位到具体物理地址。...这样一个进程浪费掉的空间是一级占用的:(4GB/4MB)*4byte=4KB,二级浪费掉的是1kb(1个一级占用这么多)*1kb(此时有1kb(4GB/4MB)个一级)=4MB,加起来是...4MB+4KB,比光用一级要多4KB,但是2级是可以不存在的,比如此时程序只用了%20的,那么4MB就需要乘以%20,这样一下子就比只有一级时少了。

1.6K30
领券