精华内容
下载资源
问答
  • 电子政务-具有热插拔功能的电源系统.zip
  • 摘要:本文将介绍采用具有热插拔功能的电源模块组成48V分布式电源结构时应考虑的设计问题与用热插拔控制器电路解决多个电路板或刀片刀片热插拔运行中的安会问题等二个方面的内容。  带电插拨功能同时也称为热插拔...
  • 本文介绍采用具有热插拔功能的电源模块组成48V分布式电源结构,应考虑的设计问题。热插拔功能对于确保热插拔元件的安全特别重要,此外,在热插拔过程中,热插拔功能能防止输入和输出电源线电压产生明显波动。任何...
  • 电信设备-多功能具有热插拔式硬盘的通讯管理机.zip
  • 24块前置热插拔硬盘设计这款宝德PR4036NS服务器最大的优势是拥有海量的存储空间,产品采用了4U机架式设计,最大支持36个热插拔的3.5英寸硬盘,存储容量高达72TB,不同于...24块前置热插拔硬盘服务器状态功能状态面板...

    24块前置热插拔硬盘设计

    这款宝德PR4036NS服务器最大的优势是拥有海量的存储空间,产品采用了4U机架式设计,最大支持36个热插拔的3.5英寸硬盘,存储容量高达72TB,不同于传统存储服务器产品,其中有24块热插拔3.5英寸硬盘在产品前置端,后端提供额外的12块3.5英寸硬盘,而且3.5英寸驱动器技术有更稳定的表现,在保证超低功耗的同时增强性能和可靠性。

    5a46016573337d106ea3f2afcd88fe21.png

    24块前置热插拔硬盘

    4fb4ca26b7ec5aa2c4d124a046aacde7.png

    服务器状态功能状态面板

    从机身规格来看,正面的左面板看到宝德PR4036NS服务器的开关键和RESET功能,以及区域很小的显示服务器状态功能面板,似乎整个前面版主要提供给存储硬盘设计。

    对于存储服务器来说,似乎从前面板整体来看,扩展功能表现相对都不是很好,在前面板的没有提供了USB 2.0传输接口。而对于这款产品来说,由于大存储容量的特性,并没有提供前置的DVD光驱设计,这样设计对于宝德PR4036NS服务器在系统应用程序以及额外管理上有少许不便。

    2c418d34bf5c1ea796befc0d1da87084.png

    配备6块西数SATA硬盘

    9d2f88bd9448c647463bccafd208c7f9.png

    这款产品存储容量高达6TB

    对于存储服务器而言,是一种特殊定制的专用服务器,只是提供大容量存储而生。由此,相比通用服务器,存储服务器最明显特点是具有更加“海量”的内部存储空间。这台宝德PR4036NS服务器最大支持36块3.5寸热插拔SATA硬盘,提供6块1TB SATA硬盘,内部存储容量可以达到72TB,已经可以跨入小型磁盘阵列的行列。

    9003a46913324bde75b43dc51b4133b3.png

    西数1TB SATA硬盘

    这款产品配备的西部数据 1TB SATAII 32M 企业级(WD1002FBYS)使用了黑盘常用的黑色标签,用加倍数据处理速度方式提高硬盘性能,最大内部传输率可达145MB/s,7200RPM,32MB缓存,单碟容量375GB。

    展开全文
  • NCP81295-D 50A,热插拔控制器,内置 MOSFET 和 IMON 功能具有并行功能,采用热性能增强型封装
  •  LTC:registered:4280 热插拔 (Hot SwapTM) 控制器允许在一块带电背板上安全地进行电路板的插拔操作。通过采用一个外部 N 沟道传输晶体管,可使电路板电源电压和浪涌电流以一种可调速率斜坡上升。一个 I2C 接口和板...
  • 因此,您必须了解哪些规则和限制限制了Xilinx FPGA的热插拔功能。如果需要热插拔,那么设计一个稳定可靠的系统将面临更大的挑战。此应用程序说明最好用作在热交换类型的应用程序中使用Xilinx FPGA时需要考虑的事项的...
  • 现象:网卡和 SCSI 控制器显示为可移除设备。与该虚拟硬件对应的“安全移除硬件”选项显示在 Windows 系统任务栏中。...解决办法:可以使用 vSphere Client 或通过编辑 .vmx 文件来禁用热插拔功能。 注意...

    现象:
    网卡和 SCSI 控制器显示为可移除设备。
    与该虚拟硬件对应的“安全移除硬件”选项显示在 Windows 系统任务栏中。
    如果正在使用 VMware View,您会注意到具有持久磁盘的 View 桌面正在断开连接。
    某些windows2012版本的虚机之间,可以访问C$而不能访问D$\E$的问题。

    解决办法:
    可以使用 vSphere Client 或通过编辑 .vmx 文件来禁用热插拔功能。

    注意: 还可以禁用诸如 e1000 或 vmxnet2 NIC 等 PCI 设备的热插拔功能。

    要使用 vSphere Client 禁用热插拔功能,请执行以下操作:

    使用 vSphere Client 连接到 ESXi/ESX 主机或 vCenter Server。
    关闭虚拟机电源。
    右键单击虚拟机,然后单击编辑设置。
    单击选项选项卡。
    单击常规 > 配置参数 > 添加行。
    插入名为 devices.hotplug 且值为 false 的新行。
    然后打开虚拟机电源。

    要使用 vSphere Web Client 禁用热插拔功能,请执行以下操作:

    从 Web 浏览器连接到 vSphere Web Client。
    使用管理员凭据进行登录。
    导航到要修改的虚拟机。
    关闭虚拟机。
    右键单击虚拟机,然后选择编辑设置。
    单击虚拟机选项选项卡。
    单击高级 > 编辑配置 > 添加行。
    插入名为 devices.hotplug 且值为 false 的新行。
    打开虚拟机电源。

    要通过编辑 .vmx 文件来禁用热插拔功能,请执行以下操作:

    关闭虚拟机电源。
    使用 SSH 客户端访问 ESXi/ESX 服务控制台。
    在文本编辑器中打开虚拟机配置文件 (.vmx)。 默认位置为:
    
    /vmfs/volumes/datastore_name/vm_name/vm_name.vmx
    
    添加以下行:
    
    devices.hotplug = "false"
    
    注意: 此设置不影响热插拔 CPU和内存。
    
    保存并关闭该文件。
    然后打开虚拟机电源。

    注意: 如果正在使用 VMware View,请先对父虚拟机执行上述过程之一,然后再执行以下步骤:

    创建父虚拟机的新快照:
    
        在 vSphere Client 中,右键单击父虚拟机,然后单击快照 > 生成快照。
        输入快照的名称和描述。
        单击确定。
    
    将受影响的池重组到此新快照中:
    
        在 View Manager 控制台中,选择并打开一个池。
        单击 View Composer > 重组,然后选择新生成的快照。
        单击下一步。
        配置调度和警告选项。
        单击下一步。
        检查确认信息。
        单击完成并验证重组操作是否成功完成。
        对所有受影响的池重复重组过程。
    展开全文
  • AIX热插拔PCI 设备功能介绍

    千次阅读 2009-03-19 14:58:00
    热插拔PCI 设备功能介绍内容提要: 本文从以下几个方面介绍PCI设备的热插拔功能 一,综述 二, 基础知识介绍三, 移走PCI 适配卡四, 增加PCI 适配卡五, 动态增加/ 移走PCI 命令行介绍说明: 热插拔PCI 设备功能...

    热插拔PCI 设备功能介绍
    内容提要: 
    本文从以下几个方面介绍PCI设备的热插拔功能 
    一,综述 
    二, 基础知识介绍
    三, 移走PCI 适配卡
    四, 增加PCI 适配卡
    五, 动态增加/ 移走PCI 命令行介绍
    说明: 
    热插拔PCI 设备功能介绍 
    一, 综述 
    PCI 适配卡的热插拔功能是AIX 操作系统提供一项重要功能,这一功能的实现同时需要系统硬件
    和操作系统的支持,本文将介绍PCI 热插拔设备的基础知识,并给出适配卡的增加和移走的示例。
    二, 基础知识介绍 
    在操作系统运行中,允许在线的增加PCI 热插拔适配卡,这些适配卡可以是系统中已经存在的,
    也可以是新的PCI 适配卡。操作系统和应用能够识别这些新增加的PCI 适配卡,而不需要重新引导
    系统。可以从下面几个方面理解这一功能的重要性:
    1 ) 对已经存在的设备增加额外的功能和能力
    2 ) 在线升级PCI 适配卡
    3 ) 对初始安装的系统,增加新的适配卡
    但是,使用PCI 热插拔替换或者增加适配卡应当注意,当使用增加的适配卡作为引导设备使用时
    如使用bootlist 命令,适配卡及其子设备可能不能识别,必须重新引导机器使操作系统识别所有这些
    潜在的引导设备。
    另外,系统也允许移走或替换有缺陷的、失败的具有PCI 热插拔功能的适配卡,或者使用同一型
    号的适配卡替换,而不需要关闭系统。当替换已存在的适配卡时,系统自动识别同一类型的适配卡,
    系统现存的设备的配置和配置信息为新增加的卡保留。可以从以下几个方面考虑替换功能的重要性:
    1 ) 临时替换适配卡,帮助诊断、定位问题。
    2 ) 替换有缺陷的、失败的、或者间歇性失败的适配卡
    3 ) 在HACMP 或者多路I/O 的配置中,替换失败的冗余适配卡 
    当移走具有热插拔功能的适配卡时,系统和应用不能再使用卡提供的资源。可以从以下几个
    方面考虑在线移走适配卡的重要性:1 ) 移走已存在的I/O 子系统
    2 ) 移走不再需要的适配卡,或者是失败的卡
    但应当注意,在移走或者替换热插拔设备时,首先应当删除卡的相应配置信息,相关的设备驱
    动程序必须释放卡相关的所有系统资源,如申请的内存、中断和EPOW 处理函数,释放DMA 和定
    时器资源,总之,驱动程序必须保证释放卡的中断、总线内存和总线I/O 信息。
    在移走适配卡之前和之后,系统管理员必须执行以下的动作:
    1 ) 终止或恢复使用设备的应用、后台进程
    2 ) 卸载或重新加载文件系统
    3 ) 执行相应的操作释放使用的设备,移走或重新创建设备的定义信息
    4 ) 将系统恢复到安全的服务模式
    注意,尽管PCI 热插拔管理提供了不停机的增加、移走和替换PCI 适配卡的能力,但并不是所有的
    设备都可以使用这一功能,例如,连接引导设备的I/O 适配卡。在尝试替换或者增加新的PCI 热插拔适
    配卡时,可以参考PCI Adapter Placement Reference 一书,判断适配卡是否可以热插拔。
    三, 移走  PCI  适配卡 
    介绍利用PCI 热插拔管理功能移走PCI 适配卡的操作示例步骤,将按照以下的步骤进行:
    1 ) 确定支持热插拔的槽位,并确定要删除的设备
    2 ) 删除要移走的设备相关信息
    3 ) 物理的移走设备
    4 ) 确定操作成功 
    以下将给出详细的操作步骤,假定要移走的设备为网络适配器ent1 ,具体的步骤如下:1 ) 显示可热插拔的适配卡,并确定删除的适配卡ent1 
    # lsslot -c pci 
    # Slot Description Device(s) 
    U0.1-P2-I1 PCI-X capable, 64 bit, 133MHz slot pci9 lai0 
    U0.1-P2-I2 PCI-X capable, 64 bit, 133MHz slot fcs0 
    U0.1-P2-I3 PCI-X capable, 64 bit, 133MHz slot ent1 
    U0.1-P2-I4 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I5 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I6 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I7 PCI-X capable, 32 bit, 66MHz slot Empty 

    上面列表中红色所示为ent1 
    2 ) 如设备在使用状态,应先卸载此设备
    #ifconfig en1 down 
    #ifconfig en1 detach 
    3 ) 删除适配卡配置信息 
    可以使用命令删除适配卡ent1 的配置信息:
    #rmdev –dl en1 
    #rmdev –dl ent1 
    或者使用PCI 热插拔管理器,如下:
    smitty device 
     
    选择Unconfig a device 菜单
     
    选择要删除的设备ent1 ,在Unconfigure any Child Devices 项中选择yes ,KEEP definition in database 项
    中可选择yes 或者no 
    4 ) 移走适配卡 
    在PCI 热插拔管理器项中选择Replace/Remove a PCI Hot Plug Adapter 子菜单项
     
    在上图中,选择要移走的设备,并设置要操作的动作为Remove ,
     
    选中操作的动作后,按回车,如上图所示,此时的PCI 设备处于可操作状态,对应的槽位的指示灯会
    不停的闪烁,现在可以移走PCI 适配卡ent1 。物理的移走适配卡ent1 后,按回车,如下图所示:
     
    5 ) 确定适配卡成功移走 
    以上的操作步骤正确操作后,使用命令lsslot 确定网络适配卡ent1 所在的槽位状态为空,既没
    有设备# lsslot -c pci 
    # Slot Description Device(s) 
    U0.1-P2-I1 PCI-X capable, 64 bit, 133MHz slot pci9 lai0 
    U0.1-P2-I2 PCI-X capable, 64 bit, 133MHz slot fcs0 
    U0.1-P2-I3 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I4 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I5 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I6 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I7 PCI-X capable, 32 bit, 66MHz slot Empty 
    四, 增加  PCI  适配卡 
    增加PCI 适配卡,可以按照以下的步骤操作:
    1 ) 确定增加的PCI 适配卡要安装的槽位
    2 ) 使用PCI 热插拔管理器设定此槽位为可操作状态
    3 ) 物理的安装PCI 适配卡到槽位
    4 ) 配置适配卡,运行cfgmgr识别新增加的PCI适配卡
    5 ) 确定适配卡已经被系统识别
    在以下的具体操作步骤中,以安装网络适配卡为例
    其具体的操作步骤为:
    1 ) 使用smitty device 选择PCI Hot Plug Manager 子菜单项
    2 ) 在PCI 热插拔管理器中,选择Add a PCI Hot Plug Adapter 子项,如下图所示: 
     
    3 ) 选择要安装的槽位 
     
    假定要安装的网络适配卡,槽位为第三槽位,并按回车键,如上图所示。
    4 ) 确定槽位为可操作状态 
     
    如上图所示,安装适配卡的槽位的指示灯将会不停的闪烁,此时可以物理的将网络适配卡安装到
    第三槽位。网络适配卡安装成功后,按回车健,PCI 热插拔管理器将自动配置网卡。并显示如下信息:
     
    如果,上图显示未失败信息,则可能是因为网络适配卡与槽位接触不良,需要重新安装网络适配卡。
    5)运行cfgmgr配置适配卡,使操作系统识别此卡 
    #cfgmgr -v 
    6) 确定设备成功安装成功 
    确定网络适配卡已经成功安装,并为系统识别,可使用命令lsslot 查看对应的槽位,是否标示为ent1 。# lsslot -c pci 
    # Slot Description Device(s) 
    U0.1-P2-I1 PCI-X capable, 64 bit, 133MHz slot pci9 lai0 
    U0.1-P2-I2 PCI-X capable, 64 bit, 133MHz slot fcs0 
    U0.1-P2-I3 PCI-X capable, 64 bit, 133MHz slot ent1 
    U0.1-P2-I4 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I5 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I6 PCI-X capable, 64 bit, 133MHz slot Empty 
    U0.1-P2-I7 PCI-X capable, 32 bit, 66MHz slot Empty 
    五, 动态增加/ 移走PCI 命令行介绍
    在上面的操作中,使用AIX smitty 工具提供的PCI Hot Plug Manager 菜单项完成的,另外AIX 操作
    系统还提供了命令行的方式实现这一功能,命令为drslot ,简单介绍如下:
    1 ) 标示热插拔槽位,使用参数-i ,格式如下: 
    drslot –i { -s 槽位号 | -l 设备名 } –c 连接方式
    在PCI 的热插拔功能中,此项为pci ,如下命令:
    drslot -i -c pci -s U0.1-P2-I3 
    标示槽位U0.1-P2-I3 ,此时此槽位的灯将不停闪烁
    2 ) 在一槽位增加PCI 适配卡,使用参数-a ,格式如下: 
    drslot –a –s 槽位号 –c 连接方式 [-I] 
    如下命令:
    drslot -a -I -c pci -s U0.1-P2-I3 
    在U0.1-P2-I3 增加一PCI 适配卡
    3 ) 移走一PCI 适配卡,使用参数-r ,格式如下: 
    drslot –r { -s 槽位号 | -l 设备名 } –c 连接方式 [-I] 
    4 ) 替换已存在的PCI 适配卡,使用参数-R ,这一操作首先是做删除动作,然后是替换动作,格式如下: 
    drslot –R { -s 槽位号 | -l 设备名 } –c 连接方式 [-I] 以上介绍了drslot 命令的简单使用参数,具体的使用方法请参考系统提供的联机帮助。

    展开全文
  • pci 热插拔

    千次阅读 2014-03-17 13:56:27
    PCI SIG推出了标准热插拔控制器规范(SHPC SPEC),其中明确了热插拔的标准使用模式和严格的寄存器组要求,并且允许操作系统提供商在平台特定的软件之外提供热插拔支持,逐步完成了热插拔标准制定工作,进入技术的...

    一 相关技术与研究

    1997年,PCI SIG制定了第一个PCI热插拔规范,其中定义了支持热插拔所必需的平台、板卡和软件元素。PCI SIG推出了标准热插拔控制器规范(SHPC SPEC),其中明确了热插拔的标准使用模式和严格的寄存器组要求,并且允许操作系统提供商在平台特定的软件之外提供热插拔支持,逐步完成了热插拔标准制定工作,进入技术的全面推广阶段。 2002年以后,Intel把热插拔作为一种天然属性赋予新推出的PCI Express规范,PCI Express热插拔总结了五年来工业标准的经验,具有如下特点:

    • 基于SHPC模式并对其进行了功能扩展;
    • PCI Express从设计上就把热插拔寄存器集成进入了其标准的性能寄存器组(而在SHPC 1.0中,热插拔寄存器是附加的);
    • 提供给操作系统一个统一的热插拔硬件寄存器接口,赋予了操作系统进行原生热插拔(绕过了传统基于BIOS的热插拔方法)的能力;
    • 通过在基本的体系机构层次定义热插拔必须的硬件要求,完善了一种标准的使用模式;
    • 提供了规格参数来保证OEM产品的低成本而高平台可靠性。

    具有完整功能的PCI Express热插拔系统在平台硬件和固件支持之外,还必须有操作系统以及设备驱动程序的支持。

    在各大芯片厂商纷纷推出支持PCI热插拔的产品的同时,Microsoft,Novell,SCO等公司在他们相关的操作系统中也都包括了支持热插拔的技术, Novell NetWare 4.11&5和SCO UnixWare 7以及更新版本支持完整PCI热插拔(热替换和热添加)。Microsoft Windows NT 4.0利用Compaq 服务器支持盘(SSD) for NT 4.0,提供了PCI热替换支持,进入2000年后,Microsoft Windows 2000也内建了对PCI热插拔技术的全面软件支持。对于GNU/Linux,从2001年1月份的内核2.4版本开始,PCI 热插拔开始成为其标准特性之一,到2.6 版本,热插拔功能已经被整合进入核心设备模型。现在,几乎所有的Linux发行版本,包括RedHat, Debian和 United Linux,都对PCI 热插拔提供了良好支持,并分别有所扩展。BSD分支在这方面起步较晚,OpenBSD在2004年三月份的3.6版本中才出现了不含设备驱动的设备热插拔参考框架,而FreeBSD 到5.3版本为止,尚未提供对PCI 热插拔的支持。

    作为2002年出现的规范,各个通用操作系统对PCI Express的支持才刚刚起步。在微软公司的 Windows 2000, Windows XP, and Windows Server 2003中,PCI Express设备被当作PCI设备进行热插拔,其他PCI Express的高级功能可以由固件激活。在Windows Longhorn中,才提供对PCI Express高级特性的原生支持。GNU/Linux在内核版本2.6.9中开始专门提供对于PCI Express 热插拔的支持,中间历经软件架构的改动,逐渐发展为以内核版本2.6.10以及内核版本2.6.12下两种不同的PCI Express热插拔驱动架构。本文主要讨论2.6.10所采用的PCI Express热插拔驱动架构,并在最后给出2.6.12的新特性。

    三 PCI Express 热插拔的软件支持

    根据规范,一个完整的 Native PCI Express 热插拔系统需要几方面的相互配合,分别为硬件元素、固件元素和软件元素。 硬件元素是指主板总线系统的电气特性方面的支持,包括热插拔控制器(Hot-Plug Controller)、卡槽电源切换逻辑(Card Slot Power Switching Logic)、板卡重置逻辑(Card Reset Logic)、电源指示灯(Power Indicator)、提示按钮(Attention Button)和板卡存在检测引脚(Card Present Detect Pins)等等;固件元素是指主板BIOS必须对热插拔提供的支持,要实现Native PCI Express热插拔,固件必须提供OSHP方法或ACPI _OSC方法之一;软件元素是指操作系统操综合使用PCI Express 热插拔所必须提供的功能组件。

    软件元素

    为了操纵平台的硬件元素,提供PCI Express热插拔服务,我们必须实现表1所示的主要热插拔软件元素。

    PCI Express服务模型

    PCIE热插拔(PCIEHP)子系统中的标准热插拔系统驱动程序通过检查PCI Express性能数据结构中的插槽性能寄存器(Slot Capabilities register),来获取硬件的热插拔部件信息。这些寄存器所能反映的信息如下:

    1. 插槽是否支持热插拔
    2. 设备是否支持不通知软件的突然拔出操作
    3. 提示灯、控制器等硬件元素是否存在

    一旦软件完成了PCI Express设备热插拔功能的开启和配置工作,热插拔行为(例如移出或插入请求,电源故障)就可以向系统热插拔处理机制提交系统中断和电源管理事件。这种热插拔处理机制由操作系统独立提供,图1展示了PCI Express Native热插拔的服务模型,并展示了它与传统的基于ACPI的模型之间的区别。

    图1 PCI Express热插拔服务模型比较
    图1 PCI Express热插拔服务模型比较

    四Linux 2.6.10 PCIE 热插拔子系统代码分析

    热插拔框架

    为了提供PCI Express热插拔服务,Linux 2.6.10 PCIE热插拔(PCIEHP)子系统必须实现用户操作界面、热插拔服务程序和标准热插拔系统驱动等热插拔软件元素,并使软件的行为符合热插拔标准使用模式[4]。另外,一些特定的热插拔功能必须与支持热插拔的设备驱动结合在一起发挥作用。

    PCIEHP核内部分的主体是一个核心线程,其控制逻辑以模块的方式加载入内核,负责监控PCI Express总线上的热插拔事件,并做相关处理;核外部分是一个用户空间的脚本,从内核中调用,并根据内核传回的信息执行后续处理过程。

    1 热插拔驱动程序生命周期

    从PCIEHP子系统启动,到子系统被卸载期间,PCIEHP完全接管系统中PCI Express插槽热插拔事件。

    PCIEHP子系统启动时,首先要开启用户态守护进程。然后初始化通知机制,开启PCI Express热插拔事件处理核心线程,为操作系统中各总线数据结构分别预初始化一个热插拔插槽列表。接着,根据内核编译时是否指定ACPI式资源管理,初始化设备资源管理方式。最后,根据设备标识,在系统中注册PCI Express热插拔驱动程序,并将其绑定到总线上所有可能挂载热插拔插槽的PCIE桥接设备,然后初始化对应的热插拔控制器,分配资源,开启定时的中断轮询机制。

    卸载PCIEHP子系统,首先释放热插拔控制器全局列表中每个控制器所占用的资源,释放热插拔插槽全局列表中每个插槽所占用的资源,终止通知机制的运行,结束PCI Express热插拔事件处理核心线程;接着,根据内核编译时是否指定ACPI式资源管理,释放相关设备占用的系统资源;然后,注销PCI Express热插拔驱动程序;在处理完当前热插拔事件后,终止核外守护进程。

    在PCIEHP加载后,为了在热插拔执行过程中追踪其状态变化,我们把热插拔插槽的状态抽象如下:

    • 静态 (STATIC STATE ),
      正常工作或者空闲的时段,
    • 开启前闪烁提示态(BLINKINGON STATE)
      发出开启请求到确认之前的时段
    • 关闭前闪烁提示态 (BLINKINGOFF STATE)
      发出关闭请求到确认之前的时段
    • 开启态 (POWERON STATE)
      执行开启操作的时段
    • 关闭态(POWEROFF STATE)
      执行关闭操作的时段

    各个插槽状态之间的转换关系如图2所示:

    图2 插槽状态转换图
    图2 插槽状态转换图

    2 用户控制脚本/sbin/hotplug和核内外通信机制

    在内核热插拔处理完毕后,它会在核内调用一个用户态脚本hotplug,这个脚本将根据内核提供的信息进行后续处理工作。它是设备热插拔通告的用户空间部分,它接收内核传出的热插拔操作类型和环境变量,处理设备挂载和卸载操作。通常,hotplug会根据设备类型调用一个策略脚本,针对设备和系统当前参数进行后续的配置工作。例如,对于网卡,可能会调用脚本指定IP地址,网关和域名服务器等等,对于存储设备,可能会调用mount命令来加载它到文件系统内。

    内核传送给hotplug的信息包含热插拔操作类型(例如PCI),并且在一个环境变量中提供本次操作相关信息:

    • 行为种类:添加或删除
    • 对象设备所属PCI 类、子类和编程接口
    • 对象制造商标志和设备标志
    • 对象总线地址、插槽地址和功能函数编号

    核外的后续配置工作涉及如下文件:

    /etc/hotplug/pci.rc
    /ect/hotplug/pci.Agent
    /etc/rc.d/init.d/hotplug
    

    在内核中,由kernel/kmod.c中的函数

    int call_usermodehelper (char *path, char **argv, char **envp, int wait)来开启用户态脚本/sbin/hotplug。在参数表中,path表示了所启动的核外应用程序的路径,argv是应用程序的参数表,envp是环境变量列表,wait则指出了是否同步等待应用程序执行完毕再返回执行结果的状态。

    3 PCIE 热插拔模块构成

    为了使用PCI Express Native Hotplug,我们必须在编译的时候开启对应的功能模块。

    在内核配置中,PCIE Hotplug对应的开关为HOTPLUG_PCI_PCIE,它依赖于HOTPLUG_PCI。如果你的主板支持PCI Express Native Hotplug,可以选择Y;如果你只是想把这个驱动作为模块来编译,那么选择M,此模块叫做pciehp,在源代码\dirver\pci\hotplug\Kconfig文件中,你可以看到:

    config HOTPLUG_PCI_PCIE
    	tristate "PCI Express Hotplug driver"
    	depends on HOTPLUG_PCI

    完整的pciehp模块功能涉及到如下几个文件pci_hotplug_core.c, pciehp_core.c,pciehp_ctrl.c,pciehp_pci.c pciehp_hpc.c,另外根据是否开启了ACPI,包含pciehprm_acpi.c 或者pciehprm_nonacpi.c,在源代码\dirver\pci\hotplug\Makefile文件中,你可以看到:

    pci_hotplug-objs	:=	pci_hotplug_core.o
    pciehp-objs		:=	pciehp_core.o	\
    				pciehp_ctrl.o	\
    				pciehp_pci.o	\
    				pciehp_hpc.o
    ifdef CONFIG_ACPI_BUS
    	pciehp-objs += pciehprm_acpi.o
    else
    	pciehp-objs += pciehprm_nonacpi.o
    endif

    代码的主要任务就是在所有支持热插拔的PCIE桥上加载热插拔驱动程序,监控热插拔事件,并根据类型,如是热插入事件、热拔出事件还是电源故障等分别予以处理。

    热插拔驱动的加载

    热插拔驱动程序的加载所进行的主要工作是开启并初始化PCIE热插拔的内核线程,这部分代码位于/driver/pci/hotplug/pciehp_core.c中。入口函数为:

    static int __init pcied_init(void)

    #ifdef CONFIG_HOTPLUG_PCI_PCIE_POLL_EVENT_MODE
    	pciehp_poll_mode = 1;
    #endif
    	retval = pcie_start_thread();
    	if (retval)
    		goto error_hpc_init;
    	retval = pciehprm_init(PCI);
    	if (!retval) {
    		retval = pci_register_driver(&pcie_driver);
    		dbg("pci_register_driver = %d\n", retval);
    		info(DRIVER_DESC " version: " DRIVER_VERSION "\n");
    	}

    pcied_init中所涉及的关键函数分析如下:

    retval = pcie_start_thread();

    初始化并开启通知机制:

    pciehp_event_start_thread()启动事件监控处理线程
    然后初始化slot列表,系统中每个bus给一个slot列表。
    struct pci_func *pciehp_slot_list[256]; 都设为NULL

    retval = pciehprm_init(PCI);

    原型:int pciehprm_init(enum php_ctlr_type ctlr_type)

    初始化资源(区别两种情况:acpi和非acpi的) 在非acpi的初始化方式下,调用空函数legacy_pciehprm_init_pci();在pcihprm_nonacpi.h中,定义了irq_info,irq_routing_table两个结构。在acpi初始化方式下,通过pciehprm_acpi_scan_pci()在acpi树下遍历搜寻PCI设备。不论acpi和非acpi的,都要求php_ctlr_type为PCI。

    retval = pci_register_driver(&pcie_driver);

    注册并初始化PCI桥热插拔驱动程序模块。

    把设备驱动加入已注册设备驱动列表,即使在期间没有相应设备出现驱动程序仍然保持有效。

    	int count = 0;
    	/* initialize common driver fields */

    用来泛化之,可以把drv->driver看作为drv的基类信息

    	drv->driver.name = drv->name;
    	drv->driver.bus = &pci_bus_type;
    	drv->driver.probe = pci_device_probe;
    	drv->driver.remove = pci_device_remove;
    	drv->driver.kobj.ktype = &pci_driver_kobj_type;
    	pci_init_dynids(&drv->dynids);
    	count = driver_register(&drv->driver);

    注意:这里是如何从基类drv->driver一般设备的驱动向子类drv这个pci设备的驱动逆向关联的--使用CONTAINER宏

    pcie_driver为PCIE驱动程序对象,定义在 pciehp_core.c中

    	static struct pci_driver pcie_driver = {
    	//驱动名称定义为"pciehp"
    .name=	PCIE_MODULE_NAME, 
    // id_table指定探测函数probe所应用的范围,这里在表中指定为所有的PCI桥设备
    	.id_table	=	pcied_pci_tbl, 
    //probe为指定的设备探测函数
    	.probe	=	pcie_probe, 
    };
    static struct pci_device_id pcied_pci_tbl[] = {
    	{
    	//此处选择所有PCI桥
    .class =        ((PCI_CLASS_BRIDGE_PCI << 8) | 0x00),
     
    	.class_mask =	~0,
    	.vendor =       PCI_ANY_ID,
    	.device =       PCI_ANY_ID,
    	.subvendor =    PCI_ANY_ID,
    	.subdevice =    PCI_ANY_ID,
    	},

    设备探测pcie_probe:

    static int pcie_probe
    (struct pci_dev *pdev, const struct pci_device_id *ent)
    in pcie-core.c

    已经确定了pdev就是pcie_driver 所匹配的PCI桥设备,而且它在pcie_driver中所对应的设备特征号是*ent,就可以对其进行进一步的初始化和探测。

    具体行为如下:

    • 绑定热插拔插槽
    • 设置了控制器及其状态
    • 注册中断处理函数
    • 读写配置头,然后分配资源,最后对插槽检测,挂接

    热插拔事件的监控处理线程

    热插拔驱动程序对于热插拔事件的轮询和通知采用异步机制,对热插拔功能部件的操纵是通过读写相关寄存器组进行的。主要功能函数关系请参见图3:

    图3 插槽热插拔事件处理函数关系
    图3 插槽热插拔事件处理函数关系

    图3中主要函数的功能介绍如下:

    A插槽事件监控线程

    作为热插拔活动最直接的信息,插槽事件由硬件操作并置位相关寄存器组,系统软件可以通过定时轮询或者中断方式获取事件信息,执行对应的事件预处理函数。插槽事件如下:

    • 热插拔命令到达
    • 插槽锁状态改变
    • 适配卡存在状态改变
    • 电源出现故障

    php_ctlr->int_poll_timer.function = &int_poll_timeout 其中php_ctlr是热插拔控制器状态php_ctlr_state_s类型,它定义于pciehp_hpc.h中,记录当前热插拔控制器重要状态,被用作HPC(controller)的控制器句柄;热插拔控制器controller位于文件pciehp.h中,描述了PCIE热插拔控制器的特征;

    定时轮询函数原型如下:

    static void int_poll_timeout(unsigned long lphp_ctlr)
    其中调用pcie_isr( 0, (void *)php_ctlr, NULL );
    当最后一个参数是NULL时,采用polling机制。
    static irqreturn_t pcie_isr(int IRQ, void *dev_id, struct pt_regs *regs);
    轮询机制通过定期(2second,使用一个计时器)读取ctrller对应的状态寄存器,来获取事件,然后调用ctrl状态参量对应的事件处理函数。也就是按钮、电源、MRL等等事件处理函数,并分别调用event_semaphore来激活event_thread.

    B事件预处理函数

    在插槽事件监控线程截获插槽事件后,它根据事件类型调用这组处理函数,执行完毕后,填写对应控制器上所挂接的事件队列,并激活睡眠等待的处理线程。可以激活睡眠中的处理线程的函数包括如下几个:

    pciehp_handle_attention_button :处理按钮事件
    pciehp_handle_switch_change:处理开关状态改变事件
    pciehp_handle_presence_change:处理存在性状态变化事件
    pciehp_handle_power_fault:处理电源故障事件
    pushbutton_helper_thread:按钮动作处理线程

    C热插拔事件处理核心线程event_thread

    event_thread的处理过程如下:
    在一个无限循环中,阻塞等待插槽事件发生
    当线程被某一事件唤醒后,
    如果 热插拔请求已通过延时确认
    进入热插拔请求处理函数
    否则
    轮询热插拔控制器队列:
    把控制器作为参数传给插槽事件处理函数
    其中

    if (pushbutton_pending)
    			pciehp_pushbutton_thread(pushbutton_pending);
    		else if (surprise_rm_pending)
    			pciehp_surprise_rm_thread(surprise_rm_pending);

    前一个处理按钮事件,后一个处理突然拔出事件。

    参数pushbutton_pending是由如下函数提供的:

    static void pushbutton_helper_thread(unsigned long data)
    {
             pushbutton_pending = data;
             up(&event_semaphore);

    而这个函数又被作为定时task事件的行动部分,赋值给

    static void interrupt_event_handler(struct controller *ctrl)中的
    p_slot->task_event.function:
    函数:
    p_slot->task_event.function 
    = (void (*)(unsigned long)) pushbutton_helper_thread;
    参数:
    p_slot->task_event.data 
    = (unsigned long) p_slot;

    D插槽事件处理函数interrupt_event_handler

    根据控制器信息,获取控制器对应插槽事件
    尚有事件等待处理,则执行以下内容:

    逐一查看控制器所挂接事件队列的每个成员(根据事件类型):

    1. 请求取消
    取消前五秒内触发的一次热插拔请求

    2. 请求触发
    触发一次热插拔操作:导致一个五秒钟的延时,如果五秒内请求没有被拒绝,则确认前一个热插拔请求

    3. 电源故障
    弹出提示信息

    4. 其他
    读取插槽的功能寄存器,更新状态信息。

    E热插拔请求处理函数pciehp_pushbutton_thread

    一个定期运行的程序,处理当前插槽上阻塞的请求,根据请求类型:对插槽中的设备进行热移出(F)或者热添加操作(G)。

    F插槽热拔出设备pciehp_disable_slot

    保证所除去的不是视频控制器
    卸载所除去的适配卡占用的系统资源,更新总线结构,关闭电源
    通知用户态守护进程
    更新插槽状态

    G插槽热添加设备pciehp_enable_slot

    1. 执行适配卡添加的一系列相关操作: 失败恢复预处理,存在性检验、打开电源,检查link training状态,获取设备基本信息,配置设备,为设备建立相关数据结构,挂接到上级总线等。

    2. 为新添加的设备查找并挂接驱动程序。

    3. 特别地,对于桥接设备,把它挂接到上级总线后,还要继续对其下级总线进行扫描和挂接。

    4. 通知用户态守护进程。

    5. 更新插槽状态。

    五 PCIE板卡热插拔的标准过程

    热插拔PCI板卡可以使用提示按钮或用户界面来进行,下面我们介绍使用用户界面来启动热插入和热拔出的操作过程,以及Fedora C4T2下所采用的方式。

    设备的热插入

    1. 操作员安装卡,闭合插槽保护锁,保护锁感应器通知热插拔控制器把连接信号接通到插槽。

    2. 然后,操作员通知热插拔服务程序:卡已经被安装并可以激活。软件提示用户对此进行确认。

    3. 在操作员请求连接后,热插拔服务程序向控制着热插拔控制器的热插拔系统驱动程序下达命令,闪烁插槽的电源指示灯,提示操作员此时不可以拔动适配卡。

    4. 在热插拔软件对此请求进行确认期间内,电源指示灯继续闪烁。注意此时软件可能会拒绝这个安装请求(例如,安全策略此刻禁止插槽被激活)。另外,如果请求没有生效,软件拒绝请求并对热插拔控制器发出命令关闭电源指示灯。规范建议软件通过一条消息通知操作员请求被拒绝的原因。

    5. 如果请求被确认,热插拔服务程序对热插拔系统驱动发出请求,为插槽加电。

    6. 加电后,软件发出命令完全打开电源指示灯。

    7. 当link training完成后,操作系统指示平台配置程序赋予适配卡必需的资源,来配置适配卡的功能。

    8. 操作系统为PCI Express设备中的功能寻找恰当的驱动程序,并加载之。

    9. 接着系统调用驱动程序的初始化入口,并执行驱动的初始化代码。这些代码完成设备的设置,并填写设备的PCI 配置命令寄存器的相关标志位来激活设备。

    热移出设备

    1. 操作员通过指定适配卡所在物理插槽号码来初始化移出请求。

    2. 软件弹出窗口要求操作员确认请求。注意,此时电源指示灯保持开启状态。

    3. 操作员确认请求后,热插拔服务程序向热插拔系统驱动发出请求,要求热插拔控制器闪烁电源指示灯。注意此时软件可能会拒绝这个移出请求(例如,适配卡目前正被关键系统功能所使用)。另外,如果请求没有被确认,软件将拒绝请求并对热插拔控制器发出命令,重新开启电源指示灯。规范建议软件通过一条消息通知操作员请求被拒绝的原因。

    4. 如果请求被确认,热插拔服务程序将命令适配卡的设备驱动保持静默,也就是说驱动一方面必须停止向适配卡发出请求,另一方面必须完成或者终止所有已经发出的请求,并禁止适配卡产生新的事务(包括中断)。

    5. 软件发出命令,通过在插槽所连接的根端口或交换端口中的链接控制寄存器禁掉适配卡的链接。这使得链接两侧的端口均被禁止。

    6. 软件指示热插拔控制器禁掉插槽。

    7. 成功切断电源后,软件发出关闭电源指示灯命令。指示灯熄灭后,操作员可以开始安全地从插槽移出适配卡。打开插槽安全锁,热插拔控制器从插槽上撤除所有的信号(例如SMBus 和Vaux),此时卡可以被移出。

    8. 操作系统释放内存空间,I/O空间,中断线等曾经属于该设备的系统资源。

    Fedora下所采用热插拔实现的方式

    如果在最近一次编译中选择了PCI Express 热插拔功能,而且驱动是以模块方式存在,那么,可以在命令行下键入以下内容:

    modprobe pciehp

    如果驱动成功,则可以在/sys/bus/pci/slots/下面发现以可热插拔插槽编号命名的目录,进入相关目录,可以进行下一步操作。

    echo 1 >power开启某个插槽上的电源 ,进行热插入

    echo 0 >power关闭某个插槽上的电源,执行热拔出

    若不能加载pciehp驱动,一般是由于硬件不支持或者固件缺少OSHP方法或ACPI _OSC方法之一。

    六 linux2.6.12中PCIE驱动模型的变化

    在linux2.6.10中,Linux驱动程序模型要求物理设备被单独的驱动程序独占访问。 PCI Express端口是一个拥有许多独立功能的PCI-PCI桥设备,作为一个简洁的方案,每个功能要分别实现其自己的驱动程序,但是这样造成了多个驱动程序在唯一的PCI-PCI桥设备中出现竞争的状况。也就是说,虽然PCI Express提供了如Power Management (PME)、 Advanced Error Reporting (AER)、 Hot-Plug (HP) 和Virtual Channel (VC) access等多种功能,但是如果某个PCI Express端口的native hotplug 驱动程序加载后,它就会独占这个PCI-PCI桥的端口,内核就不能再于其上加载其他功能的驱动程序了。为解决这个问题,在Linux内核版本2.6.12中,PCI Express的热插拔又有所改变,提出了PCI Express 端口总线驱动程序(PCI Express Port Bus Driver)的概念。

    在实现上,PCI Express 端口总线驱动程序管理主板上的所有PCI Express 端口,并且把所有提供的服务请求发送到对应的服务驱动程序上。其优点概括如下:

    • 允许多个服务驱动程序在一个PCI-PCI桥端口设备上同步运行。
    • 允许各个服务驱动程序相互不受干扰地独立实现。
    • 允许一个服务驱动程序在多个PCI-PCI桥端口设备上运行。
    • 管理PCI-PCI桥端口设备资源并分发它们到发出请求的服务驱动程序。

    例如,在注册热插拔驱动程序时,不再使用pci_register_driver直接向系统注册,而是使用int pcie_port_service_register(struct pcie_port_service_driver *new) 向端口总线驱动程序注册;在注销热插拔驱动程序时,不再使用pci_unregister_driver直接向系统注销,而是使用void pcie_port_service_unregister(struct pcie_port_service_driver *new)来向端口总线驱动程序注销;而端口总线驱动程序是直接注册注销到系统的。

    目前,PCI Express 端口总线驱动程序模型还在发展演变中。

    七 评估与总结

    根据可用性理论,系统的可用度可以使用下列公式来计算:

    在高负荷运转的服务器上,商用可靠性的元件的故障更换并非小概率事件,对于更换故障元件和升级配件这样的事件,没有热插拔支持的系统必须停机断电进行处理,而具备热插拔支持的系统则仅仅需要很少的软件切换和拔插时间开销。从上面的公式我们可以看出,MTTR值越小,系统的可用性就越高。我们定义了一个比例因子V,V= MTTRnoHP/MTTRHP,根据业界经验,V的取值一般在10-100之间。描述可用性的一种常用的方法是使用"9"。如三个 9 表示 99.9% 的可用性,它表示一年大约有 8.5 小时的服务中断期。四个 9 (99.99%) 是更高一级的可用性,表示一年大约有 1 小时的服务中断期。根据可用度公式计算,在单个元件可靠度不变的情况下,Linux操作系统对PCI Express热插拔的支持,可以使服务器系统的外设相关可用性跃升一个等级(1个9),同时,PCI Express热插拔技术使得在线更换和升级PCI Express外设板卡成为可能,这使系统获得了良好的可扩展性。

    综上所述,本文讨论了PCI Express热插拔所涉及的软件因素,分析了linux2.6.10的PCI Express插槽热插拔功能PCIEHP子系统,并对热插拔支持在提高服务器系统外设相关可用性的作用进行了定量的分析。 为了继续提高操作系统可用性和可扩展性支持能力,Linux PCI Express hotplug以下方面还有待发展:继续完善热插拔架构的开放性,以提供完整统一的接口供驱动开发人员编写其他设备的热插拔支持模块;在插槽热插拔之外,提供对Server IO Module(SIOM)热插拔的支持;完善热替换和热升级技术。这些问题都是非常具有挑战性的。

    展开全文
  • 服务器、网络交换机、冗余存储磁盘阵列(RAID),以及其它形式的通信基础设施等高可用性系统,需要在整个使用生命周期内具有接 近零的... 这个过程被称为热插拔(hot swapping)(当模块与系统软件有相互作用时,也被称为hot
  • 凌特公司日前推出的新型四电源热插拔(Hot SwapTM)控制器LTC4245具有8位片上ADC和I2C兼容接口。LTC4245拥有支持3.3V、5V和±12V CompactPCI或12V、3.3V和辅助3.3V PCI Express的灵活性,通过测量板卡电压、电流和...
  • 热插拔 (Hot Swap) 即带电插拔,指的是在不关闭系统电源的情况下,将模块、板卡插入或拔出系统而不影系统的正常工作,从而提高了系统的可靠性、快速维修性、冗余性和对灾难的及时恢复能力等。对于大功率模块化电源...
  • openwrt USB外挂U盘的时候很需要热插拔功能 openwrt官网传送门 当某些事件发生时,Procd(init系统和进程管理守护进程)执行位于/etc/hotplug.d/中的脚本,例如当接口启动或关闭时,检测到新的存储驱动器时,或者...
  • 热插拔保护电路

    2020-06-06 06:58:15
    热插拔保护电路主要功能: 软起动:即当板子插入时,通过延缓启动时间,降低瞬间电压/电流对后续电路的冲击 保护电路:OTP/OCP/OVP https://wenku.baidu.com/view/447871f6ba0d4a7302763a9d.html
  • 凌力尔特公司(Linear Technology Corporation)推出LTC4308和LTC4309,这扩展了I²C和SMBus...这两个都可热插拔的两线总线缓冲器在I/O卡插入带电背板时防止信号讹误,并按照I²C和SMBus规范提供容性隔离。 LTC4308 和
  • HDMI热插拔检测原理

    2017-12-19 17:37:52
    HDMI(19Pin)/DVI(16 pin)的功能热插拔检测(HPD),这个信号将作为主机系统是否对HDMI/DVI是否发送TMDS信号的依据。HPD是从显示器输出送往计算机主机的一个检测信号。热插拔检测的作用是当显示器等数字显示器...
  • MAX5976A/MAX5976B为完全集成的解决方案,适用于需要在带电背板上安全插入、拔出电路板卡的热插拔应用。器件在单芯片封装内集成了热插拔控制器、24mΩ功率MOSFET以及电子断路器保护。IC设计用于2.7V至18V电源保护。 ...
  • Summit Microelectronics公司推出业界首款可编程双路供电可热插拔控制器SMH4814,可监控两个独立的-48V电源,允许冗余电源控制。 设计人员可采用该公司基于GUI的非易失编程技术使SMH4814满足特定的功率管理和控制...
  • 在Web开发中,比较郁闷的事情是修改源码之后,需要重新编译整个项目,然后重启web服务器。...本文将向你展示如何使Spring Boot的Web应用具有热插拔功能(在Eclipse/STS中设置)。 1.下载spring-loaded
  • 凌力尔特公司(Linear Technology Corporation)推出 LTC4308 和 LTC4309,这扩展了 I2C 和 SMBus 总线缓冲器与上升...这两个都可热插拔的两线总线缓冲器在 I/O 卡插入带电背板时防止信号讹误,并按照 I2C 和 SMBus 规范
  • 一种版本具有热插拔功能,一种版本是焊接PCB。 热插拔板同时使用北,南和90度旋转开关,这可能会导致某些键帽的兼容性问题。 地位: 在QMK和VIA主要分支机构进行了测试和实施。 一些功能: QMK和威盛 USB-C QFN...
  • 凌力尔特公司 (Linear Technology Corporation) 推出 LTC4308 和 LTC4309,这扩展了 I2C 和 SMBus 总线缓冲器与上升时间...这两个都可热插拔的两线总线缓冲器在 I/O 卡插入带电背板时防止信号讹误,并按照 I2C 和 SMBus

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 13,800
精华内容 5,520
关键字:

具有热插拔功能