日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

optee的fast call的介绍

發布時間:2025/3/21 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 optee的fast call的介绍 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

快速鏈接:
.
👉👉👉 個人博客筆記導讀目錄(全部) 👈👈👈


說明: 在默認的情況下,本文講述的是armv8 aarch64體系,optee 3.12.0代碼

文章目錄

        • 1、optee的fast call調用的代碼導讀

1、optee的fast call調用的代碼導讀

如果調用的是fast call,在ATF的代碼中,將會把optee_vector_table->fast_smc_entry地址賦給ELR_EL3寄存器,el3_exit退出后,PC將會跳轉到該地址處,對應著optee_os中的線程向量表vector_fast_smc_entry地址

static uintptr_t opteed_smc_handler(uint32_t smc_fid,u_register_t x1,u_register_t x2,u_register_t x3,u_register_t x4,void *cookie,void *handle,u_register_t flags) { ...if (GET_SMC_TYPE(smc_fid) == SMC_TYPE_FAST) {cm_set_elr_el3(SECURE, (uint64_t)&optee_vector_table->fast_smc_entry);} else {cm_set_elr_el3(SECURE, (uint64_t)&optee_vector_table->yield_smc_entry);} ... }

optee_os中的線程向量表的定義

/** Vector table supplied to ARM Trusted Firmware (ARM-TF) at* initialization.** Note that ARM-TF depends on the layout of this vector table, any change* in layout has to be synced with ARM-TF.*/ FUNC thread_vector_table , : , .identity_mapb vector_std_smc_entryb vector_fast_smc_entryb vector_cpu_on_entryb vector_cpu_off_entryb vector_cpu_resume_entryb vector_cpu_suspend_entryb vector_fiq_entryb vector_system_off_entryb vector_system_reset_entry END_FUNC thread_vector_table DECLARE_KEEP_PAGER thread_vector_table

vector_fast_smc_entry的實現

LOCAL_FUNC vector_fast_smc_entry , : , .identity_mapreadjust_pcsub sp, sp, #THREAD_SMC_ARGS_SIZEstore_xregs sp, THREAD_SMC_ARGS_X0, 0, 7mov x0, spbl thread_handle_fast_smcload_xregs sp, THREAD_SMC_ARGS_X0, 1, 8add sp, sp, #THREAD_SMC_ARGS_SIZEldr x0, =TEESMC_OPTEED_RETURN_CALL_DONEsmc #0b . /* SMC should not return */ END_FUNC vector_fast_smc_entry

optee_os中fast call的實現

void thread_handle_fast_smc(struct thread_smc_args *args) {thread_check_canaries();#ifdef CFG_VIRTUALIZATIONif (!virt_set_guest(args->a7)) {args->a0 = OPTEE_SMC_RETURN_ENOTAVAIL;goto out;} #endiftee_entry_fast(args);#ifdef CFG_VIRTUALIZATIONvirt_unset_guest(); #endif/* Fast handlers must not unmask any exceptions */ out:__maybe_unused;assert(thread_get_exceptions() == THREAD_EXCP_ALL); } /* Note: this function is weak to let platforms add special handling */ void __weak tee_entry_fast(struct thread_smc_args *args) {__tee_entry_fast(args); } /** If tee_entry_fast() is overridden, it's still supposed to call this* function.*/ void __tee_entry_fast(struct thread_smc_args *args) {switch (args->a0) {/* Generic functions */case OPTEE_SMC_CALLS_COUNT:tee_entry_get_api_call_count(args);break;case OPTEE_SMC_CALLS_UID:tee_entry_get_api_uuid(args);break;case OPTEE_SMC_CALLS_REVISION:tee_entry_get_api_revision(args);break;case OPTEE_SMC_CALL_GET_OS_UUID:tee_entry_get_os_uuid(args);break;case OPTEE_SMC_CALL_GET_OS_REVISION:tee_entry_get_os_revision(args);break;/* OP-TEE specific SMC functions */ #ifdef CFG_CORE_RESERVED_SHMcase OPTEE_SMC_GET_SHM_CONFIG:tee_entry_get_shm_config(args);break; #endifcase OPTEE_SMC_L2CC_MUTEX:tee_entry_fastcall_l2cc_mutex(args);break;case OPTEE_SMC_EXCHANGE_CAPABILITIES:tee_entry_exchange_capabilities(args);break;case OPTEE_SMC_DISABLE_SHM_CACHE:tee_entry_disable_shm_cache(args);break;case OPTEE_SMC_ENABLE_SHM_CACHE:tee_entry_enable_shm_cache(args);break;case OPTEE_SMC_BOOT_SECONDARY:tee_entry_boot_secondary(args);break;case OPTEE_SMC_GET_THREAD_COUNT:tee_entry_get_thread_count(args);break;#if defined(CFG_VIRTUALIZATION)case OPTEE_SMC_VM_CREATED:tee_entry_vm_created(args);break;case OPTEE_SMC_VM_DESTROYED:tee_entry_vm_destroyed(args);break; #endifdefault:args->a0 = OPTEE_SMC_RETURN_UNKNOWN_FUNCTION;break;} }

總結

以上是生活随笔為你收集整理的optee的fast call的介绍的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。