linux源代码阅读笔记 free_page_tables()分析

76 /*
 77  * This function frees a continuos block of page tables, as needed
 78  * by ‘exit()‘. As does copy_page_tables(), this handles only 4Mb blocks.
 79  */
 80 int free_page_tables(unsigned long from,unsigned long size)//size以B为单位而不是以页表为单位
 81 {
 82         unsigned long *pg_table;
 83         unsigned long * dir, nr;
 84
 85         if (from & 0x3fffff)
 86                 panic("free_page_tables called with wrong alignment");
 87         if (!from)
 88                 panic("Trying to free up swapper memory space");
 89         size = (size + 0x3fffff) >> 22;//这里计算size大小的内存占用了多少页表。
 90         dir = (unsigned long *) ((from>>20) & 0xffc); /* _pg_dir = 0 */
 91         for ( ; size-->0 ; dir++) {
 92                 if (!(1 & *dir))
 93                         continue;
 94                 pg_table = (unsigned long *) (0xfffff000 & *dir);
 95                 for (nr=0 ; nr<1024 ; nr++) {
 96                         if (1 & *pg_table)
 97                                 free_page(0xfffff000 & *pg_table);
 98                         *pg_table = 0;
 99                         pg_table++;
100                 }
101                 free_page(0xfffff000 & *dir);
102                 *dir = 0;
103         }
104         invalidate();
105         return 0;
106 }

这个函数的功能是释放一段连续的内存,from是起始地址,size是释放的内存大小。这里需要注意的是,在

这个版本的内核中,size是以B为单位的而不是以页表为单位的。

89         size = (size + 0x3fffff) >> 22;这句代码,它的含义是将size由以B为单位转化为以页表为单位。怎么理解?在0.11版本内核中,页长度为4096b,每个页表有1024项。因此,一个页表所索引的内存最大为1024×4096=4MB。我们可以发现,如果size=4MB*n,那么执行完上面这个语句后,size即为n。
 dir = (unsigned long *) ((from>>20) & 0xffc);这句代码,是计算起始目录项
 97                                 free_page(0xfffff000 & *pg_table);这句代码。0xfffff000是保护位,pg_table所指向的页表起始地址的低位一定为0
 
时间: 2024-10-27 18:07:50

linux源代码阅读笔记 free_page_tables()分析的相关文章

linux源代码阅读笔记 find_entry分析

78 static struct buffer_head * find_entry(struct m_inode * dir, 79 const char * name, int namelen, struct dir_entry ** res_dir) find_entry是linux文件系统中一个较为费解的函数.下面我们来分析一番. 它的第一个参数是 m_inode型,它指示了函数操作的所在根目录的inode节点.即相对路径的起始节点. name自然是想要查找的目录路径,namelen是该目

linux源代码阅读笔记 linux文件系统(三)

当系统申请一个新的inode时.系统并不会对磁盘进行读写.它会在存储在内存的inode表(inode_table)中寻找一个空闲的位置. 如果找到了,直接返回该inode.否则要等待一个空闲的位置. 得到一个空闲的位置后,检查dirty位,如果dirty,那么需要写回磁盘. 但是注意,系统并不会直接对磁盘进行操作.而是申请一个高速缓冲块,对该高速缓冲块进行操作. ps:为了弥补cpu与磁盘之间巨大的速度差距.系统所有的对磁盘的读写操作都不会直接操作磁盘,而是操作高速缓冲区. 高速缓冲区再和磁盘进

非常好!!!Linux源代码阅读——中断【转】

Linux源代码阅读——中断 转自:http://home.ustc.edu.cn/~boj/courses/linux_kernel/2_int.html 目录 为什么要有中断 中断的作用 中断的处理原则 Linux 中断机制 中断控制器 中断描述符 中断数据结构 中断的初始化 内核接口 中断处理过程 CPU 的中断处理流程 保存中断信息 处理中断 从中断中返回 编写中断处理程序 软中断.tasklet与工作队列 上半部与下半部 软中断 tasklet 工作队列 1 为什么要有中断 1.1 中

CI框架源代码阅读笔记2 一切的入口 index.php

上一节(CI框架源代码阅读笔记1 - 环境准备.基本术语和框架流程)中,我们提到了CI框架的基本流程.这里再次贴出流程图.以备參考: 作为CI框架的入口文件.源代码阅读,自然由此開始. 在源代码阅读的过程中,我们并不会逐行进行解释.而仅仅解释核心的功能和实现. 1.       设置应用程序环境 define('ENVIRONMENT', 'development'); 这里的development能够是不论什么你喜欢的环境名称(比方dev,再如test).相相应的,你要在以下的switch c

Hadoop 2.2.0 Job源代码阅读笔记

本文所有涉及的内容均为2.2.0版本中呈现. 概述: Job在创建Job并且提交的人的眼中,可以在创建的时候通过配置Job的内容,控制Job的执行,以及查询Job的运行状态.一旦Job提交以后,将不能对其进行配置,否则将会出现IllegalStateException异常. 正常情况下用户通过Job类来创建.描述.提交Job,以及监控Job的处理过程.下面是一个简单的例子: // Create a new Job Job job = new Job(new Configuration()); j

CI框架源代码阅读笔记6 扩展钩子 Hook.php

CI框架同意你在不改动系统核心代码的基础上加入或者更改系统的核心功能(如重写缓存.输出等). 比如,在系统开启hook的条件下(config.php中$config['enable_hooks'] = TRUE;).通过加入特定的钩子,能够让系统在特定的时刻触发特定的脚本: $hook['post_system'] = array( 'class' => 'frameLog', 'function' => 'postLog', 'filename' => 'post_system.php

Flask 源代码阅读笔记

我认为我已经养成了一个坏习惯.在使用一个框架过程中对它的内部原理非常感兴趣,有时候须要花不少精力才 明确,这也导致了学习的缓慢,但换来的是对框架的内部机理的熟悉,正如侯捷所说,源代码面前,了无秘密.这也是 本文产生的直接原因. 一.flask session原理 flask的session是通过client的cookie实现的.不同于diango的server端实现,flask通过itsdangerous这个苦 将session的内容序列化到浏览器的cookie,当浏览器再次请求时将反序列化co

[Java] LinkedList / Queue - 源代码学习笔记

简单地画了下 LinkedList 的继承关系,如下图.只是画了关注的部分,并不是完整的关系图.本博文涉及的是 Queue, Deque, LinkedList 的源代码阅读笔记.关于 List 接口的笔记,可以参考上一篇博文 List / ArrayList - 源代码学习笔记 Queue 1. 继承 Collection 接口,并提供了额外的插入.提取和查看元素的方法.新增的方法都有两种形式:当操作失败时,抛出异常或者返回一个特殊值.特殊值可以是 null 或者 false ,这取决于方法本

Linux源代码情景分析读书笔记 物理页面的分配

函数 alloc_pages流程图 Linux源代码情景分析读书笔记 物理页面的分配,布布扣,bubuko.com