0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

讓我們一起來(lái)探索反向映射這個(gè)知識(shí)點(diǎn)

Linux閱碼場(chǎng) ? 來(lái)源:Linuxer ? 作者:Linuxer ? 2020-09-18 10:31 ? 次閱讀

反向映射的目的是為了找到所有映射到某一個(gè)頁(yè)面的頁(yè)表項(xiàng),從而可以對(duì)目標(biāo)頁(yè)做一些操作,比如切斷映射。

反向映射一直是一個(gè)非常神奇的存在,今天我們就好好探索一下這個(gè)知識(shí)點(diǎn)。

創(chuàng)建

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

vm_area_struct

anon_vma

anon_vma_chain

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

anon_vma

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

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

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) | +----------------------------+

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

組合

到這里,大家應(yīng)該感覺(jué)怪怪的,都不知道這些東西是個(gè)啥。別急,我把這些東西組合起來(lái),可能你就會(huì)有一些感覺(jué)了。

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

anon_vma_chain鏈接了anon_vma和vma

vma則會(huì)有指針指向自己的anon_vma

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

鏈接

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

anon_vma_chain_link

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

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); }

你對(duì)照這上面的圖一看,和圖上顯示的一摸一樣沒(méi)有任何多余的步驟。

但是,關(guān)鍵的但是來(lái)了,如果你以為一切就這這么簡(jiǎn)單,那就too young too simple了啊。

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

do_anonymous_page

首先出場(chǎng)的是函數(shù)do_anonymous_page,這個(gè)函數(shù)是在匿名頁(yè)缺頁(yè)中斷時(shí)會(huì)調(diào)用的函數(shù)。

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)

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

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

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

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

anon_vma_fork

看過(guò)了在單個(gè)進(jìn)程中的情況,接下來(lái)我們來(lái)看看創(chuàng)建一個(gè)子進(jìn)程時(shí)如何調(diào)整這個(gè)數(shù)據(jù)結(jié)構(gòu)。這個(gè)過(guò)程由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)

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

話不多說(shuō),還是用一個(gè)圖來(lái)表達(dá)

....................... ************************* . . * * 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是父進(jìn)程,C1是他的一個(gè)子進(jìn)程。當(dāng)發(fā)生fork時(shí),page->mapping沒(méi)有發(fā)生改變,所以依然需要能夠從父進(jìn)程的anon_vma上搜索到對(duì)應(yīng)的頁(yè)表。此時(shí)就得在父進(jìn)程的rb_root樹中保留一個(gè)子進(jìn)程的avc。同時(shí)子進(jìn)程又擁有自己的一套anon_vma。

可以說(shuō)這個(gè)真的是非常有意思的。

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

使用

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

內(nèi)核也已經(jīng)給我們準(zhǔn)備好了扣動(dòng)這個(gè)核武器的板機(jī) – 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

有了上面的基礎(chǔ)知識(shí),我想看這段代碼就不難了。還記得上面看到過(guò)的那個(gè)rb_root么?對(duì)了,我們就是沿著這顆紅黑樹找到的vma,然后再找到了頁(yè)表。

嗯,一切都感覺(jué)這么的完美。

原文標(biāo)題:圖解內(nèi)存匿名反向映射reverse mapping

文章出處:【微信公眾號(hào):Linuxer】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • AV
    AV
    +關(guān)注

    關(guān)注

    2

    文章

    268

    瀏覽量

    44507
  • AVC
    AVC
    +關(guān)注

    關(guān)注

    0

    文章

    21

    瀏覽量

    10996
  • 映射
    +關(guān)注

    關(guān)注

    0

    文章

    47

    瀏覽量

    15816

原文標(biāo)題:圖解內(nèi)存匿名反向映射reverse mapping

文章出處:【微信號(hào):LinuxDev,微信公眾號(hào):Linux閱碼場(chǎng)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    后悔沒(méi)有早點(diǎn)看到:天線設(shè)計(jì)中的知識(shí)點(diǎn)!

    Cat.1 bis R13架構(gòu),天線架構(gòu)精簡(jiǎn)為單天線架構(gòu),去掉了分集接收天線,因此只需要根天線。 ? 知識(shí)點(diǎn): Cat.1 bis相對(duì)于Cat.1的區(qū)別是,后者為兩根天線(根主天線,
    的頭像 發(fā)表于 12-24 17:11 ?198次閱讀
    后悔沒(méi)有早點(diǎn)看到:天線設(shè)計(jì)中的<b class='flag-5'>知識(shí)點(diǎn)</b>!

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

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

    接口測(cè)試?yán)碚?、疑?wèn)收錄與擴(kuò)展相關(guān)知識(shí)點(diǎn)

    本文章使用王者榮耀游戲接口、企業(yè)微信接口的展示結(jié)合理論知識(shí),講解什么是接口測(cè)試、接口測(cè)試?yán)碚?、疑?wèn)收錄與擴(kuò)展相關(guān)知識(shí)點(diǎn)知識(shí)學(xué)院,快來(lái)一起看看吧~
    的頭像 發(fā)表于 11-15 09:12 ?313次閱讀
    接口測(cè)試?yán)碚?、疑?wèn)收錄與擴(kuò)展相關(guān)<b class='flag-5'>知識(shí)點(diǎn)</b>

    探索藍(lán)牙5.4:讓未來(lái)連接更近

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

    選2088還是3051?一起來(lái)說(shuō)說(shuō)TA們的不同~

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

    淺談PUF技術(shù)如何保護(hù)知識(shí)產(chǎn)權(quán)

    知識(shí)產(chǎn)權(quán)保護(hù),PUF技術(shù)擁有天然獨(dú)特的優(yōu)勢(shì),能夠提供周全完善的防盜版解決方案,在保護(hù)電子產(chǎn)品知識(shí)產(chǎn)權(quán)領(lǐng)域具有廣闊的應(yīng)用前景。 接下來(lái),讓我們一起看看PUF技術(shù)是如何保護(hù)
    發(fā)表于 07-24 09:43

    探索紅外熱成像探測(cè)器的基礎(chǔ)原理

    紅外熱成像探測(cè)器究竟是什么?它是如何工作的呢?讓我們一起來(lái)揭秘。紅外熱成像探測(cè)器:神奇的熱能揭示者紅外探測(cè)器可獲得物體表面的溫度場(chǎng)分布圖像,從而實(shí)現(xiàn)紅外成像。該種探測(cè)器適用于紅外輻射成像、紅外熱成像
    的頭像 發(fā)表于 07-03 16:06 ?841次閱讀
    <b class='flag-5'>探索</b>紅外熱成像探測(cè)器的基礎(chǔ)原理

    焊接機(jī)器人的崛起:未來(lái)工業(yè)自動(dòng)化的領(lǐng)軍者!

    隨著科技的不斷進(jìn)步,焊接機(jī)器人已經(jīng)成為了現(xiàn)代工業(yè)生產(chǎn)中不可或缺的部分。它們以其高效、精準(zhǔn)的工作特性,極大地提升了生產(chǎn)效率和焊接質(zhì)量。以下是關(guān)于焊接機(jī)器人的15個(gè)重要知識(shí)點(diǎn),讓我們一起來(lái)
    的頭像 發(fā)表于 06-13 10:33 ?534次閱讀
    焊接機(jī)器人的崛起:未來(lái)工業(yè)自動(dòng)化的領(lǐng)軍者!

    模擬電子技術(shù)知識(shí)點(diǎn)問(wèn)題總結(jié)概覽

    給大家分享模擬電子技術(shù)知識(shí)點(diǎn)問(wèn)題總結(jié)。
    的頭像 發(fā)表于 05-08 15:16 ?1168次閱讀
    模擬電子技術(shù)<b class='flag-5'>知識(shí)點(diǎn)</b>問(wèn)題總結(jié)概覽

    篇搞定DCS系統(tǒng)相關(guān)知識(shí)點(diǎn)

    目標(biāo)。DCS系統(tǒng)廣泛應(yīng)用于各個(gè)行業(yè),如化工、電力、制藥等。在這些行業(yè)中,DCS系統(tǒng)可以實(shí)現(xiàn)對(duì)生產(chǎn)過(guò)程的集中監(jiān)控和分散控制,提高生產(chǎn)效率和產(chǎn)品質(zhì)量,降低能耗和減少環(huán)境污染,從而保證產(chǎn)品質(zhì)量,并確保生產(chǎn)過(guò)程的安全可靠。 二.DCS系統(tǒng)知識(shí)點(diǎn)
    的頭像 發(fā)表于 03-26 18:40 ?904次閱讀
    <b class='flag-5'>一</b>篇搞定DCS系統(tǒng)相關(guān)<b class='flag-5'>知識(shí)點(diǎn)</b>

    CANape 22.0驚艷亮相!全面升級(jí)的新特性引領(lǐng)汽車測(cè)試技術(shù)飛躍!

    系列令人矚目的重要更新,為汽車測(cè)試技術(shù)邁上了個(gè)新的臺(tái)階提供助力?,F(xiàn)在,讓我們一起來(lái)揭開CANape22.0的神秘面紗,探索它的主要更新特性吧!硬件
    的頭像 發(fā)表于 03-07 08:23 ?576次閱讀
    CANape 22.0驚艷亮相!全面升級(jí)的新特性引領(lǐng)汽車測(cè)試技術(shù)飛躍!

    【量子計(jì)算機(jī)重構(gòu)未來(lái) | 閱讀體驗(yàn)】第二章關(guān)鍵知識(shí)點(diǎn)

    本帖最后由 oxlm_1 于 2024-3-6 23:20 編輯 之所以將第二章單獨(dú)拿出來(lái),是因?yàn)樵陂喿x過(guò)程中,發(fā)現(xiàn)第二章知識(shí)點(diǎn)較多,理解起來(lái)比較耗時(shí)間。 第二章的主要知識(shí)點(diǎn): 量子
    發(fā)表于 03-06 23:17

    #新開端、新起點(diǎn),2024一起加油#

    ;2024一起加油\"則表達(dá)了大家共同努力,相互支持的決心和信念。 在2024年,無(wú)論你的目標(biāo)是什么,都希望你能保持這種積極的心態(tài),勇敢地面對(duì)挑戰(zhàn),不斷地學(xué)習(xí)和進(jìn)步。同時(shí),也希望大家能夠相互鼓勵(lì),共同前進(jìn),一起創(chuàng)造更美好的未來(lái)。 所以,
    發(fā)表于 02-26 21:01

    作為導(dǎo)線,銅線和鋁線有何區(qū)別?可以接在一起嗎?

    ,并討論它們可以否接在一起的問(wèn)題。 首先,讓我們來(lái)探討銅線和鋁線的性能差異。銅線是種有良好導(dǎo)電性能的材料,它的電導(dǎo)率高達(dá)58.1 MS/m(國(guó)際常用單位),相對(duì)電阻率為0.0278
    的頭像 發(fā)表于 02-18 13:52 ?6238次閱讀

    帶您一起詳細(xì)了解IEEE802.3bt(PoE++)的有關(guān)特點(diǎn)

    Hqst華強(qiáng)盛(盈盛電子)導(dǎo)讀:帶您一起詳細(xì)了解IEEE802.3bt(PoE++)的有關(guān)特點(diǎn),讓我們對(duì)IEEE802.3bt(PoE++)協(xié)議有更具體的了解
    的頭像 發(fā)表于 01-04 11:26 ?2187次閱讀
    帶您<b class='flag-5'>一起</b>詳細(xì)了解IEEE802.3bt(PoE++)的有關(guān)特點(diǎn)