reset_primary函數的執行
以CONFIG_BOOT_SYNC_CPU使能為例, 在使能PSCI系統中,不需要使能此宏 。
reset_primary函數執行流程
reset_primary函數是OP-TEE對CPU主核進行初始化操作的函數,該函數會初始化系統的MMU,并調用generic_boot_init_primary函數完成OP-TEE運行環境的建立, 然后觸發sev操作來喚醒從核 , 待所有CPU核都啟動完成之后 ,OP-TEE會觸發安全監控模式調用(smc), 通知系統OP-TEE啟動已完成并將CPU的狀態切換回到正常世界狀態 ,該函數的執行流程如圖所示。
reset_primary函數的主要代碼內容如下:
LOCAL_FUNC reset_primary , :
UNWIND( .fnstart)
UNWIND( .cantunwind)
/* 清空BSS段 */
ldr r0, =__bss_start
ldr r1, =__bss_end
mov r2, #0
mov r3, #0
clear_bss:
stmia r0! , {r2, r3}
cmp r0, r1
bls clear_bss
/* 初始化內存shadow區域,并設定權限 */
#ifdef CFG_CORE_SANITIZE_KADDRESS
ldr r0, =__asan_shadow_start
ldr r1, =__asan_shadow_end
mov r2, #ASAN_DATA_RED_ZONE
shadow_no_access:
str r2, [r0], #4
cmp r0, r1
bls shadow_no_access
/* 標記整個棧區域準備完成 */
ldr r2, =CFG_ASAN_SHADOW_OFFSET
ldr r0, =__nozi_stack_start
lsr r0, r0, #ASAN_BLOCK_SHIFT
add r0, r0, r2
ldr r1, =__nozi_stack_end
lsr r1, r1, #ASAN_BLOCK_SHIFT
add r1, r1, r2
mov r2, #0
shadow_stack_access_ok:
strb r2, [r0], #1
cmp r0, r1
bls shadow_stack_access_ok
#endif
set_sp //設定sp寄存器
bl plat_cpu_reset_late //core的后期初始化,可根據具體情況執行特定操作
bl console_init //初始化log數據
inval_cache_vrange(__text_start, __end) //在初始化階段禁止數據cache
bl core_init_mmu_map //初始化MMU頁表
bl core_init_mmu_regs //將MMU頁表信息寫入MMU的TTBRx寄存器中
bl cpu_mmu_enable //使能MMU
bl cpu_mmu_enable_icache //使能MMU的指令cache
bl cpu_mmu_enable_dcache //使能MMU的數據cache
mov r0, r4 /* 頁表區域的地址 */
mov r1, r5 /* 非安全入口地址 */
mov r2, r6 /* 設備樹地址 */
//帶入paged_table、Linux內核的地址、設備樹信息進入OP-TEE系統運行環境的建立
bl generic_boot_init_primary
mov r4, r0
flush_cache_vrange(__text_start, __end) //刷新cache
cpu_is_ready //設定CPU主核已經ready
flush_cpu_semaphores //刷新信號量通知從核啟動
wait_secondary //等待從核啟動完成
bl thread_clr_boot_thread //清空系統各thread的狀態
#if defined(CFG_WITH_ARM_TRUSTED_FW)
mov r1, r4 //如果支持ATF,則將OP-TEE的handle返回給ATF
#else
mov r4, #0
mov r3, r6
mov r2, r7
mov r1, #0
#endif /* CFG_WITH_ARM_TRUSTED_FW */
mov r0, #TEESMC_OPTEED_RETURN_ENTRY_DONE //設定返回給Normal World的值
smc #0 //調用SMC操作切回到Normal World狀態,OP-TEE啟動結束
b . /* SMC should not return */
UNWIND( .fnend)
END_FUNC reset_primary
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
內存
+關注
關注
8文章
3020瀏覽量
74008 -
函數
+關注
關注
3文章
4327瀏覽量
62574 -
TEE
+關注
關注
0文章
29瀏覽量
10256 -
系統
+關注
關注
1文章
1015瀏覽量
21332
發布評論請先 登錄
相關推薦
單片機main函數在中斷函數里執行?
最近看了硬漢分享的一個內容:為什么復位中斷服務程序里面直接調用的main函數,難道所有程序都在復位中斷里面執行的?
發表于 10-24 11:04
?961次閱讀
STM32在復位上電后會立即執行main函數嗎
,在執行main函數前,STM32會依次經歷:硬件選擇啟動模式讀取啟動模式對應存儲器的中斷向量表初始化棧初始化PC指針,指向Reset Handler初始化系統時鐘執行C庫
發表于 01-21 11:13
SOC的多核啟動流程詳解
(bl31warmentrypoint或平臺自定義函數)處開始執行.總結 (針對本文示例情況:reset地址是可編程的、cold boot的時候只啟動一個cpu):開機一上電只有Primary
發表于 02-21 15:11
S32K3功能復位導致Reset_B引腳執行復位動作的原因?
會使PTA5:Reset_B也執行復位動作。我正在代碼中執行任務循環以執行函數重置。開發板上實驗問題描述如下圖: 我也關閉了功能重置升級功
發表于 03-17 07:47
RESET原理及故障分析
我們知道,對于計算機用戶來說,RESET在多數情況下都是一種正常的人為操作。最熟悉的就是在機箱前面板上有一個專門用于執行RESET操作的RESET按鍵,還有在某些高級操作系統如WIN9
發表于 09-21 08:50
?3次下載
mfc程序執行流程小結,MFC程序的執行順序
摘要:本文章主要以MFC程序的執行流程、執行順序等執行過程的剖析做出的結論,下面一起來看看原文的具體介紹。
發表于 12-08 15:48
?9543次閱讀
如何使用Arduino millis函數執行多任務處理
在本教程中,我們將學習Arduino 如何使用 Arduino millis 函數執行多任務處理。通常在 Arduino 中使用delay()函數來執行LED 閃爍等周期性任務,但此
AURIX? TC3xx芯片的firmware和用戶程序啟動流程
Startup Firmware根據Reset方式的不同,執行的流程也不一樣。例如,Cold Power Reset后Startup Firmware
Linux bind的核心執行函數
bind的核心執行函數 bind系統調用的核心函數調用流程如下: SYSCALL_DEFINE3( bind , int , fd, struct sockaddr __user
GIC驅動的執行流程是什么
驅動流程分析 GIC驅動的執行流程如下圖所示: 首先需要了解一下鏈接腳本 vmlinux.lds ,腳本中定義了一個 __irqchip_of_table 段,該段用于存放中斷控制器信息,用于最終來
secondary cpu執行流程介紹
secondary cpu執行流程 aarch64架構secondary cpu的內核入口函數為secondary_entry(arch/arm64/kernel/head.S),以下為其執行
評論