当前位置: 首页 > news >正文

多处理器一致协议(MSI)协议详细介绍

多处理器一致协议 MSI 协议详细介绍

在这里插入图片描述

读操作
写操作
命中-共享S
命中-已修改M
未命中
命中-共享S
命中-已修改M
未命中
其他缓存响应
其他缓存响应
内存或其他缓存响应
开始
缓存行请求
检查本地缓存
检查本地缓存
直接读取
直接读取
发起总线读BusRd
广播无效化Inv, 更新为M
直接写入
发起总线读BusRd
更新本地缓存为S或M
更新本地缓存为I
更新本地缓存为M
结束

什么是 MSI 协议?

MSI(Modified, Shared, Invalid)协议是一种缓存一致性协议,用于在多处理器系统中维护缓存数据的一致性。它通过定义缓存行(cache line)的三种状态来实现这一目标:Modified(已修改)、Shared(共享)和Invalid(无效)。

MSI 协议的状态

MSI协议中,缓存行可以处于以下三种状态之一:

  1. Modified (M) 状态:表示缓存行中的数据已被修改,并且是最新的,其他缓存中没有该数据的副本。
  2. Shared (S) 状态:表示缓存行中的数据是干净的,与内存中的数据一致,并且可能被多个缓存共享。
  3. Invalid (I) 状态:表示缓存行中的数据是无效的,需要从内存或其他缓存中获取最新数据。

MSI 协议的工作原理

MSI协议通过监听总线上的事务来维护缓存一致性。当处理器执行读或写操作时,会根据缓存行的状态和其他处理器的监听响应来更新缓存状态。

  • 处理器读(Read):如果缓存行处于Shared状态,则可以直接读取;如果是Modified状态,可以直接读取且不影响其他缓存;如果是Invalid状态,则需要从内存或其他缓存中读取数据,并更新状态为Shared。
  • 处理器写(Write):如果缓存行处于Modified状态,可以直接写入;如果是Shared状态,则需要先将其他缓存中的相应缓存行置为Invalid,然后再写入;如果是Invalid状态,则需要先从内存中读取数据,然后写入并更新状态为Modified。
  • 总线读(BusRd):当缓存行缺失时,会触发总线读操作,其他处理器需要响应并可能需要更新缓存状态。
  • 总线互斥读(BusRdX):当一个处理器需要独占访问缓存行时,会触发总线互斥读操作,其他处理器需要将相应的缓存行置为Invalid。

MSI 协议的流程

  1. 缓存行请求:当处理器请求一个缓存行时,会检查本地缓存中的状态。
  2. 状态转换:根据请求的类型(读或写)和缓存行的当前状态,处理器会更新缓存行的状态。
  3. 总线事务:如果需要,处理器会发起总线事务,如BusRd或BusRdX,以获取数据或通知其他处理器状态变更。
  4. 响应处理:其他处理器监听总线事务,并根据事务类型和自己的缓存行状态做出响应,可能包括更新自己的缓存行状态或提供数据。

MSI 协议的应用场景

MSI协议适用于那些需要保持缓存一致性的多处理器系统,尤其是在小规模系统中,因为它依赖于总线来广播一致性消息。这种协议简单而有效,但当多个缓存共享同一数据块时,可能会因为多次无效化操作而增加流量负载。

MSI 协议的优势与不足

  • 优势
    • MSI协议通过状态标识和总线事务来有序地维护数据块状态,确保了数据块状态的清晰和一致性。
    • 它可以使用总线或环形网作为一致性事务的广播介质,且硬件实现的MSI协议在功能和可靠性上较为健壮。
  • 不足
    • MSI协议在多个私有缓存中都含有同一个共享数据块时,会进行多次写作废操作,增加流量负载。
    • 总线的带宽有限,扩展性差,且总线上的消息对于一些处理器核来说是不需要的,影响了总线的有效利用率。
http://www.lryc.cn/news/481323.html

相关文章:

  • SSH实验5密钥登录Linuxroot用户(免密登录)
  • 2024 网鼎杯 - 青龙组 Web WP
  • ORACLE 闪回技术简介
  • 【笔记】LLC电路工作频点选择 2-2 开关管与滤波压力
  • 【CUDA】认识CUDA
  • Linux(CentOS)yum update -y 事故
  • AI绘画赚钱秘籍!掌握ai绘画赚钱技巧,开启副业新篇章,ai绘画赚钱实战指南!
  • HCIP-HarmonyOS Application Developer V1.0 笔记(四)
  • 【前端】Svelte:组件封装与使用
  • STM32标准库-待机模式
  • 【论文笔记】The Power of Scale for Parameter-Efficient Prompt Tuning
  • 几个docker可用的镜像源
  • Spring学习笔记_27——@EnableLoadTimeWeaving
  • 【数据分析】如何构建指标体系?
  • 大数据程序猿不可不看的资料大全
  • 【架构设计常见技术】
  • LLMs之MemFree:MemFree的简介、安装和使用方法、案例应用之详细攻略
  • Hive简介 | 体系结构
  • [C++] GDB的调试和自动化检测
  • 车机版 Android Audio 框架笔记
  • 【NLP自然语言处理】深入解析Encoder与Decoder模块:结构、作用与深度学习应用
  • 【JAVA EE】多线程、锁、线程池的使用
  • 云计算:定义、类型及对企业的影响
  • 大数据面试题--kafka夺命连环问
  • 【大模型】Spring AI Alibaba 对接百炼平台大模型使用详解
  • Zabbix如何配置将信息发送到邮件
  • jmeter常用配置元件介绍总结之前置处理器、测试片段
  • Redis2:Redis数据结构介绍、通用命令、String类型、Key的层级格式
  • jenkins流水线pipeline
  • 【计网】基于TCP协议的Echo Server程序实现与多版本测试