哈哈哈哈哈操欧洲电影,久草网在线,亚洲久久熟女熟妇视频,麻豆精品色,久久福利在线视频,日韩中文字幕的,淫乱毛视频一区,亚洲成人一二三,中文人妻日韩精品电影

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(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)見(jiàn)過(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ú)憑,眼見(jiàn)為實(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ò)鏈表和樹(shù)連接在了一起,這一節(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è)圖我們可以畫(huà)成這樣。

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

其實(shí)此處我畫(huà)得不夠精確,av 和 avc之間應(yīng)當(dāng)是樹(shù)的關(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í)間去理解它。最開(kāi)始有點(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樹(shù)中保留一個(gè)子進(jìn)程的avc。同時(shí)子進(jìn)程又擁有自己的一套anon_vma。

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

對(duì)了,代碼中還有一個(gè)函數(shù)anon_vma_clone,在這里我就不展開(kāi)了。留給大家下來(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ì)了,我們就是沿著這顆紅黑樹(shù)找到的vma,然后再找到了頁(yè)表。

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

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

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(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

    文章

    269

    瀏覽量

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

    關(guān)注

    0

    文章

    23

    瀏覽量

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

    關(guān)注

    0

    文章

    49

    瀏覽量

    16510

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    示波器小知識(shí)點(diǎn)

    示波器的系統(tǒng)帶寬:是指個(gè)逐漸升高頻率的正弦輸入信號(hào)顯示幅度下降3dB時(shí)的頻率點(diǎn)。測(cè)試信號(hào)般是方波,而方波信號(hào)由基波及奇次諧波組成。如果用示波器去測(cè)個(gè)方波,需要注意示波器應(yīng)從頻率上
    的頭像 發(fā)表于 04-16 11:04 ?37次閱讀
    示波器小<b class='flag-5'>知識(shí)點(diǎn)</b>

    ADA4522與ad8021一起使用 如何用ADA4522補(bǔ)償零點(diǎn)漂移?

    求助!ADA4522與ad8021一起使用 如何用ADA4522補(bǔ)償零點(diǎn)漂移?有償!目前只知道積分的方法也許可以,但是不知道如何實(shí)現(xiàn)AD8021是同相比例放大
    發(fā)表于 04-16 09:26

    S32DS 3.5 內(nèi)存映射視圖在閃存擦除/寫(xiě)入后不更新問(wèn)題怎么解決

    我將 S32 Design Studio 3.5 與 RDT 環(huán)境和 GHS 工具鏈一起使用,但我遇到了內(nèi)存映射視圖的問(wèn)題。 當(dāng)我在從 RAM 運(yùn)行時(shí)執(zhí)行閃存擦除和寫(xiě)入作時(shí),實(shí)際內(nèi)存內(nèi)容會(huì)正確更新
    發(fā)表于 04-15 08:26

    【黑金云課堂筆記】第三期知識(shí)點(diǎn)總結(jié)

    ,對(duì) FPGA 免費(fèi)直播課的熱情也感染到了黑金云課堂的老師們。接下來(lái)我們會(huì)再接再厲,把每期直播都做得更扎實(shí) ? 更多精彩課程歡迎關(guān)注我們 黑金云課堂全年免費(fèi)直播課 ,現(xiàn)在讓我們先來(lái)回
    的頭像 發(fā)表于 04-01 16:08 ?150次閱讀
    【黑金云課堂筆記】第三期<b class='flag-5'>知識(shí)點(diǎn)</b>總結(jié)

    如何使用 Python 將 I2C LCD 與 VIsionFive 一起使用?

    以使用新的 VisionFive.gpio 庫(kù)。 讓我們連接 LCD 來(lái)監(jiān)控事物 By Hamzah。 如何使用 Python 將 I2C LCD 與 VIsionFive 一起使用:I2c LCD 是當(dāng)今非常
    發(fā)表于 03-30 06:52

    TVS二極管的實(shí)戰(zhàn)選型指南和布局技巧

    在前三期課程中,我們深入了解了TVS二極管的工作原理、類(lèi)型區(qū)分和選型要點(diǎn)。今天,讓我們一起來(lái)掌握TVS二極管的實(shí)戰(zhàn)選型指南和布局技巧,為這個(gè)系列畫(huà)上完美的句號(hào)。
    的頭像 發(fā)表于 01-19 14:40 ?1.2w次閱讀
    TVS二極管的實(shí)戰(zhàn)選型指南和布局技巧

    MAX9937:具備反向電池保護(hù)功能的電流檢測(cè)放大器

    MAX9937:具備反向電池保護(hù)功能的電流檢測(cè)放大器 在電子設(shè)備的設(shè)計(jì)中,電流檢測(cè)是至關(guān)重要的環(huán),它能夠幫助我們監(jiān)測(cè)設(shè)備的運(yùn)行狀態(tài)、確保系統(tǒng)的穩(wěn)定性和安全性。今天,讓我們
    的頭像 發(fā)表于 01-14 10:35 ?297次閱讀

    活動(dòng)邀請(qǐng) | 2025 Maker Farie Shenzhen,跟M5Stack一起來(lái)造!

    三天的創(chuàng)客盛宴,一起點(diǎn)亮無(wú)限創(chuàng)意!每年的十一月,都是屬于創(chuàng)客的高光時(shí)刻。今年M5Stack將在11月15日至17日連續(xù)三天,帶來(lái)滿滿的創(chuàng)客能量:我們將攜最新產(chǎn)品與創(chuàng)新項(xiàng)目亮相
    的頭像 發(fā)表于 11-07 18:25 ?684次閱讀
    活動(dòng)邀請(qǐng) | 2025 Maker Farie Shenzhen,跟M5Stack<b class='flag-5'>一起來(lái)</b>造!

    【「AI芯片:科技探索與AGI愿景」閱讀體驗(yàn)】+AI的科學(xué)應(yīng)用

    理論、實(shí)驗(yàn)及仿真統(tǒng)一起來(lái),催生了數(shù)據(jù)密集型科學(xué),這就是第四范式。它利用大量的計(jì)算和數(shù)據(jù)處理來(lái)研究復(fù)雜的問(wèn)題和現(xiàn)象。特點(diǎn)如下: 第四范式帶來(lái)的質(zhì)變: 第五范式: 科學(xué)范式的演變:二、科學(xué)發(fā)現(xiàn)的過(guò)程和方法
    發(fā)表于 09-17 11:45

    深入剖析電阻的用法和作用

    信號(hào)線上,為什么要接電阻?你定想不到小小電阻,竟然有這么大的作用。本期貿(mào)澤科普實(shí)驗(yàn)室,就讓我們一起來(lái)重新認(rèn)識(shí)——電阻。
    的頭像 發(fā)表于 08-21 09:10 ?4.5w次閱讀
    深入剖析電阻的用法和作用

    用樹(shù)莓派做個(gè)指紋識(shí)別方案,難不難?

    讓我們在樹(shù)莓派單板計(jì)算機(jī)上解鎖生物識(shí)別控制功能吧!生物識(shí)別技術(shù)利用每個(gè)人獨(dú)有的、不易復(fù)制的生理或行為特征進(jìn)行身份驗(yàn)證。地球上每個(gè)人的指紋都是獨(dú)無(wú)二的,讓我們一起來(lái)
    的頭像 發(fā)表于 08-09 13:14 ?1032次閱讀
    用樹(shù)莓派做<b class='flag-5'>一</b>個(gè)指紋識(shí)別方案,難不難?

    尋開(kāi)發(fā)伙伴 一起搞細(xì)胞電阻儀,有興趣的朋友來(lái)聊聊!

    尋開(kāi)發(fā)伙伴 一起搞細(xì)胞電阻儀,有興趣的朋友來(lái)聊聊!
    發(fā)表于 07-10 15:51

    擁抱開(kāi)源!一起來(lái)做FPGA開(kāi)發(fā)板啦!

    ,發(fā)起“擁抱開(kāi)源——一起來(lái)做FPGA開(kāi)發(fā)板” 項(xiàng)目!無(wú)論你是FPGA領(lǐng)域的資深開(kāi)發(fā)者,渴望探索國(guó)產(chǎn)芯片的無(wú)限可能;還是初入茅廬的技術(shù)小白,想要在實(shí)踐中學(xué)習(xí)成長(zhǎng);亦或是對(duì)硬件開(kāi)發(fā)充滿熱情的愛(ài)好者,希望親手
    發(fā)表于 06-06 14:05

    【「# 運(yùn)算放大器參數(shù)解析與LTspice應(yīng)用仿真」閱讀體驗(yàn)】+全書(shū)概覽與第章閱讀分享

    。 都提供了公式和原理圖以及仿真圖。都是基礎(chǔ)且重點(diǎn)的知識(shí),也都是教材中的基本內(nèi)容, 這里放在一起,第章相當(dāng)與作為復(fù)習(xí)了。對(duì)于非專業(yè)人士的話也相當(dāng)于摘出重點(diǎn)知識(shí)點(diǎn),可以作為基礎(chǔ)
    發(fā)表于 05-22 23:18

    電機(jī)選型計(jì)算公式與知識(shí)點(diǎn)匯總

    純分享帖,需要者可點(diǎn)擊附件獲取完整資料~~~*附件:電機(jī)選型計(jì)算公式與知識(shí)點(diǎn)匯總.pdf 【免責(zé)聲明】?jī)?nèi)容轉(zhuǎn)自今日電機(jī),因轉(zhuǎn)載眾多,無(wú)法確認(rèn)真正原始作者,故僅標(biāo)明轉(zhuǎn)載來(lái)源。版權(quán)歸原出處所有,純分享帖,侵權(quán)請(qǐng)聯(lián)系刪除內(nèi)容以保證您的權(quán)益。
    發(fā)表于 04-29 16:10
    巴彦县| 广丰县| 砚山县| 吴堡县| 贺兰县| 错那县| 龙州县| 大冶市| 华安县| 平乡县| 定结县| 普宁市| 万年县| 翼城县| 措勤县| 无棣县| 北宁市| 丘北县| 颍上县| 板桥市| 竹山县| 文安县| 灵川县| 寿阳县| 罗江县| 和林格尔县| 和顺县| 湘潭县| 呼图壁县| 连平县| 和平区| 恩平市| 桃园市| 新乡市| 墨竹工卡县| 年辖:市辖区| 修水县| 喀什市| 新民市| 确山县| 南部县|