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

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

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

鴻蒙內(nèi)核源碼分析之線程環(huán)境下的任務(wù)切換

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

鴻蒙的內(nèi)核線程就是任務(wù),系列篇中說(shuō)的任務(wù)和線程當(dāng)一個(gè)東西去理解.

一般二種場(chǎng)景下需要切換任務(wù)上下文:

在線程環(huán)境下,從當(dāng)前線程切換到目標(biāo)線程,這種方式也稱為軟切換,能由軟件控制的自主式切換.哪些情況下會(huì)出現(xiàn)軟切換呢?

運(yùn)行的線程申請(qǐng)某種資源(比如各種鎖,讀/寫(xiě)消息隊(duì)列)失敗時(shí),需要主動(dòng)釋放CPU的控制權(quán),將自己掛入等待隊(duì)列,調(diào)度算法重新調(diào)度新任務(wù)運(yùn)行.

每隔10ms就執(zhí)行一次的OsTickHandler節(jié)拍處理函數(shù),檢測(cè)到任務(wù)的時(shí)間片用完了,就發(fā)起任務(wù)的重新調(diào)度,切換到新任務(wù)運(yùn)行.

不管是內(nèi)核態(tài)的任務(wù)還是用戶態(tài)的任務(wù),于切換而言是統(tǒng)一處理,一視同仁的,因?yàn)榍袚Q是需要換棧運(yùn)行,寄存器有限,需要頻繁的復(fù)用,這就需要將當(dāng)前寄存器值先保存到任務(wù)自己的棧中,以便別人用完了輪到自己再用時(shí)恢復(fù)寄存器當(dāng)時(shí)的值,確保老任務(wù)還能繼續(xù)跑下去. 而保存寄存器順序的結(jié)構(gòu)體叫:任務(wù)上下文(TaskContext).

在中斷環(huán)境下,從當(dāng)前線程切換到目標(biāo)線程,這種方式也稱為硬切換.不由軟件控制的被動(dòng)式切換.哪些情況下會(huì)出現(xiàn)硬切換呢?

由硬件產(chǎn)生的中斷,比如 鼠標(biāo),鍵盤外部設(shè)備每次點(diǎn)擊和敲打,屏幕的觸摸,USB的插拔等等這些都是硬中斷.同樣的需要切換棧運(yùn)行,需要復(fù)用寄存器,但與軟切換不一樣的是,硬切換會(huì)切換工作模式(中斷模式).所以會(huì)更復(fù)雜點(diǎn),但道理還是一樣要保存和恢復(fù)切換現(xiàn)場(chǎng)寄存器的值, 而保存寄存器順序的結(jié)構(gòu)體叫:任務(wù)中斷上下文(TaskIrqContext).

本篇說(shuō)清楚在線程環(huán)境下切換(軟切換)的實(shí)現(xiàn)過(guò)程.中斷切換(硬切換)實(shí)現(xiàn)過(guò)程將在鴻蒙內(nèi)核源碼分析(總目錄)中斷切換篇中詳細(xì)說(shuō)明.

本篇具體說(shuō)清楚以下幾個(gè)問(wèn)題:

任務(wù)上下文(TaskContext)怎么保存的?

代碼的實(shí)現(xiàn)細(xì)節(jié)是怎樣的?

如何保證切換不會(huì)發(fā)生錯(cuò)誤,指令不會(huì)丟失?

在鴻蒙內(nèi)核源碼分析(總目錄)系列篇中已經(jīng)說(shuō)清楚了調(diào)度機(jī)制,線程概念,寄存器,CPU,工作模式,這些是讀懂本篇的基礎(chǔ),建議先前往翻看,不然理解本篇會(huì)費(fèi)勁.本篇代碼量較多,涉及C和匯編代碼,代碼都添加了注釋,試圖把任務(wù)的整個(gè)切換過(guò)程逐行逐行說(shuō)清楚.

前置條件

一個(gè)任務(wù)要跑起來(lái),需要兩個(gè)必不可少的硬性條件:

1.從代碼段哪個(gè)位置取指令? 也就是入口地址,main函數(shù)是應(yīng)用程序的入口地址, run()是new一個(gè)線程執(zhí)行的入口地址.高級(jí)語(yǔ)言是這么叫,但到了匯編層的叫法就是PC寄存器.給PC寄存器喂妹值,指令就從哪里取.

2.運(yùn)行的場(chǎng)地(棧空間)在哪里? ARM有7種工作模式,到了進(jìn)程層面只需要考慮內(nèi)核模式和用戶模式兩種,對(duì)應(yīng)到任務(wù)會(huì)有內(nèi)核態(tài)??臻g和用戶態(tài)棧空間.內(nèi)核模式的任務(wù)只有內(nèi)核態(tài)的??臻g,用戶模式任務(wù)二者都有.??臻g是在初始化一個(gè)任務(wù)時(shí)就分配指定好的.以下是兩種??臻g的初始化過(guò)程.為了精練省去了部分代碼,留下了核心部分.

//任務(wù)控制塊中對(duì)兩個(gè)棧空間的描述
typedef struct {
    VOID            *stackPointer;      /**< Task stack pointer */  //內(nèi)核態(tài)棧指針,SP位置,切換任務(wù)時(shí)先保存上下文并指向TaskContext位置.
    UINT32          stackSize;          /**< Task stack size */     //內(nèi)核態(tài)棧大小
    UINTPTR         topOfStack;         /**< Task stack top */      //內(nèi)核態(tài)棧頂 bottom = top + size
    // ....
    UINTPTR         userArea;       //使用區(qū)域,由運(yùn)行時(shí)劃定,根據(jù)運(yùn)行態(tài)不同而不同
    UINTPTR         userMapBase;    //用戶態(tài)下的棧底位置
    UINT32          userMapSize;    /**< user thread stack size ,real size : userMapSize + USER_STACK_MIN_SIZE */
} LosTaskCB;    
//內(nèi)核態(tài)運(yùn)行棧初始化
LITE_OS_SEC_TEXT_INIT VOID *OsTaskStackInit(UINT32 taskID, UINT32 stackSize, VOID *topStack, BOOL initFlag)
{
    UINT32 index = 1;
    TaskContext *taskContext = NULL;
    taskContext = (TaskContext *)(((UINTPTR)topStack + stackSize) - sizeof(TaskContext));//上下文存放在棧的底部
    /* initialize the task context */ //初始化任務(wù)上下文
    taskContext->PC = (UINTPTR)OsTaskEntry;//程序計(jì)數(shù)器,CPU首次執(zhí)行task時(shí)跑的第一條指令位置
    taskContext->LR = (UINTPTR)OsTaskExit;  /* LR should be kept, to distinguish it's THUMB or ARM instruction */
    taskContext->resved = 0x0;
    taskContext->R[0] = taskID;             /* R0 */
    taskContext->R[index++] = 0x01010101;   /* R1, 0x01010101 : reg initialed magic word */ //0x55
    for (; index < GEN_REGS_NUM; index++) {//R2 - R12的初始化很有意思
        taskContext->R[index] = taskContext->R[index - 1] + taskContext->R[1]; /* R2 - R12 */
    }
    taskContext->regPSR = PSR_MODE_SVC_ARM;   /* CPSR (Enable IRQ and FIQ interrupts, ARM-mode) */
    return (VOID *)taskContext;
}
//用戶態(tài)運(yùn)行棧初始化
LITE_OS_SEC_TEXT_INIT VOID OsUserTaskStackInit(TaskContext *context, TSK_ENTRY_FUNC taskEntry, UINTPTR stack)
{
    context->regPSR = PSR_MODE_USR_ARM;//工作模式:用戶模式 + 工作狀態(tài):arm
    context->R[0] = stack;//棧指針給r0寄存器
    context->SP = TRUNCATE(stack, LOSCFG_STACK_POINT_ALIGN_SIZE);//給SP寄存器值使用
    context->LR = 0;//保存子程序返回地址 例如 a call b ,在b中保存 a地址
    context->PC = (UINTPTR)taskEntry;//入口函數(shù)
}

您一定注意到了TaskContext,說(shuō)的全是它,這就是任務(wù)上下文結(jié)構(gòu)體,理解它是理解任務(wù)切換的鑰匙.它不僅在C語(yǔ)言層面出現(xiàn),而且還在匯編層出現(xiàn),TaskContext是連接或者說(shuō)打通 C->匯編->C 實(shí)現(xiàn)任務(wù)切換的最關(guān)鍵概念.本篇全是圍繞著它來(lái)展開(kāi).先看看它張啥樣,LOOK!

TaskContext 任務(wù)上下文

typedef struct {
#if !defined(LOSCFG_ARCH_FPU_DISABLE)
    UINT64 D[FP_REGS_NUM]; /* D0-D31 */
    UINT32 regFPSCR;       /* FPSCR */
    UINT32 regFPEXC;       /* FPEXC */
#endif
    UINT32 resved;          /* It's stack 8 aligned */
    UINT32 regPSR;          
    UINT32 R[GEN_REGS_NUM]; /* R0-R12 */
    UINT32 SP;              /* R13 */
    UINT32 LR;              /* R14 */
    UINT32 PC;              /* R15 */
} TaskContext;

結(jié)構(gòu)很簡(jiǎn)單,目的更簡(jiǎn)單,就是用來(lái)保存寄存器現(xiàn)場(chǎng)的值的.鴻蒙內(nèi)核源碼分析(總目錄)系列寄存器篇中已經(jīng)說(shuō)過(guò)了,到了匯編層就是寄存器在玩,當(dāng)CPU工作在用戶和系統(tǒng)模式下時(shí)寄存器是復(fù)用的,玩的是17個(gè)寄存器和內(nèi)存地址,訪問(wèn)內(nèi)存地址也是通過(guò)寄存器來(lái)玩.

哪17個(gè)? R0~R15和CPSR. 當(dāng)調(diào)度(主動(dòng)式)或者中斷(被動(dòng)式)發(fā)生時(shí).將這17個(gè)寄存器壓入任務(wù)的內(nèi)核棧的過(guò)程叫保護(hù)案發(fā)現(xiàn)場(chǎng).從任務(wù)棧中彈出依次填入寄存器的過(guò)程叫恢復(fù)案發(fā)現(xiàn)場(chǎng).

從??臻g的具體哪個(gè)位置開(kāi)始恢復(fù)呢? 答案是:stackPointer,任務(wù)控制塊(LosTaskCB)的首個(gè)變量.對(duì)應(yīng)到匯編層的就是SP寄存器.

而TaskContext(任務(wù)上下文)就是一定的順序來(lái)保存和恢復(fù)這17個(gè)寄存器的.任務(wù)上下文在任務(wù)還沒(méi)有開(kāi)始執(zhí)行的時(shí)候就已經(jīng)保存在內(nèi)核棧中了,只不過(guò)是一些默認(rèn)的值,OsTaskStackInit干的就是這個(gè)默認(rèn)的事. 而OsUserTaskStackInit是對(duì)用戶棧的初始化,改變的是(CPSR)工作模式和SP寄存器.

新任務(wù)的運(yùn)行棧指針(stackPointer)給SP寄存器意味著切換了運(yùn)行棧,這是本篇最重要的一句話.

以下通過(guò)匯編代碼逐行分析如何保存和恢復(fù)TaskContext(任務(wù)上下文)

OsSchedResched 調(diào)度算法

//調(diào)度算法的實(shí)現(xiàn)
VOID OsSchedResched(VOID)
{
    // ...此處省去 ...
    /* do the task context switch */
    OsTaskSchedule(newTask, runTask);//切換任務(wù)上下文,注意OsTaskSchedule是一個(gè)匯編函數(shù) 見(jiàn)于 los_dispatch.s
}

在鴻蒙內(nèi)核源碼分析(總目錄)之調(diào)度機(jī)制篇中,留了一個(gè)問(wèn)題,OsTaskSchedule不是一個(gè)C函數(shù),而是個(gè)匯編函數(shù),就沒(méi)有往下分析了,本篇要完成整個(gè)分析過(guò)程.OsTaskSchedule實(shí)現(xiàn)了任務(wù)的上下文切換,匯編代碼見(jiàn)于los_dispatch.S中

OsTaskSchedule的參數(shù)指向的是新老兩個(gè)任務(wù),這兩個(gè)參數(shù)分別保存在R0,R1寄存器中.

OsTaskSchedule 匯編實(shí)現(xiàn)

讀這段匯編代碼一定要對(duì)照上面的TaskContext,不然很難看懂,容易懵圈,但對(duì)照著看就秒懂.

/*
 * R0: new task 
 * R1: run task
 */
OsTaskSchedule:	/*任務(wù)調(diào)度,OsTaskSchedule的目的是將寄存器值按TaskContext的格式保存起來(lái)*/
    MRS      R2, CPSR 	/*MRS 指令用于將特殊寄存器(如 CPSR 和 SPSR)中的數(shù)據(jù)傳遞給通用寄存器,要讀取特殊寄存器的數(shù)據(jù)只能使用 MRS 指令*/
    STMFD    SP!, {LR}	/*返回地址入棧,LR = PC-4 ,對(duì)應(yīng)TaskContext->PC(R15寄存器)*/
    STMFD    SP!, {LR}	/*再次入棧對(duì)應(yīng),對(duì)應(yīng)TaskContext->LR(R14寄存器)*/
    /* jump sp */
    SUB      SP, SP, #4 /* 跳的目的是為了,對(duì)應(yīng)TaskContext->SP(R13寄存器)*/
    /* push r0-r12*/
    STMFD    SP!, {R0-R12} 	 @對(duì)應(yīng)TaskContext->R[GEN_REGS_NUM](R0~R12寄存器)。
    STMFD    SP!, {R2}		/*R2 入棧 對(duì)應(yīng)TaskContext->regPSR*/
    /* 8 bytes stack align */
    SUB      SP, SP, #4		@棧對(duì)齊,對(duì)應(yīng)TaskContext->resved
    /* save fpu registers */
    PUSH_FPU_REGS   R2	/*保存fpu寄存器*/
    /* store sp on running task */
    STR     SP, [R1] @在運(yùn)行的任務(wù)棧中保存SP,即runTask->stackPointer = sp

OsTaskContextLoad: @加載上下文
    /* clear the flag of ldrex */ @LDREX 可從內(nèi)存加載數(shù)據(jù),如果物理地址有共享TLB屬性,則LDREX會(huì)將該物理地址標(biāo)記為由當(dāng)前處理器獨(dú)占訪問(wèn),并且會(huì)清除該處理器對(duì)其他任何物理地址的任何獨(dú)占訪問(wèn)標(biāo)記。
    CLREX @清除ldrex指令的標(biāo)記
    /* switch to new task's sp */
    LDR     SP, [R0] @ 即:sp =  task->stackPointer
    /* restore fpu registers */
    POP_FPU_REGS    R2 @恢復(fù)fpu寄存器,這里用了匯編宏R2是宏的參數(shù)
    /* 8 bytes stack align */
    ADD     SP, SP, #4 @棧對(duì)齊
    LDMFD   SP!, {R0}  @此時(shí)SP!位置保存的是CPSR的內(nèi)容,彈出到R0
    MOV     R4, R0	@R4=R0,將CPSR保存在r4, 將在OsKernelTaskLoad中保存到SPSR 
    AND     R0, R0, #CPSR_MASK_MODE @R0 =R0&CPSR_MASK_MODE ,目的是清除高16位
    CMP     R0, #CPSR_USER_MODE @R0 和 用戶模式比較
    BNE     OsKernelTaskLoad @非用戶模式則跳轉(zhuǎn)到OsKernelTaskLoad執(zhí)行,跳出
    /*此處省去 LOSCFG_KERNEL_SMP 部分*/
    MVN     R3, #CPSR_INT_DISABLE @按位取反 R3 = 0x3F
    AND     R4, R4, R3		@使能中斷
    MSR     SPSR_cxsf, R4	@修改spsr值
    /* restore r0-r12, lr */
    LDMFD   SP!, {R0-R12}	@恢復(fù)寄存器值
    LDMFD   SP, {R13, R14}^	@恢復(fù)SP和LR的值,注意此時(shí)SP值已經(jīng)變了,CPU換地方上班了.
    ADD     SP, SP, #(2 * 4)@sp = sp + 8
    LDMFD   SP!, {PC}^		@恢復(fù)PC寄存器值,如此一來(lái) SP和PC都有了新值,完成了上下文切換.完美!
OsKernelTaskLoad: 			@內(nèi)核任務(wù)的加載
    MSR     SPSR_cxsf, R4 	@將R4整個(gè)寫(xiě)入到程序狀態(tài)保存寄存器
    /* restore r0-r12, lr */
    LDMFD   SP!, {R0-R12} 	@出棧,依次保存到 R0-R12,其實(shí)就是恢復(fù)現(xiàn)場(chǎng)
    ADD     SP, SP, #4 		@sp=SP+4
    LDMFD   SP!, {LR, PC}^ 	@返回地址賦給pc指針,直接跳出.

解讀

匯編分成了三段OsTaskSchedule,OsTaskContextLoad,OsKernelTaskLoad.

第一段OsTaskSchedule其實(shí)就是在保存現(xiàn)場(chǎng).代碼都有注釋,對(duì)照著TaskContext來(lái)的,它就干了一件事把17個(gè)寄存器的值按TaskContext的格式入棧,因?yàn)轼櫭捎脳7绞讲捎玫氖菨M棧遞減的方式,所以存放順序是從最后一個(gè)往前依次入棧.

連著來(lái)兩句STMFD SP!, {LR}之前讓筆者懵圈了很久, 看了TaskContext才恍然大悟,因?yàn)槿?jí)流水線的原因,LR和PC寄存器之間是差了一條指令的,LR指向了處于譯碼階段指令,而PC指向了取指階段的指令,所以此處做了兩次LR入棧,其實(shí)是保存了未執(zhí)行的譯碼指令地址,確保執(zhí)行不會(huì)丟失一條指令.

R1是正在運(yùn)行的任務(wù)棧,OsTaskSchedule總的理解是在任務(wù)R1的運(yùn)行棧中插入一個(gè)TaskContext結(jié)構(gòu)塊.而STR SP, [R1],是改變了LosTaskCB->stackPointer的值,這個(gè)值只能在匯編層進(jìn)行精準(zhǔn)的改變,而在整個(gè)鴻蒙內(nèi)核C代碼層面都沒(méi)有看到對(duì)它有任何修改的地方.這個(gè)改變意義極為重要.因?yàn)樾碌娜蝿?wù)被調(diào)度后的第一件事情就是恢復(fù)現(xiàn)場(chǎng)!!!

在OsTaskSchedule執(zhí)行完成后,因?yàn)镻C寄存器并沒(méi)有發(fā)生跳轉(zhuǎn),所以緊接著往下執(zhí)行OsTaskContextLoad

OsTaskContextLoad的任務(wù)就是恢復(fù)現(xiàn)場(chǎng),誰(shuí)的現(xiàn)場(chǎng)?當(dāng)然是R0: new task的,所以第一條指令就是CLREX,清除干凈后立馬執(zhí)行LDR SP, [R0],所指向的就是LosTaskCB->stackPointer,這個(gè)位置存的是新任務(wù)的TaskContext結(jié)構(gòu)塊,是上一次R0任務(wù)被打斷時(shí)保存下來(lái)當(dāng)時(shí)這17個(gè)寄存器的值啊,依次出棧就是恢復(fù)這17個(gè)寄存器的值.

OsTaskContextLoad在開(kāi)始之前會(huì)判斷下工作模式,即判斷下是內(nèi)核棧還是用戶棧,兩種處理方式稍有不同.但都是在恢復(fù)現(xiàn)場(chǎng).

BNE OsKernelTaskLoad是查詢CPSR后判斷此時(shí)為內(nèi)核棧的現(xiàn)場(chǎng)恢復(fù)過(guò)程,代碼很簡(jiǎn)單就是恢復(fù)17個(gè)寄存器. 如此一來(lái),任務(wù)執(zhí)行的兩個(gè)條件,第一個(gè)SP的在LDR SP, [R0]時(shí)就有了.第二個(gè)條件:PC寄存器的值也在最后一條匯編LDMFD SP!, {LR, PC}^也已經(jīng)有了.改變了PC和LR有了新值,下一條指令位置一樣是上次任務(wù)被中斷時(shí)還沒(méi)被執(zhí)行的處于譯碼階段的指令地址.

如果是用戶態(tài)區(qū)別是需要恢復(fù)中斷.因?yàn)橛脩裟J降膬?yōu)先級(jí)是最低的,必須允許響應(yīng)中斷,也是依次恢復(fù)各寄存器的值,最后一句LDMFD SP!, {PC}^結(jié)束本次旅行,下一條指令位置一樣是上次任務(wù)被中斷時(shí)還沒(méi)被執(zhí)行的處于譯碼階段的指令地址.

如此,說(shuō)清楚了任務(wù)上下文切換的整個(gè)過(guò)程,初看可能不太容易理解,建議多看幾篇,用筆畫(huà)下棧的運(yùn)行過(guò)程,腦海中會(huì)很清晰的浮現(xiàn)出整個(gè)切換過(guò)程的運(yùn)行圖.

編輯:hfy

聲明:本文內(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)投訴
  • 線程
    +關(guān)注

    關(guān)注

    0

    文章

    505

    瀏覽量

    19720
  • 鴻蒙系統(tǒng)
    +關(guān)注

    關(guān)注

    183

    文章

    2638

    瀏覽量

    66566
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    鴻蒙內(nèi)核源碼Task/線程技術(shù)分析

    前言 在鴻蒙內(nèi)核中,廣義上可理解為一個(gè)Task就是一個(gè)線程 一、怎么理解Task 1. 官方文檔是怎么描述線程 基本概念 從系統(tǒng)的角度看,線程
    的頭像 發(fā)表于 10-18 10:42 ?2250次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b>Task/<b class='flag-5'>線程</b>技術(shù)<b class='flag-5'>分析</b>

    鴻蒙內(nèi)核源碼的中斷環(huán)境任務(wù)切換

    中斷環(huán)境任務(wù)切換鴻蒙內(nèi)核線程就是
    的頭像 發(fā)表于 04-30 16:41 ?2338次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b>的中斷<b class='flag-5'>環(huán)境</b><b class='flag-5'>下</b>的<b class='flag-5'>任務(wù)</b><b class='flag-5'>切換</b>

    【HarmonyOS】鴻蒙內(nèi)核源碼分析(調(diào)度機(jī)制篇)

    意義上所理解的線程呢。狹義上的后續(xù)有 鴻蒙內(nèi)核源碼分析(啟動(dòng)過(guò)程篇) 來(lái)說(shuō)明。不知道大家有沒(méi)有這種體會(huì),學(xué)一個(gè)東西的過(guò)程中要接觸很多新概念,
    發(fā)表于 10-14 14:00

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

    |-鴻蒙內(nèi)核源碼分析(調(diào)度機(jī)制篇) | 任務(wù)是如何被調(diào)度執(zhí)行的|-鴻蒙
    發(fā)表于 11-20 11:24

    鴻蒙內(nèi)核源碼分析(調(diào)度機(jī)制篇):Task是如何被調(diào)度執(zhí)行的

    (); 就是設(shè)置啟動(dòng)任務(wù),但此時(shí)啥都還沒(méi)開(kāi)始呢,Kprocess 進(jìn)程都沒(méi)創(chuàng)建,怎么會(huì)有大家一般意義上所理解的線程呢。狹義上的后續(xù)有 鴻蒙內(nèi)核源碼
    發(fā)表于 11-23 10:53

    鴻蒙內(nèi)核源碼分析(Task管理篇):task是內(nèi)核調(diào)度的單元

    遷移示意圖注意官方文檔說(shuō)的是線程,沒(méi)有提到task(任務(wù)),但內(nèi)核源碼中卻有大量 task代碼,很少有線程(thread)代碼 ,這是怎么回
    發(fā)表于 11-23 14:01

    鴻蒙內(nèi)核源碼分析(Task管理篇):task是內(nèi)核調(diào)度的單元

    還原回去就能保證task的連續(xù)執(zhí)行,讓用戶毫無(wú)感知。鴻蒙內(nèi)核給一個(gè)任務(wù)執(zhí)行的時(shí)間是 20ms ,也就是說(shuō)有多任務(wù)競(jìng)爭(zhēng)的情況,一秒鐘內(nèi)最多要
    發(fā)表于 11-24 10:24

    線程管理線程切換

    線程管理線程切換前言基本信息前言說(shuō)明PendSV_Handler函數(shù)前言基本信息名稱描述說(shuō)明RT-Thread Studio 軟件版本版本: 1.1.3RT-Thread 系統(tǒng)版本
    發(fā)表于 08-24 08:19

    鴻蒙內(nèi)核源碼線程環(huán)境任務(wù)切換

    在中斷環(huán)境,從當(dāng)前線程切換到目標(biāo)線程,這種方式也稱為硬切換.不由軟件控制的被動(dòng)式
    的頭像 發(fā)表于 04-25 16:48 ?1495次閱讀
    <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'>線程</b><b class='flag-5'>環(huán)境</b><b class='flag-5'>下</b>的<b class='flag-5'>任務(wù)</b><b class='flag-5'>切換</b>

    鴻蒙內(nèi)核源碼分析任務(wù)環(huán)境的事件控制塊

    一對(duì)多同步模型:一個(gè)任務(wù)等待多個(gè)事件的觸發(fā)。可以是任意一個(gè)事件發(fā)生時(shí)喚醒任務(wù)處理事件,也可以是幾個(gè)事件都發(fā)生后才喚醒任務(wù)處理事件。
    的頭像 發(fā)表于 04-26 14:29 ?1374次閱讀
    <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'>任務(wù)</b><b class='flag-5'>環(huán)境</b><b class='flag-5'>下</b>的事件控制塊

    鴻蒙內(nèi)核分析線程中斷環(huán)境任務(wù)切換

    ?OsSaveSignalContextIrqC函數(shù)為止. 中斷環(huán)境任務(wù)切換鴻蒙內(nèi)核
    的頭像 發(fā)表于 03-19 14:34 ?2628次閱讀
    <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'>環(huán)境</b><b class='flag-5'>下</b>的<b class='flag-5'>任務(wù)</b><b class='flag-5'>切換</b>

    鴻蒙內(nèi)核源碼分析:task是內(nèi)核調(diào)度的單元

    從系統(tǒng)的角度看,線程是競(jìng)爭(zhēng)系統(tǒng)資源的最小運(yùn)行單元。線程可以使用或等待CPU、使用內(nèi)存空間等系統(tǒng)資源,并獨(dú)立于其它線程運(yùn)行。 鴻蒙內(nèi)核每個(gè)進(jìn)
    發(fā)表于 11-23 15:51 ?22次下載
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b><b class='flag-5'>分析</b>:task是<b class='flag-5'>內(nèi)核</b>調(diào)度的單元

    鴻蒙內(nèi)核源碼分析:進(jìn)程和Task的就緒隊(duì)列對(duì)調(diào)度的作用

    鴻蒙內(nèi)核代碼中有兩個(gè)源文件是關(guān)于隊(duì)列的,一個(gè)是用于調(diào)度的隊(duì)列,另一個(gè)是用于線程間通訊的IPC隊(duì)列。 鴻蒙內(nèi)核進(jìn)程和
    發(fā)表于 11-23 15:48 ?31次下載
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>內(nèi)核</b><b class='flag-5'>源碼</b><b class='flag-5'>分析</b>:進(jìn)程和Task的就緒隊(duì)列對(duì)調(diào)度的作用

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

    為何鴻蒙內(nèi)核源碼分析系列開(kāi)篇就說(shuō) LOS_DL_LIST ? 因?yàn)樗?b class='flag-5'>鴻蒙 LOS 內(nèi)核中無(wú)處
    發(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)核源碼分析上冊(cè)

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