📜  最高储物柜协议(HLP)

📅  最后修改于: 2021-08-24 16:39:07             🧑  作者: Mango

最高储物柜协议(HLP)是一种重要的资源共享协议,它是对优先级继承协议的扩展,旨在克服优先级继承协议的局限性。在此关键资源共享协议中,为每个关键资源分配了最高优先级值。此值是可能要求保留此关键资源的所有那些任务的最高优先级。

HLP的基本概念:
最高储物柜协议的基本概念基于最高优先级值。当任务拥有关键资源时,其优先级将更改为关键资源的最高优先级。如果任务拥有多个关键资源,则将所有最高优先级值中的最大值分配为任务的优先级。

HLP的工作:

  • 在编译时间之前找到每个任务所需的资源。
  • 最初,将最高优先级值分配给每个关键资源。
  • 关键资源的最高优先级值被计算为可能请求保留该关键资源的所有那些任务的最高优先级。
  • 当任务拥有关键资源时,会将相应的最高优先级值分配为任务的优先级。
  • 为获得多个关键资源的任务分配了所有最高优先级值的最大值。
  • 此外,执行是根据分配的优先级完成的。

HLP的功能:

  • 当使用HLP进行资源共享时,一旦任务拥有所需的关键资源,便不再对其进行阻止。
  • 在任务可以拥有一个资源之前,该任务可能需要的所有资源都应该是空闲的。
  • 它可以防止任务陷入死锁或链阻塞状态。

HLP的优势:
以下是最高储物柜协议的优点:

  • 它对于通过几个任务共享关键资源很有用。
  • 它避免了任务之间无限的优先级倒置。
  • 它克服了优先级继承协议的局限性。
  • 当一个任务占用一个资源时,它可以防止死锁,该任务所需的所有其他资源都必须是空闲的。
  • 使用最高储物柜协议,任务无法进入链阻止。

HLP的缺点:
最高锁协议的主要缺点是与继承有关的优先级倒置

当使用上限规则为获取关键资源的低优先级任务的优先级值分配了最高优先级时,不需要继承资源的中优先级任务将无法执行并进行继承相关的优先级转换,则会发生与继承相关的优先级反转。