日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

optee中core_init_mmu_regs函数解读

發布時間:2025/3/21 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 optee中core_init_mmu_regs函数解读 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

★★★ 個人博客導讀首頁—點擊此處 ★★★

在optee中有下列一段代碼,未開啟MMU之前,先使用了virt_to_phys,然后才將頁表基地址寫入到TTBR0,然后才開啟MMU,是否感到很奇怪?

bl core_init_mmu_map bl core_init_mmu_regs bl cpu_mmu_enable bl cpu_mmu_enable_icache bl cpu_mmu_enable_dcache void core_init_mmu_regs(void) {uint64_t mair;uint64_t tcr;paddr_t ttbr0;uint64_t ips = calc_physical_addr_size_bits(max_pa);ttbr0 = virt_to_phys(l1_xlation_table[0][get_core_pos()]); ------------------------ 虛擬地址轉物理地址mair = MAIR_ATTR_SET(ATTR_DEVICE, ATTR_DEVICE_INDEX);mair |= MAIR_ATTR_SET(ATTR_IWBWA_OWBWA_NTR, ATTR_IWBWA_OWBWA_NTR_INDEX);write_mair_el1(mair);tcr = TCR_RES1;tcr |= TCR_XRGNX_WBWA << TCR_IRGN0_SHIFT;tcr |= TCR_XRGNX_WBWA << TCR_ORGN0_SHIFT;tcr |= TCR_SHX_ISH << TCR_SH0_SHIFT;tcr |= ips << TCR_EL1_IPS_SHIFT;tcr |= 64 - __builtin_ctzl(CFG_LPAE_ADDR_SPACE_SIZE);/* Disable the use of TTBR1 */ ------------------------ 禁止TTBR1tcr |= TCR_EPD1;/** TCR.A1 = 0 => ASID is stored in TTBR0* TCR.AS = 0 => Same ASID size as in Aarch32/ARMv7*/write_tcr_el1(tcr);write_ttbr0_el1(ttbr0); ------------------------ 設置TTBR0的基地址write_ttbr1_el1(0); }

相關的理解
virt_to_phys將虛擬地址寫入到AT S1E1R寄存器,然后從PAR_EL1寄存器讀出物理地址
有于MMU沒開啟,output=input,也就是你讀出的物理地址其實就是等于虛擬地址的.

那么為什么還要加上virt_to_phys這一句呢,直接改為ttbr0 = l1_xlation_table[0][get_core_pos()]不更好嗎?
可能是因為在系統運行過程中,頁表基地址會更新,會重新設置頁表基地址。
在首次開機的時候,從l1_xlation_table數組讀出的物理地址等虛擬地址,但是等到MMU開啟之后,頁表更新了,再次調用core_init_mmu_regs想使用l1_xlation_table[0][get_core_pos()]做為基地址時,
它的虛擬地址已經不等于物理地址了,所以需要通過virt_to_phys轉一下

總結

以上是生活随笔為你收集整理的optee中core_init_mmu_regs函数解读的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。