active_mm = mm; ( 1 )cpu_uninstall_idmap(); ( 2 )…ops = get_cpu_ops(cpu); if (ops- >cpu_postboot)ops- >cpu_postboot(); ( 3 )…set_cpu_online(cpu, true ); ( 4 )" />
0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

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

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

secondary cpu執(zhí)行流程介紹

麥辣雞腿堡 ? 來源:TrustZone ? 作者:Hcoco ? 2023-12-05 16:12 ? 次閱讀

secondary cpu執(zhí)行流程

aarch64架構(gòu)secondary cpu的內(nèi)核入口函數(shù)為secondary_entry(arch/arm64/kernel/head.S),以下為其執(zhí)行主流程:

圖片
由于其底層相關(guān)初始化流程與primary cpu類似,因此此處不再介紹。我們這里主要看一下它是如何通過secondary_start_kernel啟動(dòng)idle線程的:

asmlinkage notrace void secondary_start_kernel(void)
{
	struct mm_struct *mm = &init_mm;              			
	…
	current- >active_mm = mm;                               (1)

	cpu_uninstall_idmap();                                 (2)
	…
	ops = get_cpu_ops(cpu);
	if (ops- >cpu_postboot)
		ops- >cpu_postboot();                           (3)
	…
	set_cpu_online(cpu, true);                             (4)
	complete(&cpu_running);                                (5)
	…
	cpu_startup_entry(CPUHP_AP_ONLINE_IDLE);               (6)
}

(1)由于內(nèi)核線程并沒有用于地址空間,因此其active_mm通常指向上一個(gè)用戶進(jìn)程的地址空間。而cpu初始化時(shí),由于之前并沒有運(yùn)行過用戶進(jìn)程,因此將其初始化為init_mm

(2)idmap地址映射僅僅是用于mmu使能時(shí)地址空間的平滑切換,在mmu使能完成后已經(jīng)沒有作用。更進(jìn)一步,由于idmap頁表所使用的ttbr0_elx頁表基地址寄存器,正常情況下是用于用戶空間頁表的,在調(diào)度器接管該cpu之前也必須要將其歸還給用戶空間

(3)執(zhí)行cpu_postboot回調(diào)

(4)由secondary cpu已經(jīng)啟動(dòng)成功,故將其設(shè)置為online狀態(tài)

(5)喚醒cpu hotplug線程

(6)讓cpu執(zhí)行idle線程,其代碼實(shí)現(xiàn)如下:

void cpu_startup_entry(enum cpuhp_state state)
{
	arch_cpu_idle_prepare();
	cpuhp_online_idle(state);
	while (1)
		do_idle();
}

至此,cpu已經(jīng)啟動(dòng)完成,并開始執(zhí)行idle線程了。最后當(dāng)然是要通知調(diào)度器,將該cpu的管理權(quán)限移交給調(diào)度器了。它是通過cpu hotplug的以下回調(diào)實(shí)現(xiàn)的:

static struct cpuhp_step cpuhp_hp_states[] = {
…
[CPUHP_AP_SCHED_STARTING] = {
		.name			= "sched:starting",
		.startup.single		= sched_cpu_starting,
		.teardown.single	= sched_cpu_dying,
}
…
}

以下為該函數(shù)的實(shí)現(xiàn):

int sched_cpu_starting(unsigned int cpu)
{
…
sched_rq_cpu_starting(cpu);        (1sched_tick_start(cpu);             (2)
…
}

(1)用于初始化負(fù)載均衡相關(guān)參數(shù),此后該cpu就可以在其后的負(fù)載均衡流程中拉取進(jìn)程

(2)tick時(shí)鐘是內(nèi)核調(diào)度器的脈搏,啟動(dòng)了該時(shí)鐘之后,cpu就會(huì)在時(shí)鐘中斷中執(zhí)行調(diào)度操作,從而讓cpu參與到系統(tǒng)的調(diào)度流程中

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

    關(guān)注

    68

    文章

    10804

    瀏覽量

    210831
  • SMP
    SMP
    +關(guān)注

    關(guān)注

    0

    文章

    71

    瀏覽量

    19614
  • 線程
    +關(guān)注

    關(guān)注

    0

    文章

    503

    瀏覽量

    19636
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    U-boot的執(zhí)行流程

    本文主要講述了U-boot的執(zhí)行流程。
    發(fā)表于 07-14 16:58 ?651次閱讀
    U-boot的<b class='flag-5'>執(zhí)行</b><b class='flag-5'>流程</b>

    求芯片內(nèi)部的程序執(zhí)行流程

    想了解仿真連接仿真后,芯片內(nèi)部的程序執(zhí)行流程,請(qǐng)問有相關(guān)介紹的資料嗎?
    發(fā)表于 05-25 12:08

    SOC的多核啟動(dòng)流程詳解

    , COLD_BOOT_SINGLE_CPU=1, _secondary_cold_boot=0,則下面代碼不被編譯, 則無論主核還是從核都不需要走 _secondary_cold_boot
    發(fā)表于 02-21 15:11

    什么是CPU分枝預(yù)測(cè)和推測(cè)執(zhí)行技術(shù)?

    什么是分枝預(yù)測(cè)和推測(cè)執(zhí)行技術(shù)?  分枝預(yù)測(cè)(branch prediction)和推測(cè)執(zhí)行(speculation execution)是CPU動(dòng)態(tài)執(zhí)行技術(shù)中的主要內(nèi)容,
    發(fā)表于 02-04 10:47 ?821次閱讀

    ATMEL的CPU介紹

    ATMEL的CPU介紹ATMEL的CPU介紹ATMEL的CPU介紹ATMEL的
    發(fā)表于 10-30 18:08 ?5次下載

    mfc程序執(zhí)行流程小結(jié),MFC程序的執(zhí)行順序

     摘要:本文章主要以MFC程序的執(zhí)行流程、執(zhí)行順序等執(zhí)行過程的剖析做出的結(jié)論,下面一起來看看原文的具體介紹
    發(fā)表于 12-08 15:48 ?9494次閱讀
    mfc程序<b class='flag-5'>執(zhí)行</b><b class='flag-5'>流程</b>小結(jié),MFC程序的<b class='flag-5'>執(zhí)行</b>順序

    關(guān)于如何判斷CPU是否正在執(zhí)行中斷函數(shù)?

    如何判斷CPU是否正在執(zhí)行中斷函數(shù)?
    的頭像 發(fā)表于 03-12 11:25 ?2546次閱讀

    如何寫出讓CPU執(zhí)行更快的代碼?

    轉(zhuǎn)自:小林coding 前言 代碼都是由 CPU 跑起來的,我們代碼寫的好與壞就決定了 CPU執(zhí)行效率,特別是在編寫計(jì)算密集型的程序,更要注重 CPU
    的頭像 發(fā)表于 10-29 11:21 ?2316次閱讀
    如何寫出讓<b class='flag-5'>CPU</b><b class='flag-5'>執(zhí)行</b>更快的代碼?

    reset_primary函數(shù)的執(zhí)行流程

    reset_primary函數(shù)的執(zhí)行 以CONFIG_BOOT_SYNC_CPU使能為例, 在使能PSCI系統(tǒng)中,不需要使能此宏 。 reset_primary函數(shù)執(zhí)行流程
    的頭像 發(fā)表于 11-02 18:06 ?501次閱讀
    reset_primary函數(shù)的<b class='flag-5'>執(zhí)行</b><b class='flag-5'>流程</b>

    for循環(huán)的執(zhí)行流程

    for循環(huán)是編程中常用的一種循環(huán)結(jié)構(gòu),它可以重復(fù)執(zhí)行一段代碼塊,直到達(dá)到指定的條件才結(jié)束循環(huán)。在這篇文章中,我將詳細(xì)介紹for循環(huán)的執(zhí)行流程,以幫助讀者深入理解該循環(huán)結(jié)構(gòu)的工作原理。
    的頭像 發(fā)表于 11-21 14:55 ?1646次閱讀

    bootm命令的執(zhí)行流程

    Bootm命令用來從memory啟動(dòng)內(nèi)核,bootm命令的執(zhí)行流程如下圖所示。 在串口終端輸入bootm命令后,執(zhí)行do_bootm函數(shù)來完成相應(yīng)的功能。Do_bootm函數(shù)首先
    的頭像 發(fā)表于 12-04 17:33 ?1083次閱讀
    bootm命令的<b class='flag-5'>執(zhí)行</b><b class='flag-5'>流程</b>

    cpu執(zhí)行程序內(nèi)部變化

    CPU(Central Processing Unit)是計(jì)算機(jī)的核心部件之一,它負(fù)責(zé)執(zhí)行計(jì)算機(jī)程序的指令,并進(jìn)行數(shù)據(jù)處理和控制操作。CPU執(zhí)行程序時(shí)會(huì)經(jīng)歷一系列復(fù)雜的內(nèi)部變化。本文
    的頭像 發(fā)表于 12-05 11:26 ?578次閱讀

    secondary cpu初始化狀態(tài)設(shè)置

    spin-table spin-table啟動(dòng)流程的示意圖如下: 芯片上電后primary cpu開始執(zhí)行啟動(dòng)流程,而secondary
    的頭像 發(fā)表于 12-05 15:27 ?965次閱讀
    <b class='flag-5'>secondary</b> <b class='flag-5'>cpu</b>初始化狀態(tài)設(shè)置

    如何在內(nèi)核中啟動(dòng)secondary cpu

    啟動(dòng)secondary cpu 內(nèi)核在啟動(dòng)secondary cpu之前當(dāng)然需要為其準(zhǔn)備好執(zhí)行環(huán)境,因?yàn)閮?nèi)核中
    的頭像 發(fā)表于 12-05 15:46 ?507次閱讀
    如何在內(nèi)核中啟動(dòng)<b class='flag-5'>secondary</b> <b class='flag-5'>cpu</b>

    SMP多核secondary cpu啟動(dòng)流程

    secondary cpu啟動(dòng) 由于psci方式啟動(dòng)secondary cpu流程,除了其所執(zhí)行
    的頭像 發(fā)表于 12-05 17:41 ?729次閱讀
    SMP多核<b class='flag-5'>secondary</b> <b class='flag-5'>cpu</b>啟動(dòng)<b class='flag-5'>流程</b>