互斥琐在ATF中的相关使用场景

本文介绍了在 ATF(Arm Trusted Firmware)中,Bakery Lock 的应用场景,主要用于解决多核环境中一致性内存的访问冲突问题。在运行时服务初始化、PSCI 实现和电源状态协调接口等方面,Bakery Lock 通过Lamport's Bakery算法保证互斥性。当一致性缓存被移除时,虽然会导致额外的缓存维护开销,但经过优化后仍能有效管理锁的性能。在特定场景下,平台可以考虑权衡是否使用一致性内存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

bakery lock

关于这个面包琐,在atf中的出现,我们先来看看。

场景一:运行时服务初始化

BL31负责初始化运行时服务。其中之一是PSCI。

作为PSCI初始化的一部分,BL31检测系统拓扑。它还初始化了实现用于跟踪功率域节点状态的状态机的数据结构。状态可以是“OFF”、“RUN”或“RETENTION”之一。

所有辅助CPU最初都处于“关闭”状态。主CPU所属的集群为“ON”;任何其他集群都是“OFF”。它还初始化保护它们的锁。

BL31在重置之后以及在热启动路径中启用数据高速缓存之前立即访问CPU或集群的状态。目前不可能使用基于“独占”的自旋锁,因此BL31使用基于Lamport’s Bakery算法的锁

运行时服务框架及其初始化在下面的“EL3运行时服务架构”部分中有更详细的描述。以下“电源状态协调接口”部分提供了PSCI实施状态的详细信息。

场景二:PSCI实现中的一致内存使用

“psci_non_cpu_pd_nodes”数据结构存储平台的功率域树信息,用于功率域的状态管理。默认情况下,该数据结构被分配在TF-A中的一致内存区域中,因为它可以由多个CPU访问,无论是启用还是禁用缓存。(因为在一致性内存中,所以需要琐,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TrustZone_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值