国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

    文章

    269

    瀏覽量

    45316
  • AVC
    AVC
    +關注

    關注

    0

    文章

    23

    瀏覽量

    11338
  • 映射
    +關注

    關注

    0

    文章

    49

    瀏覽量

    16473

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    TVS二極管的實戰選型指南和布局技巧

    在前三期課程中,我們深入了解了TVS二極管的工作原理、類型區分和選型要點。今天,讓我們一起來掌握TVS二極管的實戰選型指南和布局技巧,為這個系列畫上完美的句號。
    的頭像 發表于 01-19 14:40 ?8745次閱讀
    TVS二極管的實戰選型指南和布局技巧

    MAX9937:具備反向電池保護功能的電流檢測放大器

    MAX9937:具備反向電池保護功能的電流檢測放大器 在電子設備的設計中,電流檢測是至關重要的環,它能夠幫助我們監測設備的運行狀態、確保系統的穩定性和安全性。今天,讓我們
    的頭像 發表于 01-14 10:35 ?201次閱讀

    探索 EVAL - 6ED2742S01Q 評估套件:助力電池供電應用設計

    電機控制設計方面提供哪些便利和優勢呢?讓我們一起來探究竟。 文件下載: Infineon Technologies
    的頭像 發表于 12-20 11:15 ?852次閱讀

    活動邀請 | 2025 Maker Farie Shenzhen,跟M5Stack一起來造!

    三天的創客盛宴,一起點亮無限創意!每年的十一月,都是屬于創客的高光時刻。今年M5Stack將在11月15日至17日連續三天,帶來滿滿的創客能量:我們將攜最新產品與創新項目亮相
    的頭像 發表于 11-07 18:25 ?572次閱讀
    活動邀請 | 2025 Maker Farie Shenzhen,跟M5Stack<b class='flag-5'>一起來</b>造!

    【「AI芯片:科技探索與AGI愿景」閱讀體驗】+AI的科學應用

    理論、實驗及仿真統一起來,催生了數據密集型科學,這就是第四范式。它利用大量的計算和數據處理研究復雜的問題和現象。特點如下: 第四范式帶來的質變: 第五范式: 科學范式的演變:二、科學發現的過程和方法
    發表于 09-17 11:45

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

    信號線上,為什么要接電阻?你定想不到小小電阻,竟然有這么大的作用。本期貿澤科普實驗室,就讓我們一起來重新認識——電阻。
    的頭像 發表于 08-21 09:10 ?4.1w次閱讀
    深入剖析電阻的用法和作用

    用樹莓派做個指紋識別方案,難不難?

    讓我們在樹莓派單板計算機上解鎖生物識別控制功能吧!生物識別技術利用每個人獨有的、不易復制的生理或行為特征進行身份驗證。地球上每個人的指紋都是獨無二的,讓我們一起來
    的頭像 發表于 08-09 13:14 ?901次閱讀
    用樹莓派做<b class='flag-5'>一</b>個指紋識別方案,難不難?

    尋開發伙伴 一起搞細胞電阻儀,有興趣的朋友聊聊!

    尋開發伙伴 一起搞細胞電阻儀,有興趣的朋友聊聊!
    發表于 07-10 15:51

    擁抱開源!一起來做FPGA開發板啦!

    ,發起“擁抱開源——一起來做FPGA開發板” 項目!無論你是FPGA領域的資深開發者,渴望探索國產芯片的無限可能;還是初入茅廬的技術小白,想要在實踐中學習成長;亦或是對硬件開發充滿熱情的愛好者,希望親手
    發表于 06-06 14:05

    【「# 運算放大器參數解析與LTspice應用仿真」閱讀體驗】+全書概覽與第章閱讀分享

    。 都提供了公式和原理圖以及仿真圖。都是基礎且重點的知識,也都是教材中的基本內容, 這里放在一起,第章相當與作為復習了。對于非專業人士的話也相當于摘出重點知識點,可以作為基礎
    發表于 05-22 23:18

    電機選型計算公式與知識點匯總

    純分享帖,需要者可點擊附件獲取完整資料~~~*附件:電機選型計算公式與知識點匯總.pdf 【免責聲明】內容轉自今日電機,因轉載眾多,無法確認真正原始作者,故僅標明轉載來源。版權歸原出處所有,純分享帖,侵權請聯系刪除內容以保證您的權益。
    發表于 04-29 16:10

    為什么正弦波如此普遍?一起來深入解析

    讓我們使用直角坐標繪制些任意的系統狀態:隨機選擇的塊體速度(v)和彈簧撓度(d)的組合: 我們已知 d 和 v 的數值,這些是我們
    發表于 04-14 14:02

    MediaTek在MWC 2025展示前沿技術

    MediaTek 在 MWC 2025 上展示了超多領域的前沿技術,讓我們一起來回顧下吧!
    的頭像 發表于 04-08 14:43 ?1054次閱讀

    探索信號分析的奇妙世界

    這個信息爆炸的時代無線通信已經成為我們生活中不可或缺的部分無論是手機、無線網絡還是衛星通信背后都有個共同的英雄——信號分析儀今天,就讓我們
    的頭像 發表于 04-07 09:49 ?709次閱讀
    <b class='flag-5'>探索</b>信號分析的奇妙世界

    電氣工程師必知必會的100個電?知識點分享

    電??程師也都是從電?學徒??步?步積累成長起來的。積跬步?千?,匯細流成江海!朋友們,現在讓我們??個捷徑,花半個?時的時間積累100個必知必會的電?知識點吧!
    的頭像 發表于 03-14 11:05 ?1851次閱讀