女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

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

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

麥辣雞腿堡 ? 來(lái)源:TrustZone ? 作者:TrustZone ? 2023-11-02 18:06 ? 次閱讀

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

以CONFIG_BOOT_SYNC_CPU使能為例, 在使能PSCI系統(tǒng)中,不需要使能此宏

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

reset_primary函數(shù)是OP-TEE對(duì)CPU主核進(jìn)行初始化操作的函數(shù),該函數(shù)會(huì)初始化系統(tǒng)的MMU,并調(diào)用generic_boot_init_primary函數(shù)完成OP-TEE運(yùn)行環(huán)境的建立, 然后觸發(fā)sev操作來(lái)喚醒從核待所有CPU核都啟動(dòng)完成之后 ,OP-TEE會(huì)觸發(fā)安全監(jiān)控模式調(diào)用(smc), 通知系統(tǒng)OP-TEE啟動(dòng)已完成并將CPU的狀態(tài)切換回到正常世界狀態(tài) ,該函數(shù)的執(zhí)行流程如圖所示。

reset_primary函數(shù)的主要代碼內(nèi)容如下:

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
    /* 初始化內(nèi)存shadow區(qū)域,并設(shè)定權(quán)限 */
    #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
        /* 標(biāo)記整個(gè)棧區(qū)域準(zhǔn)備完成 */
        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                                       //設(shè)定sp寄存器
        bl  plat_cpu_reset_late //core的后期初始化,可根據(jù)具體情況執(zhí)行特定操作
        bl  console_init                            //初始化log數(shù)據(jù)
        inval_cache_vrange(__text_start, __end) //在初始化階段禁止數(shù)據(jù)cache
        bl  core_init_mmu_map                      //初始化MMU頁(yè)表
        bl  core_init_mmu_regs                     //將MMU頁(yè)表信息寫(xiě)入MMU的TTBRx寄存器中
        bl  cpu_mmu_enable                         //使能MMU
        bl  cpu_mmu_enable_icache                 //使能MMU的指令cache
        bl  cpu_mmu_enable_dcache                 //使能MMU的數(shù)據(jù)cache
        mov r0, r4                                   /* 頁(yè)表區(qū)域的地址 */
        mov r1, r5                                   /* 非安全入口地址 */
        mov r2, r6                                   /* 設(shè)備樹(shù)地址 */
        //帶入paged_table、Linux內(nèi)核的地址、設(shè)備樹(shù)信息進(jìn)入OP-TEE系統(tǒng)運(yùn)行環(huán)境的建立
        bl  generic_boot_init_primary
              mov r4, r0
              flush_cache_vrange(__text_start, __end) //刷新cache
              cpu_is_ready                                //設(shè)定CPU主核已經(jīng)ready
              flush_cpu_semaphores                       //刷新信號(hào)量通知從核啟動(dòng)
              wait_secondary                              //等待從核啟動(dòng)完成
              bl  thread_clr_boot_thread                //清空系統(tǒng)各thread的狀態(tài)
          #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     //設(shè)定返回給Normal World的值
              smc #0  //調(diào)用SMC操作切回到Normal World狀態(tài),OP-TEE啟動(dòng)結(jié)束
              b    .    /* SMC should not return */
          UNWIND( .fnend)
          END_FUNC reset_primary
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 內(nèi)存
    +關(guān)注

    關(guān)注

    8

    文章

    3108

    瀏覽量

    74988
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4371

    瀏覽量

    64202
  • TEE
    TEE
    +關(guān)注

    關(guān)注

    0

    文章

    29

    瀏覽量

    10444
  • 系統(tǒng)
    +關(guān)注

    關(guān)注

    1

    文章

    1029

    瀏覽量

    21709
收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    單片機(jī)main函數(shù)在中斷函數(shù)執(zhí)行

    最近看了硬漢分享的一個(gè)內(nèi)容:為什么復(fù)位中斷服務(wù)程序里面直接調(diào)用的main函數(shù),難道所有程序都在復(fù)位中斷里面執(zhí)行的?
    發(fā)表于 10-24 11:04 ?1259次閱讀

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

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

    STM32在復(fù)位上電后會(huì)立即執(zhí)行main函數(shù)

    ,在執(zhí)行main函數(shù)前,STM32會(huì)依次經(jīng)歷:硬件選擇啟動(dòng)模式讀取啟動(dòng)模式對(duì)應(yīng)存儲(chǔ)器的中斷向量表初始化棧初始化PC指針,指向Reset Handler初始化系統(tǒng)時(shí)鐘執(zhí)行C庫(kù)
    發(fā)表于 01-21 11:13

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

    (bl31warmentrypoint或平臺(tái)自定義函數(shù))處開(kāi)始執(zhí)行.總結(jié) (針對(duì)本文示例情況:reset地址是可編程的、cold boot的時(shí)候只啟動(dòng)一個(gè)cpu):開(kāi)機(jī)一上電只有Primary
    發(fā)表于 02-21 15:11

    S32K3功能復(fù)位導(dǎo)致Reset_B引腳執(zhí)行復(fù)位動(dòng)作的原因?

    會(huì)使PTA5:Reset_B也執(zhí)行復(fù)位動(dòng)作。我正在代碼中執(zhí)行任務(wù)循環(huán)以執(zhí)行函數(shù)重置。開(kāi)發(fā)板上實(shí)驗(yàn)問(wèn)題描述如下圖: 我也關(guān)閉了功能重置升級(jí)功
    發(fā)表于 03-17 07:47

    RESET原理及故障分析

    我們知道,對(duì)于計(jì)算機(jī)用戶(hù)來(lái)說(shuō),RESET在多數(shù)情況下都是一種正常的人為操作。最熟悉的就是在機(jī)箱前面板上有一個(gè)專(zhuān)門(mén)用于執(zhí)行RESET操作的RESET按鍵,還有在某些高級(jí)操作系統(tǒng)如WIN9
    發(fā)表于 09-21 08:50 ?3次下載
    <b class='flag-5'>RESET</b>原理及故障分析

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

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

    MySQL流程函數(shù)的操作方法

    流程函數(shù)是一類(lèi)很常用的函數(shù),我們可以通過(guò)流程函數(shù)在SQL語(yǔ)句中實(shí)現(xiàn)條件選擇,能實(shí)現(xiàn)我們想要的條件判斷。下表列出了MySQL中的
    的頭像 發(fā)表于 04-16 17:17 ?3149次閱讀
    MySQL<b class='flag-5'>流程</b><b class='flag-5'>函數(shù)</b>的操作方法

    如何使用Arduino millis函數(shù)執(zhí)行多任務(wù)處理

    在本教程中,我們將學(xué)習(xí)Arduino 如何使用 Arduino millis 函數(shù)執(zhí)行多任務(wù)處理。通常在 Arduino 中使用delay()函數(shù)來(lái)執(zhí)行LED 閃爍等周期性任務(wù),但此
    的頭像 發(fā)表于 09-06 14:41 ?1.5w次閱讀
    如何使用Arduino millis<b class='flag-5'>函數(shù)</b><b class='flag-5'>執(zhí)行</b>多任務(wù)處理

    AURIX? TC3xx芯片的firmware和用戶(hù)程序啟動(dòng)流程

    Startup Firmware根據(jù)Reset方式的不同,執(zhí)行流程也不一樣。例如,Cold Power Reset后Startup Firmware
    的頭像 發(fā)表于 05-31 15:23 ?3509次閱讀
    AURIX? TC3xx芯片的firmware和用戶(hù)程序啟動(dòng)<b class='flag-5'>流程</b>

    Linux bind的核心執(zhí)行函數(shù)

    bind的核心執(zhí)行函數(shù) bind系統(tǒng)調(diào)用的核心函數(shù)調(diào)用流程如下: SYSCALL_DEFINE3( bind , int , fd, struct sockaddr __user
    的頭像 發(fā)表于 07-31 10:51 ?784次閱讀

    GIC驅(qū)動(dòng)的執(zhí)行流程是什么

    驅(qū)動(dòng)流程分析 GIC驅(qū)動(dòng)的執(zhí)行流程如下圖所示: 首先需要了解一下鏈接腳本 vmlinux.lds ,腳本中定義了一個(gè) __irqchip_of_table 段,該段用于存放中斷控制器信息,用于最終來(lái)
    的頭像 發(fā)表于 09-28 15:09 ?729次閱讀
    GIC驅(qū)動(dòng)的<b class='flag-5'>執(zhí)行</b><b class='flag-5'>流程</b>是什么

    OP-TEE的內(nèi)核初始化函數(shù)調(diào)用

    OP-TEE內(nèi)核組件等操作。該函數(shù)執(zhí)行流程如圖所示。 generic_boot_init_primary函數(shù)
    的頭像 發(fā)表于 11-02 18:18 ?1051次閱讀
    OP-TEE的內(nèi)核初始化<b class='flag-5'>函數(shù)</b>調(diào)用

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

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

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

    secondary cpu執(zhí)行流程 aarch64架構(gòu)secondary cpu的內(nèi)核入口函數(shù)為secondary_entry(arch/arm64/kernel/head.S),以下為其執(zhí)行
    的頭像 發(fā)表于 12-05 16:12 ?1202次閱讀
    secondary cpu<b class='flag-5'>執(zhí)行</b><b class='flag-5'>流程</b>介紹