cpu操作函數(shù)
cpu_ops函數(shù)由bringup_cpu調(diào)用,以觸發(fā)secondary cpu啟動(dòng)。它是根據(jù)設(shè)備樹中解析出的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獲取其對應(yīng)的cpu_ops回調(diào)
其中spin-table啟動(dòng)方式的回調(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啟動(dòng)
以上流程都準(zhǔn)備完成后,觸發(fā)secondary cpu啟動(dòng)就非常簡單了。只需調(diào)用其cpu_ops回調(diào)函數(shù),向其對應(yīng)的spin_table_cpu_release_addr位置寫入secondary cpu入口地址即可。以下為其調(diào)用流程:
其中smp_spin_table_cpu_boot的實(shí)現(xiàn)如下:
static int smp_spin_table_cpu_boot(unsigned int cpu)
{
write_pen_release(cpu_logical_map(cpu)); (1)
sev(); (2)
return 0;
}
(1)向給定地址寫入內(nèi)核entry
(2)通過sev指令喚醒secondary cpu啟動(dòng)
此后,該線程將等待cpu啟動(dòng)完成,并在完成后將其設(shè)置為online狀態(tài)
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報(bào)投訴
相關(guān)推薦
對應(yīng)CPU的SMP功能:2.1 核啟動(dòng)加載目前的啟動(dòng)順序是,系統(tǒng)默認(rèn)開始啟動(dòng)0核,在0核的主任務(wù)入口內(nèi)啟
發(fā)表于 05-15 12:45
CONFIG_HOTPLUG_CPU.cpu_die = vexpress_cpu_die,#endif};2.2.多核啟動(dòng)多核的
發(fā)表于 05-25 10:43
處理器的啟動(dòng),僅此而已,所以,現(xiàn)在社區(qū)幾乎很少使用spin-table這種方式,取而代之的是psci,他不僅可以啟動(dòng)從處理器,還可以關(guān)閉,掛起等其他核操作,現(xiàn)在基本上arm64平臺上使用多核
發(fā)表于 06-06 17:11
1、ARM64的多核啟動(dòng)流程分析工作中遇到的多核 ARM CPU 越來越多,總結(jié)分享一些多核啟動(dòng)
發(fā)表于 06-13 18:23
本帖主要描述raspi 3b上SMP實(shí)現(xiàn),該實(shí)現(xiàn)主要基于現(xiàn)有raspi2 bsp代碼基礎(chǔ)上添加相關(guān)SMP支持,所需支持的功能主要包括:多核啟動(dòng)多核
發(fā)表于 12-05 13:56
,所有CPU共享系統(tǒng)內(nèi)存和外設(shè)資源。嵌入式領(lǐng)域除 SMP 外還有一種支持多核處理器芯片的操作系統(tǒng)體系結(jié)構(gòu),即 AMP。AMP(Asymmetric Multi-processing)
發(fā)表于 02-03 14:33
支持 SMP,在對稱多核上可以通過使能 RT_USING_SMP 來開啟。系統(tǒng)上電后,各 CPU 的啟動(dòng)流程如下圖所示:每個(gè)次級
發(fā)表于 02-13 15:02
基于自主開發(fā)以雙核嵌入式CPU EM8301為處理核心的嵌入式應(yīng)用的目的,針對雙核CPU芯片的系統(tǒng)結(jié)構(gòu)和Linux內(nèi)核的特性,通過研究嵌入式Linux操作系統(tǒng)在SMP系統(tǒng)上的移植,探討
發(fā)表于 11-14 16:09
?11次下載
一般嵌入式系統(tǒng)使用的都是對稱多處理器(Symmetric Multi-Processor, SMP)系統(tǒng),包含了多個(gè)cpu, 這幾個(gè)cpu都是相同的處理器,如4核Contex-A53。
發(fā)表于 06-09 14:28
?1060次閱讀
上面說了pin-table的多核啟動(dòng)方式,看似很繁瑣,實(shí)際上并不復(fù)雜,無外乎主處理器喚醒從處理器到指定地址上去執(zhí)行指令
發(fā)表于 06-09 14:31
?798次閱讀
工作中遇到的多核 ARM CPU 越來越多,總結(jié)分享一些多核啟動(dòng)的知識,希望能幫助更多小伙伴。 在 ARM64 架構(gòu)下如果想要啟動(dòng)
發(fā)表于 06-22 10:04
?2322次閱讀
SMP 英文為Symmetric Multi-Processing ,是對稱多處理結(jié)構(gòu)的簡稱,是指在一個(gè)計(jì)算機(jī)上匯集了一組處理器(多CPU),各CPU之間共享內(nèi)存子系統(tǒng)以及總線結(jié)構(gòu),一個(gè)服務(wù)器系統(tǒng)可以同時(shí)運(yùn)行多個(gè)處理器,并共享內(nèi)
發(fā)表于 07-26 09:26
?1.9w次閱讀
,一個(gè)服務(wù)器系統(tǒng)可以同時(shí)運(yùn)行多個(gè)處理器,并共享內(nèi)存和其他的主機(jī)資源。 CMP 英文為Chip multiprocessors,指的是單芯片多處理器,也指多核心。其思想是將大規(guī)模并行處理器中的SMP集成到同一芯片內(nèi),各個(gè)處理器并行執(zhí)行不同的進(jìn)程。 (1)
發(fā)表于 12-05 15:23
?1951次閱讀
secondary cpu啟動(dòng) 由于psci方式啟動(dòng)secondary cpu的流程,除了其所執(zhí)行的cpu_ops不同之外,其它流程與spi
發(fā)表于 12-05 17:41
?966次閱讀
//lib/psci/psci_setup.c - >plat_setup_psci_ops //設(shè)置平臺的psci操作 調(diào)用平臺的plat_setup_psci_ops函數(shù)去設(shè)置psci操作 eg
發(fā)表于 12-05 17:45
?764次閱讀
評論