衡阳派盒市场营销有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

讓我們一起來探索反向映射這個知識點

Linux閱碼場 ? 來源:Linuxer ? 作者:Linuxer ? 2020-09-18 10:31 ? 次閱讀

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

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

創建

在反向匿名映射中除了page struct,一共有三個相關的數據結構:

vm_area_struct

anon_vma

anon_vma_chain

第一個數據結構我們已經見過了,是一個老朋友。而后兩者就是為了構造反向匿名映射而新生的。我們先來看看這兩個新的數據結構的樣子。

anon_vma

anon_vma +----------------------------+ |root | = self |parent | = self | (struct anon_vma*) | |refcount | = 1 | (atomic_t) | |degree | = 1 | (unsigned) | +----------------------------+

這個結構由anon_vma_alloc()函數統一生成,上圖中也顯示了創造出來時候的樣子。從這里看,也就是個帶有上下級關系的這么一個結構。

anon_vma_chain

anon_vma_chain +----------------------------+ |vma | | (struct vm_area_struct*)| |anon_vma | | (struct anon_vma*) | | | |rb | | (struct rb_node) | |same_vma | | (struct list_head) | +----------------------------+

這個結構由anon_vma_chain_alloc()統一創建,貌似創建完了也不需要初始化,拿來后面就直接用了。

組合

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

在這里,我們把這三個重要的數據結構之間的組合關系展現給大家。當然這只是最簡單的組合關系,目的是為了讓大家能有一個感性的認識。

anon_vma_chain鏈接了anon_vma和vma

vma則會有指針指向自己的anon_vma

空口無憑,眼見為實。那為什么會長成這樣的呢?接下來我們就來看看在內核中我們是如何將這些數據結構鏈接起來的。

鏈接

上一節的最后,我們看到了三個重要的數據結構通過鏈表和樹連接在了一起,這一節我們就來看看他們是怎么連接起來的。

anon_vma_chain_link

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

static void anon_vma_chain_link(struct vm_area_struct *vma, struct anon_vma_chain *avc, struct anon_vma *anon_vma) { avc->vma = vma; avc->anon_vma = anon_vma; list_add(&avc->same_vma, &vma->anon_vma_chain); anon_vma_interval_tree_insert(avc, &anon_vma->rb_root); }

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

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

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

do_anonymous_page

首先出場的是函數do_anonymous_page,這個函數是在匿名頁缺頁中斷時會調用的函數。

do_anonymous_page(vmf) __anon_vma_prepare(vma) avc = anon_vma_chain_alloc() anon_vma = find_mergeable_anon_vma(vma) anon_vma = anon_vma_alloc() vma->anon_vma = anon_vma anon_vma_chain_link(vma, avc, anon_vma)

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

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

....................... ************************* . . * * av v avc v v vma v +-----------+ +-------------+ +-------------+ | |<------------|anon_vma vma|------------>| | | |<- | | | | +-----------+ +-------------+ +-------------+ ^ ^ ^ ^ . . * * . . ************************* . . . . . . ************************* . . * * . avc v v vma v . +-------------+ +-------------+ . ------|anon_vma vma|------------>| | . | | | | . +-------------+ +-------------+ . ^ ^ ^ . . * * ....................... *************************

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

anon_vma_fork

看過了在單個進程中的情況,接下來我們來看看創建一個子進程時如何調整這個數據結構。這個過程由anon_vma_fork處理。

anon_vma_fork(vma, pvma) anon_vma_clone(vma, pvma) anon_vma = anon_vma_alloc() avc = anon_vma_chain_alloc() anon_vma->root = pvma->anon_vma->root anon_vma->parent = pvma->anon_vma vma->anon_vma = anon_vma anon_vma_chain_link(vma, avc, anon_vma)

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

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

....................... ************************* . . * * av v avc v v vma v +-----------+ +-------------+ +-------------+ P | |<------------|anon_vma vma|------------>| | | |<----+ | | | | +-----------+ +-------------+ +-------------+ ^ ^ ^ ^ . . * * . . ************************* . . . . . . . . . . ************************* . . * * . avc v v * . +-------------+ * . |anon_vma vma| * . | | * . +-------------+ * . ^ ^ * . . * * ...................... * * * * * * * * ....................... * * . . * * av v avc v v vma v +-----------+ +-------------+ >+-------------+ C1 | |<------------|anon_vma vma|------------>| | | | | | | | +-----------+ +-------------+ +-------------+ ^ ^ ^ ^ . . * * ....................... *************************

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

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

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

使用

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

內核也已經給我們準備好了扣動這個核武器的板機 – rmap_walk_anon。

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

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

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

原文標題:圖解內存匿名反向映射reverse mapping

文章出處:【微信公眾號:Linuxer】歡迎添加關注!文章轉載請注明出處。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • AV
    AV
    +關注

    關注

    2

    文章

    268

    瀏覽量

    44568
  • AVC
    AVC
    +關注

    關注

    0

    文章

    21

    瀏覽量

    11018
  • 映射
    +關注

    關注

    0

    文章

    47

    瀏覽量

    15861

原文標題:圖解內存匿名反向映射reverse mapping

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    總結了8個常見的知識點

    各位朋友,大家好,這里是大話硬件。 周末在家學習是非常好的時間,把以前的東西梳理下,就是非常不錯的題目。一起來看看吧~ 1、什么是建立時間和保持時間? 建立時間(Setup Time)是指被采樣
    的頭像 發表于 01-24 10:08 ?83次閱讀
    總結了8個常見的<b class='flag-5'>知識點</b>

    Aigtek功率放大器應用:電感線圈的知識點分享

    電磁驅動是功率放大器的大基礎應用領域,其中我們最常見的就是用功放來驅動電感線圈,那么關于電感線圈的這10大知識點你都知道嗎?今天Aigtek安泰電子來給大家介紹下電感線圈的基礎
    的頭像 發表于 01-07 15:43 ?164次閱讀
    Aigtek功率放大器應用:電感線圈的<b class='flag-5'>知識點</b>分享

    后悔沒有早點看到:天線設計中的知識點

    Cat.1 bis R13架構,天線架構精簡為單天線架構,去掉了分集接收天線,因此只需要根天線。 ? 知識點: Cat.1 bis相對于Cat.1的區別是,后者為兩根天線(根主天線,
    的頭像 發表于 12-24 17:11 ?502次閱讀
    后悔沒有早點看到:天線設計中的<b class='flag-5'>知識點</b>!

    視覺AI之旅:一起探索 FiftyOne ——第二部分 入門指南

    /journey-into-visual-ai-exploring-fiftyone-together-part-ii-getting-started-14cca5adfcd3 ? ? ,前言 上次我們介紹了《視覺AI之旅:一起
    的頭像 發表于 12-24 17:00 ?117次閱讀
    視覺AI之旅:<b class='flag-5'>一起</b><b class='flag-5'>探索</b> FiftyOne ——第二部分  入門指南

    接口測試理論、疑問收錄與擴展相關知識點

    本文章使用王者榮耀游戲接口、企業微信接口的展示結合理論知識,講解什么是接口測試、接口測試理論、疑問收錄與擴展相關知識點知識學院,快來一起看看吧~
    的頭像 發表于 11-15 09:12 ?389次閱讀
    接口測試理論、疑問收錄與擴展相關<b class='flag-5'>知識點</b>

    探索藍牙5.4:讓未來連接更近

    到底有哪些亮點和優勢?它又將如何改變我們的生活呢?讓我們一起來探索下。1、增強的廣播功能藍牙5.4引入了全新的廣播功能,支持更高效的廣播數
    的頭像 發表于 09-10 16:58 ?1296次閱讀
    <b class='flag-5'>探索</b>藍牙5.4:讓未來連接更近<b class='flag-5'>一</b>步

    選2088還是3051?一起來說說TA們的不同~

    作為工業實踐中最常用的現場儀表,變送器被廣泛應用于各種工業自控環境,涉及水利水電、鐵路交通、智能建筑、生產自控、航空航天、石化、油井、電力、船舶、機床、管道等眾多行業。今天我們一起來看看「2088壓力變送器」、「3051差壓變送器」這兩款變送器有啥區別?
    的頭像 發表于 09-02 10:40 ?697次閱讀
    選2088還是3051?<b class='flag-5'>一起來</b>說說TA們的不同~

    淺談PUF技術如何保護知識產權

    知識產權保護,PUF技術擁有天然獨特的優勢,能夠提供周全完善的防盜版解決方案,在保護電子產品知識產權領域具有廣闊的應用前景。 接下來,讓我們一起看看PUF技術是如何保護
    發表于 07-24 09:43

    焊接機器人的崛起:未來工業自動化的領軍者!

    隨著科技的不斷進步,焊接機器人已經成為了現代工業生產中不可或缺的部分。它們以其高效、精準的工作特性,極大地提升了生產效率和焊接質量。以下是關于焊接機器人的15個重要知識點讓我們一起來
    的頭像 發表于 06-13 10:33 ?586次閱讀
    焊接機器人的崛起:未來工業自動化的領軍者!

    模擬電子技術知識點問題總結概覽

    給大家分享模擬電子技術知識點問題總結。
    的頭像 發表于 05-08 15:16 ?1237次閱讀
    模擬電子技術<b class='flag-5'>知識點</b>問題總結概覽

    篇搞定DCS系統相關知識點

    目標。DCS系統廣泛應用于各個行業,如化工、電力、制藥等。在這些行業中,DCS系統可以實現對生產過程的集中監控和分散控制,提高生產效率和產品質量,降低能耗和減少環境污染,從而保證產品質量,并確保生產過程的安全可靠。 二.DCS系統知識點
    的頭像 發表于 03-26 18:40 ?999次閱讀
    <b class='flag-5'>一</b>篇搞定DCS系統相關<b class='flag-5'>知識點</b>

    CANape 22.0驚艷亮相!全面升級的新特性引領汽車測試技術飛躍!

    系列令人矚目的重要更新,為汽車測試技術邁上了個新的臺階提供助力。現在,讓我們一起來揭開CANape22.0的神秘面紗,探索它的主要更新特性吧!硬件
    的頭像 發表于 03-07 08:23 ?638次閱讀
    CANape 22.0驚艷亮相!全面升級的新特性引領汽車測試技術飛躍!

    【量子計算機重構未來 | 閱讀體驗】第二章關鍵知識點

    本帖最后由 oxlm_1 于 2024-3-6 23:20 編輯 之所以將第二章單獨拿出來,是因為在閱讀過程中,發現第二章知識點較多,理解起來比較耗時間。 第二章的主要知識點: 量子
    發表于 03-06 23:17

    #新開端、新起點,2024一起加油#

    ;2024一起加油\"則表達了大家共同努力,相互支持的決心和信念。 在2024年,無論你的目標是什么,都希望你能保持這種積極的心態,勇敢地面對挑戰,不斷地學習和進步。同時,也希望大家能夠相互鼓勵,共同前進,一起創造更美好的未來。 所以,
    發表于 02-26 21:01

    作為導線,銅線和鋁線有何區別?可以接在一起嗎?

    ,并討論它們可以否接在一起的問題。 首先,讓我們探討銅線和鋁線的性能差異。銅線是種有良好導電性能的材料,它的電導率高達58.1 MS/m(國際常用單位),相對電阻率為0.0278
    的頭像 發表于 02-18 13:52 ?7159次閱讀
    威尼斯人娱乐百利宫| 新葡京百家乐官网的玩法技巧和规则| 百家乐官网拍是什么| 网络博彩| 牌九娱乐城| 汝州市| 百家乐官网破解的办法| 大亨百家乐官网娱乐城| 百家乐官网的连庄连闲| 网络百家乐官网娱乐| 德州扑克学校| 皇冠网上投注网| 莱阳市| 乐都县| 哪个百家乐官网投注平台信誉好| 百家乐官网路单| 百家乐官网怎么玩| 百家乐算点子打法攻略| 澳门百家乐实战视频| 博彩百家乐的玩法技巧和规则| 全讯网carrui| 澳门葡京赌场图片| 百家乐官网号论坛博彩正网| 百家乐官网真钱斗地主| 喜达百家乐现金网| 百家乐路子技巧| 大发888娱乐场 注册| 博王国际娱乐| 最好的百家乐官网好评平台都有哪些| 百博百家乐官网的玩法技巧和规则| 百家乐网址讯博网| 百家乐娱乐礼金| 博盈娱乐场| 真人百家乐官网代理分成| 新加坡百家乐官网规则| E乐博百家乐娱乐城| 大发888常见断续| 苍山县| 累积式百家乐官网的玩法技巧和规则 | 德州扑克筹码定做| 百家乐官网有几种打法|