do_set_pmd

统计参数只会在这里设置:

add_mm_counter(vma->vm_mm, MM_FILEPAGES, HPAGE_PMD_NR);

但是这貌似都是处理大页的情况哪,小页呢?

alloc_set_pte中有函数:inc_mm_couter_fast(vma->vm_mm, mm_couter_file(page))

其中,mm_counter_file是在include 目录下设置的,注意一下,这个函数返回的是页的类型,有两种类型,一种是:

1446 static inline int mm_counter_file(struct page *page)
1447 {
1448 if (PageSwapBacked(page)) //如果这个页是被swap出去了,那么这个页就是MM_SHMEMPAGES,
1449 return MM_SHMEMPAGES;
1450 return MM_FILEPAGES;
1451 }
1452

SHMEMPAGES 感觉和ANON/FILE是两种不同的考察维度呀,也就是说匿名页和filebacked的页都是可以当做SHMEM来用的。好像不对啊,匿名页就是匿名页,如果是可以共享的,也就是说MAP_ANONYMOUS  和 MAP_SHARED 是可以同时设置的?【结论MAP_ANONYMOUS和MAP_SHARED是不可以同时设置的】,

PRIVATE 和 SHARED 都是对于文件来说的,是说多个

[什么叫做共享内存的页呀: 下面这个patch中加了这个统计项,patch大致思想是:目前共享内存的页,都和file-backed的文件一起去统计了(实际共享内存后面挂载的设备是/dev/zero,我们没办法看到共享内存的页了,所以这个patch就是解决的就是区分这两种页]

eca56ff906bdd0239485e8b47154a6e73dd9a2f3

那么下面一个问题还是没有解决,为什么mm_counter_file中统计出来的page只会去统计MM_SHMEM / MM_FILE

除了匿名页之外,有两种页:共享内存的页还有文件backed的页

MAP_ANONYMOUS 是不能单独出现的

SHMEMPAGES既可以当做

这一部分好好讲讲文件系统的mmap file-backed

[ 一个进程所有的页的类型包括:匿名页,文件backed的页,共享内存的页,swap出去的页.]

私有的文件映射如果改动的话会发生啥事情

《Linux环境编程》对该部分的解释有亮点,但是避重就轻,过多地去讲在MAP_SHARED的情况下,内存映射是如何完成的,比较难理解的是私有映射是如何完成的:

如果我设置了私有的映射,并且还具有写权限,这个时候如果发生了写,操作系统是如何实现的呢?这种情况也分明是存在的!

猜想:这个时候会发生写时写时复制机制,不会影响到文件的内容:【测试程序:

https://github.com/honpey/codebox/blob/master/mmap/mmap_file_private.c

设置了文件的MAP_PRIVATE 标志之后,我们发现,此时写入的任何东西都不会保存,所以我们就大胆猜想,初始化时,是做了一个映射,但是第一次访问之后,发生了缺页中断,而这个缺页中断的作用是从pagecache中copy一份数据到新的page中,即所谓的写时复制!这是file-backed mmap类型的写时复制。

这个

file mmap的更多相关文章

  1. linux删除文件后没有释放空间

    转载 http://blog.csdn.net/wyzxg/article/details/4971843 今天发现一台服务器的home空间满了,于是要清空无用的文件,当我删除文件后,发现可用空间没有 ...

  2. Linux删除文件后空间没有释放

    .COMMAND默认以9个字符长度显示的命令名称.可使用+c参数指定显示的宽度,若+c后跟的参数为零,则显示命令的全名.PID:进程的ID号.PPID父进程的IP号,默认不显示,当使用-R参数可打开. ...

  3. 实用lsof常用命令行

    1, 使用 lsof 命令行列出所有打开的文件 # lsof 这可是一个很长的列表,包括打开的文件和网络 上述屏幕截图中包含很多列,例如 PID.user.FD 和 TYPE 等等. FD - Fil ...

  4. xlrd doc

    The xlrd Module A Python module for extracting data from MS Excel ™ spreadsheet files. Version 0.7.3 ...

  5. 解决linux删除文件后空间没有释放问题

    linux删除文件后沒有释放空间 今天发现一台服务器的home空间满了,于是要清空没用的文件,当我删除文件后,发现可用空间沒有变化 os:centos4.7 现象: 发现当前磁盘空间使用情况: [ro ...

  6. lsof 命令用法详解

    lsof 命令用法详解 作用 用于查看你进程开打的文件,打开文件的进程,进程打开的端口(TCP.UDP).找回/恢复删除的文件.是十分方便的系统监视工具,因为lsof命令需要访问核心内存和各种文件,所 ...

  7. 使用 ps、strace、lsof 进行 Linux 进程 trouble-shooting

      linux_observability_tools 介绍 在Linux 下进行进程的排错,有很多方法.比如,修改源代码,print出一些关键的信息,如果代码是Python 的话,可以使用trace ...

  8. Buildroot lmbench使用方法

    /********************************************************************** * Buildroot lmbench使用方法 * 说明 ...

  9. lsof根据端口返回进程号杀死进程的方法

    参考自:http://newmiracle.cn/?p=661 Linux shell根据端口返回进程号杀死进程的方法 kill -9 `lsof -t -i:8888` 这个就是杀死8888端口的进 ...

随机推荐

  1. 6.安装使用vue-quill-editor

    前言: 在vue项目中,因为涉及到使用文本编辑器, 恰恰vue-quill-editor就是一个简单实用的富文本编辑器. 参考文档:vue中使用vue-quill-editor富文本编辑器,自定义to ...

  2. 易语言调用C++写的DLL

    直接调用会弹出堆栈错误的信息,原因是VS默认是__cdcel方式,而易语言是__stdcall,所以调用约定不一致导致堆栈错误. 解决方案很简单,易语言声明DLL函数时“在库中对应命令名”函数名前加一 ...

  3. MySQL工作经验

    以下是根据工作中遇到各种场景用到的一些Mysql用法,比较实用,基本是语法之外的一些东西. 修改账户密码 1.打开Mysql控制台,输入原密码: 2.输入以下语法:mysql> set pass ...

  4. centos7部署harbor

    官网 https://github.com/goharbor/harbor 1.升级系统内核 rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrep ...

  5. datatable 默认按某字段排序

    "columns": [ { data: null}, { data: 'name'}, { data: 'birthday'} ], "order": [[ ...

  6. 如何解决mysql中读取含表情符号的内容无法识别的问题

    当内容中包含有表情符号的时候,写入mysql时一般会设置字段或者表的charset为utf8mb4的形式: ) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicod ...

  7. POJ:3259-Wormholes(最短路判断负环)

    Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 58153 Accepted: 21747 Descripti ...

  8. [BZOJ2243][SDOI2011]染色(树链剖分)

    [传送门] 树链剖分就行了,注意线段树上颜色的合并 Code #include <cstdio> #include <algorithm> #define N 100010 # ...

  9. 简易版AI英文问答程序解决

    第四章的作业和实践题要论印象深刻无疑就是AI的那道题了.不得不说一开始看到题目的时候,我真的蒙了很久. 本题要求你实现一个简易版的 AI 英文问答程序,规则是: 1.无论用户说什么,首先把对方说的话在 ...

  10. PJSIP-PJLIB(samples) (the usage of the pjlib lib) (eg:string/I/O)

    Here are some samples about  PJLIB! PJLIB is the basic lib of PJSIP, so we need master the lib first ...