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

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

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

鴻蒙內(nèi)核源碼分析寄存器的本質(zhì)

鴻蒙系統(tǒng)HarmonyOS ? 來源:my.oschina ? 作者:鴻蒙內(nèi)核源碼分析 ? 2021-04-26 14:51 ? 次閱讀

寄存器的本質(zhì)

寄存器從大一的計算機組成原理就開始聽到它,感覺很神秘,如夢如霧多年.揭開本質(zhì)后才發(fā)現(xiàn),寄存器就是一個32位的存儲空間,一個int變量而已,但它的厲害之處在于極高頻率的使用,讓人不敢相信是怎么做到的,不管再復(fù)雜再牛牛的應(yīng)用程序,電商也好,游戲,直播也罷,到了它這里都變成了有限的十幾個寄存器在玩,簡直太神奇了. 本篇將清楚說明寄存器的數(shù)量和功能,至于它是如何把復(fù)雜的上層程序變成了這十幾個寄存器來玩?這是編譯器的事情,不在討論范圍之內(nèi).

在 32 位的 ARM 架構(gòu)中,核心寄存器(core register)的數(shù)量一般有 37 個或者更多,視處理器實現(xiàn)的功能多少而定。所謂核心寄存器就是指 ARM 處理器內(nèi)核執(zhí)行常規(guī)指令時使用的寄存器,不包括用于浮點計算和 SIMD 技術(shù)的特殊寄存器,也可以理解為是 ARM 的核心處理器單元(PE)中的寄存器,不包括外圍的協(xié)處理器中的寄存器。

ARM7的37個寄存器,具體看圖說明:

o4YBAGCGYhyAXl4JAAKFrt4KWDs986.png

這些寄存器不能同時顯示,處理器指令狀態(tài)和工作模式指定哪些寄存器可供使用,圖中一一對應(yīng).

其中31個通用32位寄存器,系統(tǒng)和用戶模式全程復(fù)用寄存器,而其余5中異常(或叫特權(quán))模式從R8_* ~ R14_* 的寄存器叫模式專屬寄存器.這種特征的寄存器有個專門的稱呼,叫 Banked register。Bank 本意是銀行和存款的意思,在這里的意思是"有備份的".

注意 r8 和 r8_fiq是兩個不同的寄存器,名字前綴是為了好記,管理方便,以示同級概念理解.如此湊成了31個寄存器.

其中r13寄存器用于SP寄存器,始終指向棧頂,因為每種工作模式都有獨立的運行棧,所以有獨立的寄存器去記住各自的棧頂.

同理r14寄存器用于LR寄存器,用于保存模式切換時的切換位置,也是獨立存在,說明模式間回跳時并不需要重新給r14_*賦值,只需在跳出去的時候保存即可.

系統(tǒng)和用戶模式共用r13(sp)和r14(lr)寄存器,所以在每個子函數(shù)的棧幀中都要保存上一個調(diào)用它函數(shù)的SP和LR值,自己執(zhí)行完成后要從棧幀中恢復(fù)這兩個寄存器的值,否則無法界定回去后從哪里開始,從哪里計算偏移位置.

r15(pc)寄存器是指向代碼段的,所有模式復(fù)用的原因是它是共用的,一份代碼,你運行與不運行,代碼段就在哪里,不增不減.

6個狀態(tài)寄存器,其中CPSR(1個)和SPSR_*(5個),它們主要用于自運行或發(fā)生模式切換后的各種狀態(tài)保存.

CPSR:程序狀態(tài)寄存器(current program status register) (當(dāng)前程序狀態(tài)寄存器),在任何處理器模式下被訪問。

SPSR:程序狀態(tài)保存寄存器(saved program status register),每一種處理器模式下都有一個狀態(tài)寄存器SPSR,SPSR用于保存CPSR的狀態(tài),以便異常返回后恢復(fù)異常發(fā)生時的工作狀態(tài)。當(dāng)特定 的異常中斷發(fā)生時,這個寄存器用于存放當(dāng)前程序狀態(tài)寄存器的內(nèi)容。在異常中斷退出時,可以用SPSR來恢復(fù)CPSR。

七種工作模式

關(guān)于工作模式在鴻蒙內(nèi)核源碼分析(總目錄)之工作模式篇中有詳細(xì),可自行前往查看.此處只簡單說明下. 下圖來源于ARM720T.pdf第43頁,在ARM體系中,CPU工作在以下七種模式中:

o4YBAGCGYjGAE94iAAGdWhwa4NM821.png

用戶模式(usr):該模式是用戶程序的工作模式,它運行在操作系統(tǒng)的用戶態(tài),它沒有權(quán)限去操作其它硬件資源,只能執(zhí)行處理自己的數(shù)據(jù),也不能切換到其它模式下,要想訪問硬件資源或切換到其它模式只能通過軟中斷或產(chǎn)生異常。

快速中斷模式(fiq):快速中斷模式是相對一般中斷模式而言的,用來處理高優(yōu)先級中斷的模式,處理對時間要求比較緊急的中斷請求,主要用于高速數(shù)據(jù)傳輸及通道處理中。

普通中斷模式(irq):一般中斷模式也叫普通中斷模式,用于處理一般的中斷請求,通常在硬件產(chǎn)生中斷信號之后自動進(jìn)入該模式,該模式可以自由訪問系統(tǒng)硬件資源。

管理模式(svc):操作系統(tǒng)保護(hù)模式,CPU上電復(fù)位和當(dāng)應(yīng)用程序執(zhí)行 SVC 指令調(diào)用系統(tǒng)服務(wù)時也會進(jìn)入此模式,操作系統(tǒng)內(nèi)核的普通代碼通常工作在這個模式下。

終止模式(abt):當(dāng)數(shù)據(jù)或指令預(yù)取終止時進(jìn)入該模式,中止模式用于支持虛擬內(nèi)存或存儲器保護(hù),當(dāng)用戶程序訪問非法地址,沒有權(quán)限讀取的內(nèi)存地址時,會進(jìn)入該模式,

系統(tǒng)模式(sys):供操作系統(tǒng)使用的高特權(quán)用戶模式,與用戶模式類似,但具有可以直接切換到其他模式等特權(quán),用戶模式與系統(tǒng)模式兩者使用相同的寄存器,都沒有SPSR(Saved Program Statement Register,已保存程序狀態(tài)寄存器),但系統(tǒng)模式比用戶模式有更高的權(quán)限,可以訪問所有系統(tǒng)資源。

未定義模式(und):未定義模式用于支持硬件協(xié)處理器的軟件仿真,CPU在指令的譯碼階段不能識別該指令操作時,會進(jìn)入未定義模式。

除用戶模式外,其余6種工作模式都屬于特權(quán)模式

特權(quán)模式中除了系統(tǒng)模式以外的其余5種模式稱為異常模式

大多數(shù)程序運行于用戶模式

進(jìn)入特權(quán)模式是為了處理中斷、異常、或者訪問被保護(hù)的系統(tǒng)資源

硬件權(quán)限級別:系統(tǒng)模式 > 異常模式 > 用戶模式

快中斷(fiq)與慢中斷(irq)區(qū)別:快中斷處理時禁止中斷

每種模式都有自己獨立的入口和獨立的運行??臻g.系列篇之CPU篇已介紹過只要提供了入口函數(shù)和運行空間,CPU就可以干活了.入口函數(shù)解決了指令來源問題,運行空間解決了指令的運行場地問題. 而且在多核情況下,每個CPU核的每種特權(quán)模式都有自己獨立的??臻g.注意是特權(quán)模式下的??臻g,用戶模式的??臻g是由用戶(應(yīng)用)程序提供的.

R0~R7 寄存器

這 8 個寄存器是最普通的,所有模式都可以訪問和使用. 尤其是R0是寄存器中的王牌,被稱為頭號寄存器,通用寄存器中它用的最高頻,隨便翻段匯編代碼都能看到它的影子.鴻蒙開機第一跳指令就是 r0 = 0

reset_vector: //鴻蒙開機代碼
    /* clear register TPIDRPRW */
    mov     r0, #0					@r0 = 0
    mcr     p15, 0, r0, c13, c0, 4 	@c0,c13 = 0, C13為進(jìn)程標(biāo)識符 含義見 ARM720T.PDF 第64頁
    /* do some early cpu setup: i/d cache disable, mmu disabled */ @禁用MMU, i/d緩存
    mrc     p15, 0, r0, c1, c0, 0  	@r0 = c1 ,c1寄存器詳細(xì)解釋見第64頁
    bic     r0, #(1<<12) 			@位清除指令,清除r0的第11位
    bic     r0, #(1<<2 | 1<<0)		@清除第0和2位 ,禁止 MMU和緩存 0位:MMU enable/disable 2位:Cache enable/disable
    mcr     p15, 0, r0, c1, c0, 0 	@c1=r0 

再看拿自旋鎖的匯編代碼,這些代碼都在系列篇中詳細(xì)講解過,可前往鴻蒙內(nèi)核源碼分析(總目錄)自行查看.

FUNCTION(ArchSpinLock)	@非要拿到鎖
	mov 	r1, #1		@r1=1
1:						@循環(huán)的作用,因SEV是廣播事件.不一定lock->rawLock的值已經(jīng)改變了
	ldrex	r2, [r0]	@r0 = &lock->rawLock, 即 r2 = lock->rawLock
	cmp 	r2, #0		@r2和0比較
	wfene				@不相等時,說明資源被占用,CPU核進(jìn)入睡眠狀態(tài)
	strexeq r2, r1, [r0]@此時CPU被重新喚醒,嘗試令lock->rawLock=1,成功寫入則r2=0
	cmpeq	r2, #0		@再來比較r2是否等于0,如果相等則獲取到了鎖
	bne 	1b			@如果不相等,繼續(xù)進(jìn)入循環(huán)
	dmb 				@用DMB指令來隔離,以保證緩沖中的數(shù)據(jù)已經(jīng)落實到RAM中
	bx		lr			@此時是一定拿到鎖了,跳回調(diào)用ArchSpinLock函數(shù)

R0被潛規(guī)則的干了兩件事,突出了它的重要性:

第一個參數(shù) 由R0保管,當(dāng)然第二個參數(shù)就給R1保管

函數(shù)的返回值統(tǒng)一交給R0保管, 例如 a -> b ,b執(zhí)行完會把返回值給r0,回到a后,a從r0取值,不管取到什么,它就認(rèn)為這是b的返回值,默認(rèn)都只認(rèn)r0保存了返回值,這就是規(guī)定.

具體看一個C函數(shù)和它的匯編,在系列篇也已經(jīng)講過,可自行翻看.

//++++++++++++ square(c -> 匯編)++++++++++++++++++++++++
int square(int a,int b){
    return a*b;
}
square(int, int):
        sub     sp, sp, #8     @sp減去8,意思為給square分配棧空間,只用2個??臻g完成計算
        str     r0, [sp, #4]   @第一個參數(shù)入棧
        str     r1, [sp]       @第二個參數(shù)入棧
        ldr     r1, [sp, #4]   @取出第一個參數(shù)給r1
        ldr     r2, [sp]       @取出第二個參數(shù)給r2
        mul     r0, r1, r2     @執(zhí)行a*b給R0,返回值的工作一直是交給R0的
        add     sp, sp, #8     @函數(shù)執(zhí)行完了,要釋放申請的??臻g
        bx      lr             @子程序返回,等同于mov pc,lr,即跳到調(diào)用處
//++++++++++++ fp(c -> 匯編)++++++++++++++++++++++++
int fp(int b)
{
    int a = 1;
    return square(a+b,a+b);
}
fp(int):
        push    {r11, lr}      @r11(fp)/lr入棧,保存調(diào)用者main的位置
        mov     r11, sp        @r11用于保存sp值,函數(shù)棧開始位置 
        sub     sp, sp, #8     @sp減去8,意思為給fp分配??臻g,只用2個棧空間完成計算
        str     r0, [sp, #4]   @先保存參數(shù)值,放在SP+4,此時r0中存放的是參數(shù)
        mov     r0, #1         @r0=1
        str     r0, [sp]       @再把1也保存在SP的位置
        ldr     r0, [sp]       @把SP的值給R0
        ldr     r1, [sp, #4]   @把SP+4的值給R1
        add     r1, r0, r1     @執(zhí)行r1=a+b
        mov     r0, r1         @r0=r1,用r0,r1傳參
        bl      square(int, int)@先mov lr, pc 再mov pc square(int, int)   
        mov     sp, r11        @函數(shù)執(zhí)行完了,要釋放申請的??臻g 
        pop     {r11, lr}      @彈出r11和lr,lr是專用標(biāo)簽,彈出就自動復(fù)制給lr寄存器
        bx      lr             @子程序返回,等同于mov pc,lr,即跳到調(diào)用處

這段代碼同樣適用于理解以下的各個寄存器.R0的作用相當(dāng)于 x86 的 EAX

R7 寄存器

為啥要單獨講R7寄存器,因為它偶爾作為特殊寄存器在使用.內(nèi)核對上層應(yīng)用提供了數(shù)百個系統(tǒng)調(diào)用功能,當(dāng)發(fā)生系統(tǒng)調(diào)用時,在CPU工作模式切換過程中,系統(tǒng)調(diào)用號是一直保存在R7寄存器中的,通過系統(tǒng)調(diào)用號就能查詢到對應(yīng)的注冊函數(shù).具體在 系統(tǒng)調(diào)用篇中有詳細(xì)的過程說明,這里只列出部分代碼

//4個參數(shù)的系統(tǒng)調(diào)用時底層處理
static inline long __syscall4(long n, long a, long b, long c, long d)
{
	register long a7 __asm__("a7") = n; //將系統(tǒng)調(diào)用號保存在R7寄存器
	register long a0 __asm__("a0") = a; //R0
	register long a1 __asm__("a1") = b; //R1
	register long a2 __asm__("a2") = c; //R2
	register long a3 __asm__("a3") = d; //R3
	__asm_syscall("r"(a7), "0"(a0), "r"(a1), "r"(a2), "r"(a3))
}
//切換到SVC模式后,由匯編代碼調(diào)用由C語言實現(xiàn)的系統(tǒng)調(diào)用統(tǒng)一入口
LITE_OS_SEC_TEXT UINT32 *OsArmA32SyscallHandle(UINT32 *regs)
{
    UINT32 ret;
    UINT8 nArgs;
    UINTPTR handle;
    UINT32 cmd = regs[REG_R7];// 從R7寄存器中取出系統(tǒng)調(diào)用號
    handle = g_syscallHandle[cmd];//查詢系統(tǒng)調(diào)用的注冊函數(shù) 
    //...
}

fp(R11) 寄存器

R11:可以用作通用寄存器,在開啟特定編譯選項時可以用作幀指針寄存器FP,用來實現(xiàn)?;厮莨δ?。 GNU編譯器(gcc)默認(rèn)將R11作為存儲變量的通用寄存器,因而默認(rèn)情況下無法使用FP的?;厮莨δ?。為支持調(diào)用棧解析功能,需要在編譯參數(shù)中添加-fno-omit-frame-pointer選項,提示編譯器將R11作為FP使用。

FP寄存器(Frame Point),幀指針寄存器,指向當(dāng)前函數(shù)的父函數(shù)的棧幀起始地址。利用該寄存器可以得到父函數(shù)的棧幀,從棧幀中獲取父函數(shù)的FP,就可以得到祖父函數(shù)的棧幀,以此類推,可以追溯程序調(diào)用棧,得到函數(shù)間的調(diào)用關(guān)系。

在鴻蒙內(nèi)核R11是當(dāng)FP寄存器使用.

SP(R13) 寄存器

SP:棧指針寄存器(stack pointer),它也是 banked register,而且所有模式都有一份,總共有 6 個(有虛擬化支持時再多一個),分別用于用戶、IRQ、FIQ、 未定義、中止和管理員模式。在 ARM 手冊,有時用 SP_usr、SP_svc 這樣的寫法來表示不同模式下的 SP 寄存器。

SP指向函數(shù)棧的棧頂,如此 fp 和 sp 就劃定了函數(shù)棧的范圍,函數(shù)在運行期間除了動態(tài)申請的內(nèi)存要跑出去玩,其余就在這塊空間里玩.

在鴻蒙內(nèi)核R13是當(dāng)SP寄存器使用.

LR(R14) 寄存器

又叫 Link Register,簡稱 LR,在主動調(diào)用子函數(shù)時,ARM 處理器會自動將子函數(shù)的返回地址放到這個寄存器中。 另外在異常發(fā)生的被動階段,會導(dǎo)致程序正常運行的被打斷, 并將控制流轉(zhuǎn)移到相應(yīng)的異常處理(異常響應(yīng)),有些異常(fiq、irq)事件處理后,系統(tǒng)還希望能回 到當(dāng)初異常發(fā)生時被打斷的源程序斷點處繼續(xù)完成源程序的執(zhí)行(異常返回),這就需要一種解決方案, 用于記錄源程序的斷點位置,以便正確的異常返回。 類似的還有子程序的調(diào)用和 返回。在主程序中(通過子程序調(diào)用指令)調(diào)用子程序時,也需要記錄下主程序中的調(diào)用點位置,以便將來的子程序的返回。

LR:鏈接寄存器(linked pointer),就是用來解決上述問題的,ARM處理器中使用 R14實現(xiàn)對斷點和調(diào)用點的記錄,即R14用作返回連接寄存器(LR),確保回來知道自己從哪個位置中斷,以便繼續(xù)執(zhí)行.

在鴻蒙內(nèi)核R14是當(dāng)LR寄存器使用.

PC(R15) 寄存器

簡稱 PC(Program Counter)。當(dāng)執(zhí)行 ARM 指令(每條指令 4 字節(jié)),它的值為當(dāng)前指令的地址加 8,當(dāng)執(zhí)行 Thumb 指令事,它的值為當(dāng)前指令的地址加 4,其設(shè)計原則是讓 PC 指向當(dāng)前指令后面的第二條指令。

PC寄存器涉及到arm的流水線結(jié)構(gòu)設(shè)計,具體在后續(xù)流水線篇中詳細(xì)說明,敬請關(guān)注.

在鴻蒙內(nèi)核R15是當(dāng)PC寄存器使用.

CPSR 寄存器

pIYBAGCGYk-AFdtZAAHj4sYPMJs267.png

CPSR(current program status register)當(dāng)前程序的狀態(tài)寄存器 CPSR有4個8位區(qū)域:標(biāo)志域(F)、狀態(tài)域(S)、擴展域(X)、控制域(C) 32 位的程序狀態(tài)寄存器可分為4 個域:

位[31:24]為條件標(biāo)志位域,用f 表示;

位[23:16]為狀態(tài)位域,用s 表示;

位[15:8]為擴展位域,用x 表示;

位[7:0]為控制位域,用c 表示;

CPSR和其他寄存器不一樣,其他寄存器是用來存放數(shù)據(jù)的,都是整個寄存器具有一個含義. 而CPSR寄存器是按位起作用的,也就是說,它的每一位都有專門的含義,記錄特定的信息.

CPSR的低8位(包括I、F、T和M[4:0])稱為控制位,程序無法修改, 除非CPU運行于特權(quán)模式下,程序才能修改控制位

N、Z、C、V均為條件碼標(biāo)志位。它們的內(nèi)容可被算術(shù)或邏輯運算的結(jié)果所改變, 并且可以決定某條指令是否被執(zhí)行!意義重大!

CPSR的第31位是 N,符號標(biāo)志位。它記錄相關(guān)指令執(zhí)行后,其結(jié)果是否為負(fù). 如果為負(fù) N = 1,如果是非負(fù)數(shù) N = 0.

CPSR的第30位是Z,0標(biāo)志位。它記錄相關(guān)指令執(zhí)行后,其結(jié)果是否為0. 如果結(jié)果為0.那么Z = 1.如果結(jié)果不為0,那么Z = 0.

CPSR的第29位是C,進(jìn)位標(biāo)志位(Carry)。一般情況下,進(jìn)行無符號數(shù)的運算。 加法運算:當(dāng)運算結(jié)果產(chǎn)生了進(jìn)位時(無符號數(shù)溢出),C=1,否則C=0。 減法運算(包括CMP):當(dāng)運算時產(chǎn)生了借位時(無符號數(shù)溢出),C=0,否則C=1。

CPSR的第28位是V,溢出標(biāo)志位(Overflow)。在進(jìn)行有符號數(shù)運算的時候, 如果超過了機器所能標(biāo)識的范圍,稱為溢出。

MSR{條件} 程序狀態(tài)寄存器(CPSR 或SPSR)_<域>,操作數(shù) MSR 指令用于將操作數(shù)的內(nèi)容傳送到程序狀態(tài)寄存器的特定域中 示例如下:

	MSR CPSR,R0   @傳送R0 的內(nèi)容到CPSR
	MSR SPSR,R0   @傳送R0 的內(nèi)容到SPSR
	MSR CPSR_c,R0 @傳送R0 的內(nèi)容到CPSR,但僅僅修改CPSR中的控制位域

MRS{條件} 通用寄存器,程序狀態(tài)寄存器(CPSR 或SPSR) MRS 指令用于將程序狀態(tài)寄存器的內(nèi)容傳送到通用寄存器中。該指令一般用在以下兩種情況: 1) 當(dāng)需要改變程序狀態(tài)寄存器的內(nèi)容時,可用MRS 將程序狀態(tài)寄存器的內(nèi)容讀入通用寄存器,修改后再寫回程序狀態(tài)寄存器。 2) 當(dāng)在異常處理或進(jìn)程切換時,需要保存程序狀態(tài)寄存器的值,可先用該指令讀出程序狀態(tài)寄存器的值,然后保存。 示例如下:

MRS R0,CPSR   @傳送CPSR 的內(nèi)容到R0
MRS R0,SPSR   @傳送SPSR 的內(nèi)容到R0
               @MRS指令是唯一可以直接讀取CPSR和SPSR寄存器的指令

SPSR 寄存器

SPSR(saved program status register)程序狀態(tài)保存寄存器.五種異常模式下一個狀態(tài)寄存器SPSR,用于保存CPSR的狀態(tài),以便異常返回后恢復(fù)異常發(fā)生時的工作狀態(tài)。

1、SPSR 為 CPSR 中斷時刻的副本,退出中斷后,將SPSR中數(shù)據(jù)恢復(fù)到CPSR中。

2、用戶模式和系統(tǒng)模式下SPSR不可用,所以SPSR寄存器只有5個

編輯:hfy

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

    關(guān)注

    6

    文章

    360

    瀏覽量

    41517
  • SIMD
    +關(guān)注

    關(guān)注

    0

    文章

    33

    瀏覽量

    10253
  • 狀態(tài)寄存器
    +關(guān)注

    關(guān)注

    0

    文章

    38

    瀏覽量

    7050
收藏 人收藏

    評論

    相關(guān)推薦

    鴻蒙內(nèi)核源碼分析:關(guān)于內(nèi)存涉及的C7,C2,C13三個寄存器

    ARM Register )指令訪問,包含16個32位的寄存器,其編號為0~15。本篇重點講解其中的 C7,C2,C13三個寄存器。 先拆解一段匯編代碼 上來看段匯編,讀懂內(nèi)核源碼
    的頭像 發(fā)表于 10-29 10:41 ?4004次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b><b class='flag-5'>分析</b>:關(guān)于內(nèi)存涉及的C7,C2,C13三個<b class='flag-5'>寄存器</b>

    鴻蒙內(nèi)核源碼分析:用通俗易懂的語言告訴你鴻蒙內(nèi)核發(fā)生了什么?

    查看。內(nèi)存在內(nèi)核的比重極大內(nèi)存模塊占了鴻蒙內(nèi)核約15%代碼量, 近50個文件,非常復(fù)雜。鴻蒙源碼分析
    發(fā)表于 11-19 10:14

    鴻蒙內(nèi)核源碼分析源碼注釋篇):給HarmonyOS源碼逐行加上中文注釋

    都懂的概念去詮釋或者映射一個他們從沒聽過的概念.說別人能聽得懂的話這很重要!!! 一個沒學(xué)過計算機知識的賣菜大媽就不可能知道內(nèi)核的基本運作了嗎? NO!,筆者在系列篇中試圖用 鴻蒙源碼分析
    發(fā)表于 11-19 10:32

    鴻蒙內(nèi)核源碼分析:給HarmonyOS源碼逐行加上中文注釋

    過計算機知識的賣菜大媽就不可能知道內(nèi)核的基本運作了嗎? NO!,筆者在系列篇中試圖用 鴻蒙源碼分析系列篇|張大爺系列故事【 CSDN | OSCHINA】 去構(gòu)建這一層級的認(rèn)知,希望能
    發(fā)表于 11-19 15:06

    鴻蒙源碼分析系列(總目錄) | 給HarmonyOS源碼逐行加上中文注釋

    同步更新。鴻蒙源碼分析系列篇|- 鴻蒙內(nèi)核源碼分析
    發(fā)表于 11-20 11:24

    鴻蒙內(nèi)核源碼分析(必讀篇):用故事說內(nèi)核

    本文基于開源鴻蒙內(nèi)核分析,官方源碼【kernel_liteos_a】官方文檔【docs】參考文檔【Huawei LiteOS】本文作者:鴻蒙
    發(fā)表于 11-23 10:15

    鴻蒙內(nèi)核源碼分析(百篇博客分析.挖透鴻蒙內(nèi)核)

    致敬內(nèi)核開發(fā)者感謝開放原子開源基金會,致敬鴻蒙內(nèi)核開發(fā)者??梢院敛豢鋸埖恼f鴻蒙內(nèi)核源碼可作為大學(xué)
    發(fā)表于 07-04 17:16

    寄存器,寄存器是什么意思

    寄存器,寄存器是什么意思 寄存器定義  寄存器是中央處理內(nèi)的組成部分。寄存器是有限存貯容量
    發(fā)表于 03-08 14:26 ?2.2w次閱讀

    數(shù)據(jù)寄存器,數(shù)據(jù)寄存器是什么意思

    數(shù)據(jù)寄存器,數(shù)據(jù)寄存器是什么意思 數(shù)據(jù)寄存器數(shù)據(jù)寄存器包括累加AX、基址寄存器BX、計數(shù)
    發(fā)表于 03-08 14:38 ?1.2w次閱讀

    鴻蒙內(nèi)核源碼分析: 虛擬內(nèi)存和物理內(nèi)存是怎么管理的

    有了上篇鴻蒙內(nèi)核源碼分析(內(nèi)存概念篇)的基礎(chǔ),本篇講內(nèi)存管理部分,本章源碼超級多,很燒腦,但筆者關(guān)鍵處都加了注釋。廢話不多說,開始吧。內(nèi)存一
    發(fā)表于 11-23 11:45 ?19次下載
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b><b class='flag-5'>分析</b>: 虛擬內(nèi)存和物理內(nèi)存是怎么管理的

    鴻蒙內(nèi)核源碼分析內(nèi)核最重要結(jié)構(gòu)體

    為何鴻蒙內(nèi)核源碼分析系列開篇就說 LOS_DL_LIST ? 因為它在鴻蒙 LOS 內(nèi)核中無處
    發(fā)表于 11-24 17:54 ?35次下載
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b><b class='flag-5'>分析</b> :<b class='flag-5'>內(nèi)核</b>最重要結(jié)構(gòu)體

    華為鴻蒙系統(tǒng)內(nèi)核源碼分析上冊

    鴻蒙內(nèi)核源碼注釋中文版【 Gitee倉】給 Harmoηy○S源碼逐行加上中文注解,詳細(xì)闡述設(shè)計細(xì)節(jié),助你快速精讀 Harmonyos內(nèi)核源碼
    發(fā)表于 04-09 14:40 ?17次下載

    U54內(nèi)核中斷控制和狀態(tài)寄存器

    向量的基地址,以及設(shè)置 U54內(nèi)核處理中斷的模式。對于 Direct 和 Vectored模式,中斷處理模式在 mtvec 寄存器的 MODE 字段中定義。mtvec 寄存器在表 86 中描述,mtvec.MODE 字段在表 8
    的頭像 發(fā)表于 10-08 09:54 ?610次閱讀
    U54<b class='flag-5'>內(nèi)核</b>中斷控制和狀態(tài)<b class='flag-5'>寄存器</b>

    干貨滿滿:ARM的內(nèi)核寄存器講解

    內(nèi)核寄存器與外設(shè)寄存器內(nèi)核寄存器與外設(shè)寄存器是完全不同的概念。
    發(fā)表于 04-17 11:47 ?1906次閱讀
    干貨滿滿:ARM的<b class='flag-5'>內(nèi)核</b><b class='flag-5'>寄存器</b>講解

    寄存器故障分析

    寄存器故障分析是計算機硬件維護(hù)與系統(tǒng)穩(wěn)定性保障中的重要環(huán)節(jié)。寄存器作為計算機中的關(guān)鍵組成部分,負(fù)責(zé)存儲和傳輸數(shù)據(jù),其穩(wěn)定性和可靠性直接影響到整個計算機系統(tǒng)的性能。以下是對寄存器故障的全
    的頭像 發(fā)表于 08-29 11:26 ?294次閱讀