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

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

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

SMP多核啟動cpu操作函數(shù)

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

cpu操作函數(shù)

cpu_ops函數(shù)由bringup_cpu調(diào)用,以觸發(fā)secondary cpu啟動。它是根據(jù)設備樹中解析出的enable-method屬性確定的。

int __init init_cpu_ops(int cpu)
{
	const char *enable_method = cpu_read_enable_method(cpu);   (1)
			…
	cpu_ops[cpu] = cpu_get_ops(enable_method);                 (2)
		…
}

(1)獲取該cpu enable-method屬性的值

(2)根據(jù)其enable-method獲取其對應的cpu_ops回調(diào)

其中spin-table啟動方式的回調(diào)如下:

const struct cpu_operations smp_spin_table_ops = {
	.name		= "spin-table",
	.cpu_init	= smp_spin_table_cpu_init,
	.cpu_prepare	= smp_spin_table_cpu_prepare,
	.cpu_boot	= smp_spin_table_cpu_boot,
}

觸發(fā)secondary cpu啟動

以上流程都準備完成后,觸發(fā)secondary cpu啟動就非常簡單了。只需調(diào)用其cpu_ops回調(diào)函數(shù),向其對應的spin_table_cpu_release_addr位置寫入secondary cpu入口地址即可。以下為其調(diào)用流程:

圖片

其中smp_spin_table_cpu_boot的實現(xiàn)如下:

static int smp_spin_table_cpu_boot(unsigned int cpu)
{
	write_pen_release(cpu_logical_map(cpu));    (1sev();                                      (2return 0;
}

(1)向給定地址寫入內(nèi)核entry

(2)通過sev指令喚醒secondary cpu啟動

此后,該線程將等待cpu啟動完成,并在完成后將其設置為online狀態(tài)

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

    關注

    68

    文章

    10863

    瀏覽量

    211782
  • SMP
    SMP
    +關注

    關注

    0

    文章

    74

    瀏覽量

    19667
  • 函數(shù)
    +關注

    關注

    3

    文章

    4331

    瀏覽量

    62622
  • 設備樹
    +關注

    關注

    0

    文章

    38

    瀏覽量

    3126
收藏 人收藏

    評論

    相關推薦

    AliOS Things SMP系統(tǒng)及其在esp32上實現(xiàn)示例

    對應CPUSMP功能:2.1 核啟動加載目前的啟動順序是,系統(tǒng)默認開始啟動0核,在0核的主任務入口內(nèi)
    發(fā)表于 05-15 12:45

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

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

    ARM64 SMP多核啟動相關資料推薦(下)

    處理器的啟動,僅此而已,所以,現(xiàn)在社區(qū)幾乎很少使用spin-table這種方式,取而代之的是psci,他不僅可以啟動從處理器,還可以關閉,掛起等其他核操作,現(xiàn)在基本上arm64平臺上使用多核
    發(fā)表于 06-06 17:11

    介紹在ARM64架構(gòu)下啟動多核的兩種方式

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

    基于raspi 3b上的SMP設計實現(xiàn)

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

    RT-Thread SMP和AMP初體驗簡介

    ,所有CPU共享系統(tǒng)內(nèi)存和外設資源。嵌入式領域除 SMP 外還有一種支持多核處理器芯片的操作系統(tǒng)體系結(jié)構(gòu),即 AMP。AMP(Asymmetric Multi-processing)
    發(fā)表于 02-03 14:33

    RT-Thread框架下的SMP支持

    支持 SMP,在對稱多核上可以通過使能 RT_USING_SMP 來開啟。系統(tǒng)上電后,各 CPU啟動流程如下圖所示:每個次級
    發(fā)表于 02-13 15:02

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

    基于自主開發(fā)以雙核嵌入式CPU EM8301為處理核心的嵌入式應用的目的,針對雙核CPU芯片的系統(tǒng)結(jié)構(gòu)和Linux內(nèi)核的特性,通過研究嵌入式Linux操作系統(tǒng)在SMP系統(tǒng)上的移植,探討
    發(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 ?997次閱讀
    ARM64 <b class='flag-5'>SMP</b><b class='flag-5'>多核</b><b class='flag-5'>啟動</b>(上)—spin-table

    ARM64 SMP多核啟動(下)—PSCI

    上面說了pin-table的多核啟動方式,看似很繁瑣,實際上并不復雜,無外乎主處理器喚醒從處理器到指定地址上去執(zhí)行指令
    發(fā)表于 06-09 14:31 ?727次閱讀
    ARM64 <b class='flag-5'>SMP</b><b class='flag-5'>多核</b><b class='flag-5'>啟動</b>(下)—PSCI

    多核CPU啟動方式

    工作中遇到的多核 ARM CPU 越來越多,總結(jié)分享一些多核啟動的知識,希望能幫助更多小伙伴。 在 ARM64 架構(gòu)下如果想要啟動
    的頭像 發(fā)表于 06-22 10:04 ?2201次閱讀

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

    SMP 英文為Symmetric Multi-Processing ,是對稱多處理結(jié)構(gòu)的簡稱,是指在一個計算機上匯集了一組處理器(多CPU),各CPU之間共享內(nèi)存子系統(tǒng)以及總線結(jié)構(gòu),一個服務器系統(tǒng)可以同時運行多個處理器,并共享內(nèi)
    的頭像 發(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>方法

    SMP是什么 啟動方式介紹

    ,一個服務器系統(tǒng)可以同時運行多個處理器,并共享內(nèi)存和其他的主機資源。 CMP 英文為Chip multiprocessors,指的是單芯片多處理器,也指多核心。其思想是將大規(guī)模并行處理器中的SMP集成到同一芯片內(nèi),各個處理器并行執(zhí)行不同的進程。 (1)
    的頭像 發(fā)表于 12-05 15:23 ?1836次閱讀

    SMP多核secondary cpu啟動流程

    secondary cpu啟動 由于psci方式啟動secondary cpu的流程,除了其所執(zhí)行的cpu_ops不同之外,其它流程與spi
    的頭像 發(fā)表于 12-05 17:41 ?878次閱讀
    <b class='flag-5'>SMP</b><b class='flag-5'>多核</b>secondary <b class='flag-5'>cpu</b><b class='flag-5'>啟動</b>流程

    SMP多核啟動PSCI代碼示例

    //lib/psci/psci_setup.c - >plat_setup_psci_ops //設置平臺的psci操作 調(diào)用平臺的plat_setup_psci_ops函數(shù)去設置psci操作 eg
    的頭像 發(fā)表于 12-05 17:45 ?710次閱讀