SMP:对称多处理机系统

附件:SMP.xmind

1 系统架构
1 多处理器<->存储器
1 紧耦合型tightly coupled
  • 1 多端口存储器方式:
    • 比如存储器3块,每块4个端口
    • 连接简单
    • 存储器端口有限,限制了连接的处理器个数
  • 2 集中控制开关方式:
    • 把各存储块硬件控制逻辑换成一个集中式开关,该开关给出处理器到存储块的访问路径

    • 克服多端口缺陷,支持更多处理器
    • 开关单元就复杂: m个存储块,n个处理器,则路径MxN;开关单元故障导致系统可靠性降低
  • 3 局部存储器方式 -> 不对称体系结构:
    • 各个处理器有自己的私有局部存储器
    • 类似解决多处理器冲突的方法:给主存加cache,减少访问主存次数
2 松耦合型loosely coupled -> 分布式:
  • 每个处理器与一个局部存储器相连,但局部存储器不具私有性;处理器Pi访问Mi不经开关切换线路,但访问Mj需经过开关切换
  • 开关切换:
    • 1 局部开关把请求信号作为消息包发给目的开关,途中各开关起转发作用
    • 2 目的开关得到消息后,把自己局部存储器数据作为消息返发回源开关,再转至等待处理器
  • 优点:高可靠性+可扩充性
  • 缺点:延时,取决于Mj和Pi距离
2 处理器<->IO设备
  • 1 多端口IO设备
    • 设备每个端口与一个处理器总线相连,设备可用此端口进行数据传输+中断处理

    • 设备进程在每个处理器上运行
  • 2 中间交叉开关控制:
    • 类似集中式或分布式开关,但更复杂:设备与处理器在一个事物处理中保持时间可能很长,因此用软件控制开关切换比硬件实现更方便

    • 设备进程在每个处理器上运行
  • 3 某IO只与单个处理器相连
    • 设备进程在可访问该设备的处理器上运行
  • 4 某IO与单个处理器相连但可被其它处理器访问
    • 尽管处理器可访问任意设备,但某设备发出的数据和中断信号只能由与之相连的处理器处理,原因:1 设备的中断信号需要尽快相应;2 到非局部存储器的数据传输存在时间延迟

    • 设备进程操作分成两种:能在所有处理器运行;在同设备相连处理器运行
2 操作系统
2.1 分类:
2.1.1 主从式:master-slave
  • 一台主处理机记录控制其它处理机,并分配任务给从处理机
  • 示例:
    • Cyber-170  OS驻留在外围处理机PO上运行,其它处理机从属于该PO
    • DECSystem10  两台处理机:主+从
  • 特点:
    • 1 OS只在一台机器运行,不要求整个管理程序都是可重入的
    • 2 主处理机故障容易引起系统崩溃
    • 3 任务分配算法影响处理器资源利用率
    • 4 用于负载不重或功能差异很大的处理器组成的非对称系统
    • 5 硬件/软件简单,但灵活性差劲
2.1.2 独立监督式:separate supervisor
  • 描述:每台处理机均有自己的监管程序
  • 特点:
    • 1 每个处理机按自身需要及任务执行管理功能->独立
    • 2 管理代码必须可重入,或为每个处理机装入专用管理程序副本。
    • 3 每个处理机都有自己的管理程序:1 访问共用表格冲突少,阻塞也少,效率高;2 冲突仲裁不可缺少
    • 4 一台处理机故障不会造成系统崩溃
    • 5 每个处理机都有自己专用I/O设备和文件等
    • 6 适用于松耦合体系,每个处理机都有局部存储器存放监管程序->存储冗余高
    • 7 实现处理机负载均衡很苦难
  • 示例:IBM370/158
2.1.3 浮动监督式:floating supervisor
  • 描述:只有一台监管处理机,但谁做主处理机不固定
  • 特点:
    • 1 虽只有1台主处理机,但可数台处理机执行一个管理服务子程序->管理程序代码可重入
    • 2 主处理机可浮动->主处理机故障不影响系统运行
    • 3 容易平衡负载
    • 4 请求冲突可通过优先权解决,对共享资源的访问冲突用互斥解决
    • 5 采用处理机集合概念管理,每一处理机都可控制任I/O设备+存储块管理方式透明、可靠、灵活

  • 示例:IBM3081
2.2 功能评价:
  • 1 共享资源:应有进程同步与互斥算法
  • 2 多处理机调度:负载均衡很重要;任务分配时:1 必须了解每台处理机能力以便分配任务 2 确切了解作业中诸任务关系
  • 3 存储器访问:访问仲裁;数据一致性
  • 4 提高可靠性:故障后自动切换;备份资源
3 设计
  • 1 体系结构方面:
    • 处理器同构
    • 处理器同构  通过“仿真软件”抹平异构机之间的硬件差异
  • 2 程序设计方面:同步
    • 1 同步重要性
    • 2 同步实现:
      • 1 紧耦合:通过共享存储器;
      • 2  松耦合:通过计算机网络/分布式系统
    • 3 中心进程实现同步
      • 1 中心进程保存了所有用户权限和冲突图信息
      • 2 访问共享资源的请求先向该进程发请求,中心进程查看冲突图:1 该请求不会引起死锁->插入请求队列;2 否则-> 退回

      • 3 轮到该请求时,中心进程向其发送回答信息允许进入临界段访问
      • 4 退出临界段时,请求向中心进程发送释放资源消息,中心进程收到后处理下一个请求

  • 3 组建
    • 1 CPU必须内置APIC单元(Advanced Programmable Interrupt Controllers):CPU通过APIO通信,控制中断,给中断附加动作;每个处理器有自己的APIO,一个I/O APIC专门处理I/O设备引起的中断

    • 2 相同产品型号,相同类型CPU核心
    • 3 尽可能保持相同的产品序列编号
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值