色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

Linux匯編啟動relocate重定向分析

麥辣雞腿堡 ? 來源:嵌入式Linux充電站 ? 作者:Vincent ? 2023-10-08 11:32 ? 次閱讀

relocate

relocate重定向,就是在開啟mmu。開啟mmu的操作就是將一級頁表的地址以及權限寫到satp寄存器中,這就算開啟mmu了。

#ifdef CONFIG_MMU
    la a0, early_pg_dir //跳轉到relocate前,先把第一級頁表early_pg_dir的地址存入a0
    call relocate		//跳轉到relocate,開啟MMU
#endif

relocate有兩次開啟mmu的操作,第一次開啟mmu使用的是setup_vm()建立的trampoline_gd_dir頁表,這頁表保存的是kernel的前2M內存。第二次開啟MMU使用的是early_pg_dir頁表,這個頁表映射了整個kernel內存以及dtb的4M空間。

如果trampoline_pg_dir或者early_pg_dir這兩個頁表的映射沒弄好的話,開啟MMU的時候就會失敗,所以頁表的建立十分關鍵。頁表創建后續再深究,下面分析relocate匯編代碼。

  • 計算返回地址
    返回地址就是ra加上虛擬地址和物理地址之間的偏移量,這個是固定偏移量。PAGE_OFFSETkernel入口地址對應的虛擬地址,_start就是kernel入口地址的虛擬地址,PAGE_OFFSET - _start就得到它們之間的偏移,然后再和ra相加,就是返回地址。
/* Relocate return address */
	li a1, PAGE_OFFSET
	la a2, _start
	sub a1, a1, a2
	add ra, ra, a1
  • 將異常入口1f的虛擬地址寫入stvec寄存器
    因為一旦開啟MMU,地址都變成了虛擬地址,原來訪問的都是物理地址,開啟MMU時,地址發生了改變,VA != PA,從而進入異常,所以要先設置異常入口地址,此時的異常入口為1f
/* Point stvec to virtual address of intruction after satp write */
	la a2, 1f
	add a2, a2, a1
	csrw CSR_TVEC, a2
  • 提前計算切換到early_pg_dir頁表要寫入satp的值

再進入relocate之前,就已經把early_pg_dir賦值給a0了,所以a0是early_pg_dir。srl是邏輯右移,mmu使用的是sv39,虛擬地址39位,物理地址56位:

圖片低12位是偏移量,所以PAGE_SHIFT等于12,將early_pg_dir地址右移12位存到a2。根據satp寄存器定義:

圖片

MODE等于0x8代表使用sv39 mmu0x0代表不進行地址翻譯,即不開啟MMU。這里STAP_MODEsv39,即0x8。將early_pg_dir地址和SATP_MODE進行或運算后,即可得到寫入satp寄存器的值,最后保存到a2

/* Compute satp for kernel page tables, but don't load it yet */
	srl a2, a0, PAGE_SHIFT
	li a1, SATP_MODE	//sv39 mmu
	or a2, a2, a1
  • 第一次開啟MMU,使用trampoline_pg_dir頁表

satp值的計算和上述是一樣的。開啟MMU之前,通過sfence.vma命令先刷新TLB。此時開啟MMU,就會進入下面的標號為1的匯編段

la a0, trampoline_pg_dir
	srl a0, a0, PAGE_SHIFT
	or a0, a0, a1
	sfence.vma	
	csrw CSR_SATP, a0

進入異常1f段,重新設置異常入口為.Lsecondary_park,然后切換到early_pg_dir頁表,相當于第二次開啟MMU。此時,如果之前建立的early_pg_dir頁表不對,則會就進入.Lsecondary_park.Lsecondary_park里面是個wfi指令,是個死循環。

完整relocate匯編代碼:

relocate:
	/* Relocate return address */
	li a1, PAGE_OFFSET
	la a2, _start
	sub a1, a1, a2
	add ra, ra, a1

	/* Point stvec to virtual address of intruction after satp write */
	la a2, 1f
	add a2, a2, a1
	csrw CSR_TVEC, a2

	/* Compute satp for kernel page tables, but don't load it yet */
	srl a2, a0, PAGE_SHIFT
	li a1, SATP_MODE
	or a2, a2, a1

	/*
	 * Load trampoline page directory, which will cause us to trap to
	 * stvec if VA != PA, or simply fall through if VA == PA.  We need a
	 * full fence here because setup_vm() just wrote these PTEs and we need
	 * to ensure the new translations are in use.
	 */
	la a0, trampoline_pg_dir
	srl a0, a0, PAGE_SHIFT
	or a0, a0, a1
	sfence.vma
	csrw CSR_SATP, a0
.align 2
1:
	/* Set trap vector to spin forever to help debug */
	la a0, .Lsecondary_park
	csrw CSR_TVEC, a0

	/* Reload the global pointer */
.option push
.option norelax
	la gp, __global_pointer$
.option pop

	/*
	 * Switch to kernel page tables.  A full fence is necessary in order to
	 * avoid using the trampoline translations, which are only correct for
	 * the first superpage.  Fetching the fence is guarnteed to work
	 * because that first superpage is translated the same way.
	 */
	csrw CSR_SATP, a2
	sfence.vma

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

    關注

    87

    文章

    11292

    瀏覽量

    209331
  • 匯編
    +關注

    關注

    2

    文章

    214

    瀏覽量

    25927
  • MMU
    MMU
    +關注

    關注

    0

    文章

    91

    瀏覽量

    18283
  • 地址表
    +關注

    關注

    0

    文章

    4

    瀏覽量

    810
收藏 人收藏

    評論

    相關推薦

    Linux后臺程序重定向的問題

    目前有一種方法是在程序后臺啟動的時候,直接重定向到某個shell或telnet。方法如下:如tty命令查看目標shell為 /dev/pts/0./yourapp & > /dev
    發表于 08-22 13:54

    linux shell數據重定向(輸入重定向與輸出重定向)詳細分析

    在了解重定向之前,我們先來看看linux 的文件描述符。linux文件描述符:可以理解為linux跟蹤打開文件,而分配的一個數字,這個數字有點類似c語言操作文件時候的句柄,通過句柄就可
    發表于 03-02 13:59

    Linux Shell系列教程之(十六) Shell輸入輸出重定向

      一、Shell輸入輸出重定向概述  在了解重定向相關知識之前,我們先來看看Linux的文件描述符。  Linux的文件描述符可以理解為linux
    發表于 09-12 15:53

    如何對Linux Bash輸入輸出重定向

    Linux - Bash - 輸入輸出重定向
    發表于 04-27 09:01

    Linux輸入與輸出的重定向介紹

    Linux輸入與輸出的重定向
    發表于 06-12 14:54

    實現printf函數的重定向

    目錄重定向函數屬性設置重定向函數在配置好串口之后需要在相關文件中添加以下函數以實現printf函數的重定向//注意添加頭文件#include "stdio.h"#ifdef
    發表于 08-24 07:09

    MDK的重定向與printf的重定向有什么不一樣?

    MDK的重定向與printf的重定向有什么不一樣?
    發表于 12-01 06:05

    串口重定向是什么意思?

    串口重定向是什么意思?
    發表于 12-08 06:57

    將輸出到串口的日志信息重定向到當前的telnet

    概述在嵌入式Linux系統中,有時通過遠程(telnet或者ssh)登錄到現場設備,想看程序的實時打印的調試信息,需要將輸出到串口的調試信息重定向到當前登錄的終端界面上。也可以將程序重新啟動到當前
    發表于 12-16 07:13

    DNS 重定向的缺陷

    DNS 重定向的缺陷 這一種路由解決方案,由于充分利用了現有的網絡結構,結構簡單,因而被人們認為是一種有效的技術,是現階段CDN 應用中主
    發表于 03-25 10:25 ?2281次閱讀

    實現重定向printf()和scanf() 函數案例分析

    要想printf()和scanf() 函數工作,我們需要把printf()和scanf() 重新定向到串口中。重定向是指用戶可以自己重寫C 的庫函數,當連接器檢查到用戶編寫了與C 庫函數相同
    發表于 06-23 08:26 ?9196次閱讀
    實現<b class='flag-5'>重定向</b>printf()和scanf() 函數案例<b class='flag-5'>分析</b>

    單片機printf重定向的函數免費下載

    本文檔的主要內容詳細介紹的是單片機printf重定向的函數免費下載。
    發表于 07-03 17:42 ?0次下載
    單片機printf<b class='flag-5'>重定向</b>的函數免費下載

    ICMP重定向抓包分析 什么情況下路由器要向源發送ICMP重定向

    轉發。 ICMP重定向抓包分析 ICMP-Wiresharek抓包-PC端抓包 1.主機A發送ARPbroadcast報文,判斷目標地址非本端網絡,廣播尋找網關; 2.主機A收到ARP報文關于網關
    的頭像 發表于 08-24 15:43 ?5518次閱讀
    ICMP<b class='flag-5'>重定向</b>抓包<b class='flag-5'>分析</b> 什么情況下路由器要向源發送ICMP<b class='flag-5'>重定向</b>

    Keil下使用STlink重定向printf的配置

    Keil下使用STlink重定向printf的配置1. printf 重定向Keil默認下使用Micro LIB庫,該庫調用 fputs 實現 printf,所以需要重新定義fputs函數,以重定向
    發表于 12-27 18:43 ?18次下載
    Keil下使用STlink<b class='flag-5'>重定向</b>printf的配置

    Linux I/O重定向詳解

    Linux I/O重定向可以定義為,更改從命令讀取輸入到命令發送輸出的方式。你可以重定向命令的輸入和輸出。對于重定向符號,可以是 或者 | 。
    的頭像 發表于 05-04 14:34 ?831次閱讀
    主站蜘蛛池模板: 久久精品国产免费播放| 超碰最新网站| 野花韩国在线观看| 午夜A级理论片左线播放 | 99麻豆精品国产人妻无码| 亚洲在线视频自拍精品| 亚洲成人中文| 亚洲 日韩 国产 制服 在线| 天天干夜夜曰| 色爰情人网站| 翁止熄痒禁伦短文合集免费视频| 乳液全集电影在线观看| 日韩精品无码免费专区| 日本免费无码A专区在线观看| 免费麻豆国产黄网站在线观看| 男人大臿蕉香蕉大视频| 男人舔女人的阴部黄色骚虎视频| 乱码午夜-极品国产内射| 老板揉搓秘书丰满大乳| 毛片免费在线播放| 欧美激情视频一区| 欧美日韩精品久久久免费观看| 欧洲vs美洲完整视频| 日本久久精品毛片一区随边看| 让人爽到湿的小黄书| 涩涩999| 色偷偷男人| 亚洲XXX午休国产熟女屁| 亚洲一区二区女搞男| 一级片mp4| 99re.05久久热最新地址| u15女少天堂写真| 国产AV无码成人黄网站免费| 国产精品私人玩物在线观看 | 在线广播收听| 97人妻在线公开视频在线观看| FREEXXX性乌克兰XXX| 国产h视频在线观看免费| 国产手机精品一区二区| 久久久国产精品免费A片蜜芽广| 麻豆精选2021|