成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

圖解內(nèi)存匿名反向映射Reverse Mapping

存儲 存儲軟件
反向映射的目的是為了找到所有映射到某一個頁面的頁表項,從而可以對目標頁做一些操作,比如切斷映射。

 [[342467]]

反向映射的目的是為了找到所有映射到某一個頁面的頁表項,從而可以對目標頁做一些操作,比如切斷映射。

反向映射一直是一個非常神奇的存在,今天我們就好好探索一下這個知識點。

創(chuàng)建

在反向匿名映射中除了page struct,一共有三個相關的數(shù)據(jù)結(jié)構(gòu):

  • vm_area_struct
  • anon_vma
  • anon_vma_chain

第一個數(shù)據(jù)結(jié)構(gòu)我們已經(jīng)見過了,是一個老朋友。而后兩者就是為了構(gòu)造反向匿名映射而新生的。我們先來看看這兩個新的數(shù)據(jù)結(jié)構(gòu)的樣子。

anon_vma

  1. anon_vma 
  2.     +----------------------------+ 
  3.     |root                        |  = self 
  4.     |parent                      |  = self 
  5.     |    (struct anon_vma*)      | 
  6.     |refcount                    |  = 1 
  7.     |    (atomic_t)              | 
  8.     |degree                      |  = 1 
  9.     |    (unsigned)              | 
  10.     +----------------------------+ 

這個結(jié)構(gòu)由anon_vma_alloc()函數(shù)統(tǒng)一生成,上圖中也顯示了創(chuàng)造出來時候的樣子。從這里看,也就是個帶有上下級關系的這么一個結(jié)構(gòu)。

anon_vma_chain

  1. anon_vma_chain 
  2.    +----------------------------+ 
  3.    |vma                         | 
  4.    |    (struct vm_area_struct*)| 
  5.    |anon_vma                    | 
  6.    |    (struct anon_vma*)      | 
  7.    |                            | 
  8.    |rb                          | 
  9.    |    (struct rb_node)        | 
  10.    |same_vma                    | 
  11.    |    (struct list_head)      | 
  12.    +----------------------------+ 

這個結(jié)構(gòu)由anon_vma_chain_alloc()統(tǒng)一創(chuàng)建,貌似創(chuàng)建完了也不需要初始化,拿來后面就直接用了。

組合

到這里,大家應該感覺怪怪的,都不知道這些東西是個啥。別急,我把這些東西組合起來,可能你就會有一些感覺了。

 

在這里,我們把這三個重要的數(shù)據(jù)結(jié)構(gòu)之間的組合關系展現(xiàn)給大家。當然這只是最簡單的組合關系,目的是為了讓大家能有一個感性的認識。

  • anon_vma_chain鏈接了anon_vma和vma
  • vma則會有指針指向自己的anon_vma

空口無憑,眼見為實。那為什么會長成這樣的呢?接下來我們就來看看在內(nèi)核中我們是如何將這些數(shù)據(jù)結(jié)構(gòu)鏈接起來的。

鏈接

上一節(jié)的最后,我們看到了三個重要的數(shù)據(jù)結(jié)構(gòu)通過鏈表和樹連接在了一起,這一節(jié)我們就來看看他們是怎么連接起來的。

anon_vma_chain_link

往簡單了講,要連接這三個重要的數(shù)據(jù)結(jié)構(gòu),都靠一個函數(shù):anon_vma_chain_link(vma, avc, anon_vma)。而這個函數(shù)本身簡單到令人發(fā)指,以至于我能把整個定義給大家展示出來。

  1. static void anon_vma_chain_link(struct vm_area_struct *vma, 
  2.                     struct anon_vma_chain *avc, 
  3.                     struct anon_vma *anon_vma) 
  4.     { 
  5.         avc->vma = vma; 
  6.         avc->anon_vma = anon_vma; 
  7.         list_add(&avc->same_vma, &vma->anon_vma_chain); 
  8.         anon_vma_interval_tree_insert(avc, &anon_vma->rb_root); 
  9.     } 

你對照這上面的圖一看,和圖上顯示的一摸一樣沒有任何多余的步驟。

但是,關鍵的但是來了,如果你以為一切就這這么簡單,那就too young too simple了啊。

接下來我們將從anon_vma_chain_link函數(shù)被調(diào)用的關系入手,去看看在實際運行中究竟會演化出什么樣的變化來。

do_anonymous_page

首先出場的是函數(shù)do_anonymous_page,這個函數(shù)是在匿名頁缺頁中斷時會調(diào)用的函數(shù)。

  1. do_anonymous_page(vmf) 
  2.         __anon_vma_prepare(vma) 
  3.             avc = anon_vma_chain_alloc() 
  4.             anon_vma = find_mergeable_anon_vma(vma) 
  5.             anon_vma = anon_vma_alloc() 
  6.             vma->anon_vma = anon_vma 
  7.             anon_vma_chain_link(vma, avc, anon_vma) 

從上面的流程可以看出,當發(fā)生缺頁中斷時,內(nèi)核會給對應的vma構(gòu)造anon_vma,并且利用avc去鏈接這兩者。這種可以說是系統(tǒng)中最簡單的例子,也是上圖中顯示的情況。

細心的人可能已經(jīng)看到了,上面有一種情況是find_mergeable_anon_vma。如果這個函數(shù)返回一個可以重用的anon_vma,那么內(nèi)核就可以利用原有的anon_vma了。此時這個圖我們可以畫成這樣。

  1.       .......................      ************************* 
  2.         .                     .      *                       * 
  3. av      v                 avc v      v                vma    v 
  4. +-----------+             +-------------+             +-------------+ 
  5. |           |<------------|anon_vma  vma|------------>|             | 
  6. |           |<-           |             |             |             | 
  7. +-----------+  \          +-------------+             +-------------+ 
  8.         ^                     ^      ^                       ^ 
  9.         .       \             .      *                       * 
  10.         .                     .      ************************* 
  11.         .        \            . 
  12.         .                     . 
  13.         .         \           .      ************************* 
  14.         .                     .      *                       * 
  15.         .          \      avc v      v                vma    v 
  16.         .                 +-------------+             +-------------+ 
  17.         .           ------|anon_vma  vma|------------>|             | 
  18.         .                 |             |             |             | 
  19.         .                 +-------------+             +-------------+ 
  20.         .                     ^      ^                       ^ 
  21.         .                     .      *                       * 
  22.         .......................      ************************* 

其實此處我畫得不夠精確,av 和 avc之間應當是樹的關系,而不是現(xiàn)在顯示的鏈表的關系。但是我想意思已經(jīng)表達清楚,即在一個進程中多個vma可以共享同一個anon_vma作為匿名映射的節(jié)點。

anon_vma_fork

看過了在單個進程中的情況,接下來我們來看看創(chuàng)建一個子進程時如何調(diào)整這個數(shù)據(jù)結(jié)構(gòu)。這個過程由anon_vma_fork處理。

  1. anon_vma_fork(vma, pvma) 
  2.         anon_vma_clone(vma, pvma) 
  3.         anon_vma = anon_vma_alloc() 
  4.         avc = anon_vma_chain_alloc() 
  5.         anon_vma->root = pvma->anon_vma->root 
  6.         anon_vma->parent = pvma->anon_vma 
  7.         vma->anon_vma = anon_vma 
  8.         anon_vma_chain_link(vma, avc, anon_vma) 

這個函數(shù)很有意思,我還真是花了些時間去理解它。最開始有點看不清,所以我干脆退回到最簡單的狀態(tài),也就是當前進程是根進程的時候。此時我才大致的了解了一點fork時究竟發(fā)生了什么。

話不多說,還是用一個圖來表達

  1.             .......................      ************************* 
  2.             .                     .      *                       * 
  3.     av      v                 avc v      v                vma    v 
  4.     +-----------+             +-------------+             +-------------+ 
  5. P   |           |<------------|anon_vma  vma|------------>|             | 
  6.     |           |<----+       |             |             |             | 
  7.     +-----------+      \      +-------------+             +-------------+ 
  8.             ^                     ^      ^                       ^ 
  9.             .           \         .      *                       * 
  10.             .                     .      ************************* 
  11.             .            \        . 
  12.             .                     . 
  13.             .             \       . 
  14.             .                     . 
  15.             .              \      .      ************************* 
  16.             .                     .      *                       * 
  17.             .               \ avc v      v                       * 
  18.             .                 +-------------+                    * 
  19.             .                \|anon_vma  vma|\                   * 
  20.             .                 |             |                    * 
  21.             .                 +-------------+  \                 * 
  22.             .                    ^       ^                       * 
  23.             .                    .       *       \               * 
  24.             ......................       *                       * 
  25.                                          *         \             * 
  26.                                          *                       * 
  27.                                          *           \           * 
  28.             .......................      *                       * 
  29.             .                     .      *             \         * 
  30.     av      v                 avc v      v              \ vma    v 
  31.     +-----------+             +-------------+            >+-------------+ 
  32. C1  |           |<------------|anon_vma  vma|------------>|             | 
  33.     |           |             |             |             |             | 
  34.     +-----------+             +-------------+             +-------------+ 
  35.             ^                     ^      ^                       ^ 
  36.             .                     .      *                       * 
  37.             .......................      ************************* 

P是父進程,C1是他的一個子進程。當發(fā)生fork時,page->mapping沒有發(fā)生改變,所以依然需要能夠從父進程的anon_vma上搜索到對應的頁表。此時就得在父進程的rb_root樹中保留一個子進程的avc。同時子進程又擁有自己的一套anon_vma。

可以說這個真的是非常有意思的。

對了,代碼中還有一個函數(shù)anon_vma_clone,在這里我就不展開了。留給大家下來思考一下下。

使用

好了,到了這里我們已經(jīng)擁有了一個非常強悍的武器 – 匿名反向映射。有了他我們就可以指哪打哪了。

內(nèi)核也已經(jīng)給我們準備好了扣動這個核武器的板機 – rmap_walk_anon。

  1. rmap_walk_anon(page, rwc, true/false
  2.         anon_vma = page_anon_vma(page), get anon_vma from page->mapping 
  3.         pgoff_start = page_to_pgoff(page); 
  4.             return page_to_index(page) 
  5.         pgoff_end = pgoff_start + hpage_nr_pages(page) - 1; 
  6.         anon_vma_interval_tree_foreach(avc, &anon_vma->rb_root, pgoff_start, pgoff_end) 
  7.         rwc->rmap_one(page, vma, address, rwc->arg) -> do the real work 

有了上面的基礎知識,我想看這段代碼就不難了。還記得上面看到過的那個rb_root么?對了,我們就是沿著這顆紅黑樹找到的vma,然后再找到了頁表。

嗯,一切都感覺這么的完美。

本文轉(zhuǎn)載自微信公眾號「Linux閱碼場」,可以通過以下二維碼關注。轉(zhuǎn)載本文請聯(lián)系Linux閱碼場公眾號。

 

責任編輯:武曉燕 來源: Linux閱碼場
相關推薦

2018-10-10 14:14:51

Linux內(nèi)存映射

2009-06-03 14:06:44

ibmdwXML

2020-11-20 07:55:55

Linux內(nèi)核映射

2021-04-27 13:56:49

內(nèi)存.映射地址

2011-03-21 09:11:52

Linux頁面回收反向映射

2024-05-06 08:09:10

Linux內(nèi)存管理

2013-10-12 13:01:51

Linux運維內(nèi)存管理

2009-12-15 16:09:54

水星MR804端口映射

2023-02-20 08:27:17

2009-07-24 10:00:38

.NET 4.0內(nèi)存映

2022-01-10 17:41:31

內(nèi)存結(jié)構(gòu)PostgreSQL

2021-09-05 18:29:58

Linux內(nèi)存回收

2009-12-14 13:19:50

TENDA路由器端口映

2011-04-25 17:15:39

MongodbMMAP

2012-06-20 14:16:36

Java內(nèi)存映射

2019-02-26 14:33:22

JVM內(nèi)存虛擬機

2023-03-01 10:37:51

2022-01-26 00:10:00

Linux內(nèi)存磁盤

2024-07-26 10:23:52

2025-04-07 00:01:00

Linux內(nèi)核反向映射
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久中文字幕视频 | 中文区中文字幕免费看 | 成人在线免费观看视频 | 欧美综合在线观看 | 久久免费视频观看 | 欧美男人亚洲天堂 | www.日本国产 | 午夜电影一区二区 | 欧美成人aaa级毛片在线视频 | 国产精品久久久久久久岛一牛影视 | 色婷婷国产精品综合在线观看 | 日产久久 | 欧美日韩精品一区二区三区四区 | 久久免费看 | 成人欧美一区二区三区在线播放 | 国产精品3区 | 日本不卡一区二区 | 夜夜草视频 | 日韩精品在线播放 | 激情欧美日韩一区二区 | 国产精品久久久久久久久婷婷 | 色综合久久久久 | 日本激情视频在线播放 | 97精品国产一区二区三区 | 黄色在线观看网址 | 亚洲精品乱码久久久久久蜜桃91 | 成人在线激情 | 日韩最新网站 | 国产精品久久一区 | 国产亚洲日本精品 | 人人人人人爽 | 国际精品鲁一鲁一区二区小说 | 毛片免费观看 | 精品一区二区三区在线观看 | 久久综合一区 | 国产欧美在线视频 | 国产在线视频一区二区 | 久久aⅴ乱码一区二区三区 亚洲国产成人精品久久久国产成人一区 | 日韩av免费在线观看 | 国产精品美女www爽爽爽 | 亚洲精品一区二区三区四区高清 |