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

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

3天內不再提示

SMP多核secondary cpu啟動流程

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

secondary cpu啟動

由于psci方式啟動secondary cpu的流程,除了其所執(zhí)行的cpu_ops不同之外,其它流程與spin-table方式是相同的,因此我們這里只給出執(zhí)行流程圖,詳細分析可以參考上篇博文。其中以下流程執(zhí)行secondary cpu啟動相關的一些初始化工作:

圖片

在初始化完成且hotplug線程創(chuàng)建完成后,就可通過以下流程喚醒cpu hotplug線程:

圖片

此后hotplug線程將調用psci回調函數,并最終觸發(fā)smc異常進入bl31:

圖片

bl31接收到該異常后執(zhí)行std_svc_smc_handler處理函數,并最終調用平臺相關的電源管理接口,完成cpu的上電工作,以下為其執(zhí)行流程:

圖片

平臺相關回調函數pwr_domain_on將為secondary cpu設置入口函數,然后為其上電使該cpu跳轉到內核入口secondary_entry處開始執(zhí)行。以下為其內核啟動流程:

圖片

到這里其實就結束了,不得不說這個前輩的文章是真的寫的邏輯清晰,收獲頗多。

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

    關注

    184

    文章

    17718

    瀏覽量

    250170
  • cpu
    cpu
    +關注

    關注

    68

    文章

    10863

    瀏覽量

    211763
  • 多核
    +關注

    關注

    0

    文章

    43

    瀏覽量

    12344
  • SMP
    SMP
    +關注

    關注

    0

    文章

    74

    瀏覽量

    19665
收藏 人收藏

    評論

    相關推薦

    記錄學習ARM Linux的多核啟動過程

    CONFIG_HOTPLUG_CPU.cpu_die = vexpress_cpu_die,#endif};2.2.多核啟動多核
    發(fā)表于 05-25 10:43

    介紹在ARM64架構下啟動多核的兩種方式

    1、ARM64的多核啟動流程分析工作中遇到的多核 ARM CPU 越來越多,總結分享一些多核
    發(fā)表于 06-13 18:23

    基于raspi 3b上的SMP設計實現

    本帖主要描述raspi 3b上SMP實現,該實現主要基于現有raspi2 bsp代碼基礎上添加相關SMP支持,所需支持的功能主要包括:多核啟動多核
    發(fā)表于 12-05 13:56

    RT-Thread SMP和AMP初體驗簡介

    多處理,AMP模式的RTOS在各個CPU上均運行一個操作系統(tǒng)實例(這些操作實例不一定完全相同),各個操作系統(tǒng)擁有自己專用的內存,相互之間通過訪問受限的共享內存進行通信。RT-Thread SMP 啟動
    發(fā)表于 02-03 14:33

    RT-Thread框架下的SMP支持

    支持 SMP,在對稱多核上可以通過使能 RT_USING_SMP 來開啟。系統(tǒng)上電后,各 CPU啟動
    發(fā)表于 02-13 15:02

    SOC的多核啟動流程詳解

    啟動的時候啟動多個core, COLD_BOOT_SINGLE_CPU=0, _secondary_cold_boot=1, 則下面代碼會被編譯,則主核走 do_primary_col
    發(fā)表于 02-21 15:11

    Linux在SMP系統(tǒng)上的移植研究

    硬件平臺下的啟動流程、任務調度策略、任務間同步與互斥、中斷處理等問題,結合自主研發(fā)嵌入式應用的實際需求,得到解決上述問題的方案,完成嵌入式Linux在SMP系統(tǒng)上的移植,并實現嵌入式Linux在自主
    發(fā)表于 11-14 16:09 ?11次下載
    Linux在<b class='flag-5'>SMP</b>系統(tǒng)上的移植研究

    ARM64 SMP多核啟動(上)—spin-table

    一般嵌入式系統(tǒng)使用的都是對稱多處理器(Symmetric Multi-Processor, SMP)系統(tǒng),包含了多個cpu, 這幾個cpu都是相同的處理器,如4核Contex-A53。
    發(fā)表于 06-09 14:28 ?996次閱讀
    ARM64 <b class='flag-5'>SMP</b><b class='flag-5'>多核</b><b class='flag-5'>啟動</b>(上)—spin-table

    多核CPU啟動方式

    多核 CPU啟動方式 嵌入式系統(tǒng)的啟動的基本流程是先運行 bootloader ,然后由 bootloader 引導
    的頭像 發(fā)表于 06-22 10:04 ?2200次閱讀

    SMP是什么?多核芯片(SMP)的啟動方法

    SMP 英文為Symmetric Multi-Processing ,是對稱多處理結構的簡稱,是指在一個計算機上匯集了一組處理器(多CPU),各CPU之間共享內存子系統(tǒng)以及總線結構,一個服務器系統(tǒng)可以同時運行多個處理器,并共享內
    的頭像 發(fā)表于 07-26 09:26 ?1.8w次閱讀
    <b class='flag-5'>SMP</b>是什么?<b class='flag-5'>多核</b>芯片(<b class='flag-5'>SMP</b>)的<b class='flag-5'>啟動</b>方法

    RT-Thread SMP啟動流程

    SMP(Symmetric Multi-processing) :對稱多處理,在一個計算機上匯集了一組處理器 (多 CPU), 各 CPU 之間共享內存子系統(tǒng)以及總線結構。
    的頭像 發(fā)表于 08-03 15:10 ?1167次閱讀
    RT-Thread <b class='flag-5'>SMP</b><b class='flag-5'>啟動</b><b class='flag-5'>流程</b>

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

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

    如何在內核中啟動secondary cpu

    cpu流程,與secondary cpu啟動流程是相同的,因此內核復用了
    的頭像 發(fā)表于 12-05 15:46 ?607次閱讀
    如何在內核中<b class='flag-5'>啟動</b><b class='flag-5'>secondary</b> <b class='flag-5'>cpu</b>

    SMP多核啟動cpu操作函數

    cpu操作函數 cpu_ops函數由bringup_cpu調用,以觸發(fā)secondary cpu啟動
    的頭像 發(fā)表于 12-05 16:04 ?781次閱讀
    <b class='flag-5'>SMP</b><b class='flag-5'>多核</b><b class='flag-5'>啟動</b><b class='flag-5'>cpu</b>操作函數

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

    : 由于其底層相關初始化流程與primary cpu類似,因此此處不再介紹。我們這里主要看一下它是如何通過secondary_start_kernel啟動idle線程的: asmlin
    的頭像 發(fā)表于 12-05 16:12 ?848次閱讀
    <b class='flag-5'>secondary</b> <b class='flag-5'>cpu</b>執(zhí)行<b class='flag-5'>流程</b>介紹