CN113867812B - 一种bmc获取链路信息的方法、系统、设备以及介质 - Google Patents
一种bmc获取链路信息的方法、系统、设备以及介质 Download PDFInfo
- Publication number
- CN113867812B CN113867812B CN202111007703.3A CN202111007703A CN113867812B CN 113867812 B CN113867812 B CN 113867812B CN 202111007703 A CN202111007703 A CN 202111007703A CN 113867812 B CN113867812 B CN 113867812B
- Authority
- CN
- China
- Prior art keywords
- register
- link
- negotiation
- bios
- link negotiation
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 27
- 230000004044 response Effects 0.000 claims abstract description 67
- 238000001514 detection method Methods 0.000 claims description 13
- 238000004590 computer program Methods 0.000 claims description 9
- 238000010586 diagram Methods 0.000 description 5
- 230000006870 function Effects 0.000 description 5
- 238000004891 communication Methods 0.000 description 3
- 238000013461 design Methods 0.000 description 3
- 230000009466 transformation Effects 0.000 description 3
- 238000000844 transformation Methods 0.000 description 3
- 230000014509 gene expression Effects 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000002159 abnormal effect Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000008569 process Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/4401—Bootstrapping
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本发明公开了一种BMC获取链路信息的方法,包括以下步骤:对设备的链路进行协商;响应于BIOS启动,检测所述设备的链路协商状态;响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。本发明还公开了一种系统、计算机设备以及可读存储介质。本发明提出的技术方案能够在BIOS启动完成后,查询设备的链路协商信息,能够适用于大多数x86系统的应用,并且可以在出现链路连接问题时便于分析。
Description
技术领域
本发明涉及BMC领域,具体涉及一种BMC获取链路信息的方法、系统、设备以及存储介质。
背景技术
BIOS是服务器和存储产品主板正常工作的前提条件,基础功能的实现有赖于BIOS的设计,开放功能接口,实现主板强大的通信和控制功能。BIOS文件存放于南桥芯片下挂的spi flash中,南桥正常工作后通过加载flash里面的BIOS,正常启动x86系统。
BMC是整个存储或服务器单板的大管家,从一款服务器上电时刻,它的所有部件都归BMC来负责和管理。但是目前BMC无法获取BIOS检测到链路协商信息。
发明内容
有鉴于此,为了克服上述问题的至少一个方面,本发明实施例提出一种BMC获取链路信息的方法,包括以下步骤:
对设备的链路进行协商;
响应于BIOS启动,检测所述设备的链路协商状态;
响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。
在一些实施例中,还包括:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
在一些实施例中,将链路协商信息记录到CPLD中的第一寄存器中,进一步包括:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
在一些实施例中,还包括:
响应于所述协商失败次数达到阈值,认定所述设备的链路协商失败。
在一些实施例中,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种BMC获取链路信息的系统,包括:
协商模块,配置为对设备的链路进行协商;
检测模块,配置为响应于BIOS启动,检测所述设备的链路协商状态;
记录模块,配置为响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
写入模块,配置为响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
获取模块,配置为响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。
在一些实施例中,还包括更新模块,配置为:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
在一些实施例中,记录模块还配置为:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种计算机设备,包括:
至少一个处理器;以及
存储器,所述存储器存储有可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时执行以下步骤:
对设备的链路进行协商;
响应于BIOS启动,检测所述设备的链路协商状态;
响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。
在一些实施例中,还包括:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
在一些实施例中,将链路协商信息记录到CPLD中的第一寄存器中,进一步包括:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
在一些实施例中,还包括:
响应于所述协商失败次数达到阈值,认定所述设备的链路协商失败。
在一些实施例中,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时执行以下步骤:
对设备的链路进行协商;
响应于BIOS启动,检测所述设备的链路协商状态;
响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。
在一些实施例中,还包括:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
在一些实施例中,将链路协商信息记录到CPLD中的第一寄存器中,进一步包括:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
在一些实施例中,还包括:
响应于所述协商失败次数达到阈值,认定所述设备的链路协商失败。
在一些实施例中,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
本发明具有以下有益的技术效果:本发明的实施例提出的方案能够在BIOS启动完成后,查询设备的链路协商信息,能够适用于大多数x86系统的应用,并且可以在出现链路连接问题时便于分析。
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的实施例。
图1为本发明的实施例提供的BMC获取链路信息的方法的流程示意图;
图2为本发明的实施例提供的BMC获取CPU与PCIE switch之间的链路信息的结构框图;
图3为本发明的实施例提供的BMC获取链路信息的系统的结构示意图;
图4为本发明的实施例提供的计算机设备的结构示意图;
图5为本发明的实施例提供的计算机可读存储介质的结构示意图。
具体实施方式
为使本发明的目的、技术方案和优点更加清楚明白,以下结合具体实施例,并参照附图,对本发明实施例进一步详细说明。
需要说明的是,本发明实施例中所有使用“第一”和“第二”的表述均是为了区分两个相同名称非相同的实体或者非相同的参量,可见“第一”“第二”仅为了表述的方便,不应理解为对本发明实施例的限定,后续实施例对此不再一一说明。
在本发明的实施例中,BIOS是英文"Basic Input Output System"的缩略语,中文名称就是"基本输入输出系统"。它是一组固化到计算机内主板上一个ROM芯片上的程序,它保存着计算机最重要的基本输入输出的程序、系统设置信息、开机后自检程序和系统自启动程序。其主要功能是为计算机提供最底层的、最直接的硬件设置和控制,是系统正常启动的必须条件。
南桥芯片(South Bridge)是主板芯片组的重要组成部分,它主要负责控制主板的输入输出部分,如:硬盘,I/O接口等。
I2C(Inter-Integrated Circuit)总线是用于连接微控制器及其外围设备,两线――串行数据(SDA)和串行时钟(SCL)线在连接到总线的器件间传递信息。
CPLD(Complex Programmable Logic Device)指复杂可编程逻辑器件,是一种用户根据各自需要而自行构造逻辑功能的数字集成电路。其基本设计方法是借助集成开发软件平台,用原理图、硬件描述语言等方法,生成相应的目标文件,将其传送到目标芯片中,实现设计的数字系统。
BMC全称BaseboardManagement Controller,BMC是整个存储或服务器单板的大管家。从一款服务器上电时刻,它的所有部件都归BMC来负责和管理。
根据本发明的一个方面,本发明的实施例提出一种BMC获取链路信息的方法,如图1所示,其可以包括步骤:
S1,对设备的链路进行协商;
S2,响应于BIOS启动,检测所述设备的链路协商状态;
S3,响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
S4,响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
S5,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。
本发明的实施例提出的方案能够在BIOS启动完成后,可查询设备的链路协商信息,能够适用于大多数x86系统的应用,并且可以在出现链路连接问题时便于分析。
在一些实施例中,还包括:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
具体的,BIOS启动后,会进行PCIE设备的检测,判断是否有pcie device或者pciebridge存在。如果存在,则继续通过寄存器DL_ACTIVE判断Link Active状态,如果不存在则bios会继续启动。
如果Link Active状态为True,则判断link成功,BIOS记录link成功,如果LinkActive状态为False,则link失败,进行Retrain操作并通过寄存器RETRAIN_LINK记录retrain次数。每一次Retrain后重新检查Link Active状态,如果三次内重试Link Active为TRUE,则link成功,bios记录link成功及Retrain次数;最多Retrain三次(BIOS代码限定,次数可根据需求进行适当变更,次数过多可能会影响BIOS启动时间),如果Link Active都是为False,则判FAIL,BIOS记录link失败及Retrain次数。
在一些实施例中,还包括:
响应于所述协商失败次数达到阈值,认定所述设备的链路协商失败。
具体的,如果链路协商失败后进行重试且重试次数超过设定值认为该设备协商失败,重试次数超过设定值认为该设备协商失败,跳过对该设备检测或枚举(保证能正常开机)。
在一些实施例中,将链路协商信息记录到CPLD中的第一寄存器中,进一步包括:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
在一些实施例中,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
下面以获取CPU和PCIe Switch间PCIe链路协商信息为例并结合图2详细说明本发明的实施例提出的BMC获取链路信息的方法。
如图2所示,主板的南桥芯片、CPLD控制逻辑、BMC相互配合,共同完成CPU和PCIeSwitch间多条PCIe链路协商的次数记录工作,BIOS通过南桥I2C将BIOS启动完成标志和PCIe链路协商次数情况发送给CPLD,CPLD内部经过信息传递后,将BIOS启动完成标志和PCIe链路协商次数情况提供给BMC,BMC检测到bios启动完成后,在系统下可通过I2C读指令查询PCIe链路协商信息,得到链路协商信息后可选择性的将对应寄存器数据清零。
在BIOS正常加载并启动过程中,BIOS会检测CPU和PCIe Switch间PCIe链路协商情况,链路协商失败后进行重试,重试次数超过设定值认为该设备PCIe链路协商失败,并跳过对该设备检测或枚举(保证能正常开机)。
南桥的I2C控制模块可做为I2C通讯的主设备,BIOS将协商日志通过南桥I2C发送给CPLD为BIOS提供的相关寄存器中,同时也会发送BIOS启动完成标志到对应寄存器;
CPLD作为南桥I2C的从设备,逻辑代码内部集成BIOS寄存器模块,提供给南桥若干可进行读写的寄存器,指定若干个第一寄存器用来接收PCIe链路协商日志,第二寄存器接收bios启动完成标志;
CPLD作为BMC I2C的从设备,逻辑代码内部集成BMC寄存器模块,提供给BMC若干可进行读写的寄存器,指定其中一个寄存器第三寄存器用来接收PCIe链路协商日志、BIOS启动完成标志。
CPLD内部通过代码可实现CPLD的BIOS寄存器将PCIe链路协商信息和BIOS启动完成标志传递给CPLD的BMC寄存器。
BMC的I2C控制模块也可做为I2C通讯的主设备,BMC正常启动工作后,可在BMC系统下通过I2C读指令读取CPLD的BMC寄存器。当BMC检测到BIOS启动完成后,读取相应寄存器的PCIe链路协商信息并保存到日志中,用来分析异常情况下的PCIe链路协商情况,并选择性的将对应寄存器数据清零。
本发明提出的方案通过BIOS检测链路协商情况,链路协商失败后进行重试,重试次数超过设定值认为该设备PCIe链路协商失败,并跳过对该设备检测或枚举(保证能正常开机)。南桥通过I2C总线传输BIOS启动完成标志和PCIe链路协商信息到CPLD的BIOS寄存器;CPLD的BIOS寄存器模块收到BIOS启动完成标志和PCIe链路协商信息后,将其传递给CPLD的BMC寄存器模块,CPLD的BMC寄存器模块收到BIOS启动完成标志后,检测PCIe链路协商信息并保存到日志中,出现PCIe问题时便于查询分析。
需要特别指出的是,上述BMC获取链路信息的方法的各个实施例中的各个步骤均可以相互交叉、替换、增加、删减,因此,这些合理的排列组合变换之于BMC获取链路信息的方法也应当属于本发明的保护范围,并且不应将本发明的保护范围局限在实施例之上。
基于同一发明构思,根据本发明的另一个方面,本发明的实施例还提供了一种BMC获取链路信息的系统400,如图3所示,包括:
协商模块401,配置为对设备的链路进行协商;
检测模块402,配置为响应于BIOS启动,检测所述设备的链路协商状态;
记录模块403,配置为响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
写入模块404,配置为响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
获取模块405,配置为响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。
在一些实施例中,还包括更新模块,配置为:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
在一些实施例中,记录模块还配置为:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
在一些实施例中,还包括:
响应于所述协商失败次数达到阈值,认定所述设备的链路协商失败。
在一些实施例中,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
本发明提出的方案通过BIOS检测链路协商情况,链路协商失败后进行重试,重试次数超过设定值认为该设备PCIe链路协商失败,并跳过对该设备检测或枚举(保证能正常开机)。南桥通过I2C总线传输BIOS启动完成标志和PCIe链路协商信息到CPLD的BIOS寄存器;CPLD的BIOS寄存器模块收到BIOS启动完成标志和PCIe链路协商信息后,将其传递给CPLD的BMC寄存器模块,CPLD的BMC寄存器模块收到BIOS启动完成标志后,检测PCIe链路协商信息并保存到日志中,出现PCIe问题时便于查询分析。
基于同一发明构思,根据本发明的另一个方面,如图4所示,本发明的实施例还提供了一种计算机设备501,包括:
至少一个处理器520;以及
存储器510,存储器510存储有可在处理器上运行的计算机程序511,处理器520执行程序时执行以下步骤:
S1,对设备的链路进行协商;
S2,响应于BIOS启动,检测所述设备的链路协商状态;
S3,响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
S4,响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
S5,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。
在一些实施例中,还包括:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
在一些实施例中,将链路协商信息记录到CPLD中的第一寄存器中,进一步包括:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
在一些实施例中,还包括:
响应于所述协商失败次数达到阈值,认定所述设备的链路协商失败。
在一些实施例中,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
本发明提出的方案通过BIOS检测链路协商情况,链路协商失败后进行重试,重试次数超过设定值认为该设备PCIe链路协商失败,并跳过对该设备检测或枚举(保证能正常开机)。南桥通过I2C总线传输BIOS启动完成标志和PCIe链路协商信息到CPLD的BIOS寄存器;CPLD的BIOS寄存器模块收到BIOS启动完成标志和PCIe链路协商信息后,将其传递给CPLD的BMC寄存器模块,CPLD的BMC寄存器模块收到BIOS启动完成标志后,检测PCIe链路协商信息并保存到日志中,出现PCIe问题时便于查询分析。
需要特别指出的是,上述BMC获取链路信息的方法的各个实施例中的各个步骤均可以相互交叉、替换、增加、删减,因此,这些合理的排列组合变换之于BMC获取链路信息的方法也应当属于本发明的保护范围,并且不应将本发明的保护范围局限在实施例之上。
基于同一发明构思,根据本发明的另一个方面,如图5所示,本发明的实施例还提供了一种计算机可读存储介质601,计算机可读存储介质601存储有计算机程序指令610,计算机程序指令610被处理器执行时执行以下步骤:
S1,对设备的链路进行协商;
S2,响应于BIOS启动,检测所述设备的链路协商状态;
S3,响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
S4,响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
S5,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息。
在一些实施例中,还包括:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
在一些实施例中,将链路协商信息记录到CPLD中的第一寄存器中,进一步包括:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
在一些实施例中,还包括:
响应于所述协商失败次数达到阈值,认定所述设备的链路协商失败。
在一些实施例中,响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
本发明提出的方案通过BIOS检测链路协商情况,链路协商失败后进行重试,重试次数超过设定值认为该设备PCIe链路协商失败,并跳过对该设备检测或枚举(保证能正常开机)。南桥通过I2C总线传输BIOS启动完成标志和PCIe链路协商信息到CPLD的BIOS寄存器;CPLD的BIOS寄存器模块收到BIOS启动完成标志和PCIe链路协商信息后,将其传递给CPLD的BMC寄存器模块,CPLD的BMC寄存器模块收到BIOS启动完成标志后,检测PCIe链路协商信息并保存到日志中,出现PCIe问题时便于查询分析。
需要特别指出的是,上述BMC获取链路信息的方法的各个实施例中的各个步骤均可以相互交叉、替换、增加、删减,因此,这些合理的排列组合变换之于BMC获取链路信息的方法也应当属于本发明的保护范围,并且不应将本发明的保护范围局限在实施例之上。
最后需要说明的是,本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关硬件来完成,程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。
此外,应该明白的是,本文的计算机可读存储介质(例如,存储器)可以是易失性存储器或非易失性存储器,或者可以包括易失性存储器和非易失性存储器两者。
本领域技术人员还将明白的是,结合这里的公开所描述的各种示例性逻辑块、模块、电路和算法步骤可以被实现为电子硬件、计算机软件或两者的组合。为了清楚地说明硬件和软件的这种可互换性,已经就各种示意性组件、方块、模块、电路和步骤的功能对其进行了一般性的描述。这种功能是被实现为软件还是被实现为硬件取决于具体应用以及施加给整个系统的设计约束。本领域技术人员可以针对每种具体应用以各种方式来实现的功能,但是这种实现决定不应被解释为导致脱离本发明实施例公开的范围。
以上是本发明公开的示例性实施例,但是应当注意,在不背离权利要求限定的本发明实施例公开的范围的前提下,可以进行多种改变和修改。根据这里描述的公开实施例的方法权利要求的功能、步骤和/或动作不需以任何特定顺序执行。此外,尽管本发明实施例公开的元素可以以个体形式描述或要求,但除非明确限制为单数,也可以理解为多个。
应当理解的是,在本文中使用的,除非上下文清楚地支持例外情况,单数形式“一个”旨在也包括复数形式。还应当理解的是,在本文中使用的“和/或”是指包括一个或者一个以上相关联地列出的项目的任意和所有可能组合。
上述本发明实施例公开实施例序号仅仅为了描述,不代表实施例的优劣。
本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
所属领域的普通技术人员应当理解:以上任何实施例的讨论仅为示例性的,并非旨在暗示本发明实施例公开的范围(包括权利要求)被限于这些例子;在本发明实施例的思路下,以上实施例或者不同实施例中的技术特征之间也可以进行组合,并存在如上的本发明实施例的不同方面的许多其它变化,为了简明它们没有在细节中提供。因此,凡在本发明实施例的精神和原则之内,所做的任何省略、修改、等同替换、改进等,均应包含在本发明实施例的保护范围之内。
Claims (9)
1.一种BMC获取链路信息的方法,其特征在于,包括以下步骤:
对设备的链路进行协商;
响应于BIOS启动,检测所述设备的链路协商状态;
响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,
其中响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
2.如权利要求1所述的方法,其特征在于,还包括:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
3.如权利要求2所述的方法,其特征在于,将链路协商信息记录到CPLD中的第一寄存器中,进一步包括:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
4.如权利要求2所述的方法,其特征在于,还包括:
响应于所述协商失败次数达到阈值,认定所述设备的链路协商失败。
5.一种BMC获取链路信息的系统,其特征在于,包括:
协商模块,配置为对设备的链路进行协商;
检测模块,配置为响应于BIOS启动,检测所述设备的链路协商状态;
记录模块,配置为响应于检测到所述设备的链路协商成功,将链路协商信息记录到CPLD中的第一寄存器中;
写入模块,配置为响应于所述BIOS启动成功,将所述BIOS启动成功标识写入到所述CPLD的第二寄存器中;
获取模块,配置为响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,
其中响应于BMC检测到所述第二寄存器中的所述BIOS启动标识,从所述第一寄存器获取所述链路协商信息,进一步包括:
所述CPLD将所述第一寄存器中的链路协商信息和所述第二寄存器中的BIOS启动标识写入到第三寄存器;
响应于BMC检测到所述第三寄存器中的所述BIOS启动标识,从所述第三寄存器获取所述链路协商信息。
6.如权利要求5所述的系统,其特征在于,还包括更新模块,配置为:
响应于检测到所述设备的链路协商失败,更新协商失败次数;
判断所述协商失败次数是否达到阈值;
响应于所述协商失败次数未达到阈值,重新对所述设备进行链路协商。
7.如权利要求6所述的系统,其特征在于,记录模块还配置为:
将所述设备的链路协商成功标识以及所述协商失败次数更新到所述第一寄存器中。
8.一种计算机设备,包括:
至少一个处理器;以及
存储器,所述存储器存储有可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时执行如权利要求1-4任意一项所述的方法的步骤。
9.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时执行如权利要求1-4任意一项所述的方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111007703.3A CN113867812B (zh) | 2021-08-30 | 2021-08-30 | 一种bmc获取链路信息的方法、系统、设备以及介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111007703.3A CN113867812B (zh) | 2021-08-30 | 2021-08-30 | 一种bmc获取链路信息的方法、系统、设备以及介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113867812A CN113867812A (zh) | 2021-12-31 |
CN113867812B true CN113867812B (zh) | 2023-08-04 |
Family
ID=78988748
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111007703.3A Active CN113867812B (zh) | 2021-08-30 | 2021-08-30 | 一种bmc获取链路信息的方法、系统、设备以及介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113867812B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114911740B (zh) * | 2022-06-02 | 2024-06-28 | 中国长城科技集团股份有限公司 | PCIe拆分方法、装置、电子设备及可读存储介质 |
Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112463222A (zh) * | 2020-11-11 | 2021-03-09 | 苏州浪潮智能科技有限公司 | 一种服务器bios与bmc之间的数据交互方法、装置及设备 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10572434B2 (en) * | 2017-02-27 | 2020-02-25 | International Business Machines Corporation | Intelligent certificate discovery in physical and virtualized networks |
-
2021
- 2021-08-30 CN CN202111007703.3A patent/CN113867812B/zh active Active
Patent Citations (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112463222A (zh) * | 2020-11-11 | 2021-03-09 | 苏州浪潮智能科技有限公司 | 一种服务器bios与bmc之间的数据交互方法、装置及设备 |
Also Published As
Publication number | Publication date |
---|---|
CN113867812A (zh) | 2021-12-31 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US8468389B2 (en) | Firmware recovery system and method of baseboard management controller of computing device | |
US7430662B2 (en) | Techniques for initializing a device on an expansion card | |
US8132055B2 (en) | Operating system-firmware interface update recovery | |
US7900036B2 (en) | System and method for implementing boot/recovery on a data processing sysem | |
WO2016206514A1 (zh) | 启动处理方法及装置 | |
CN106547653B (zh) | 计算机系统故障状态检测方法、装置及系统 | |
US10824517B2 (en) | Backup and recovery of configuration files in management device | |
CN116932010B (zh) | 系统固件升级方法、装置及服务器 | |
TW201712543A (zh) | 伺服器故障檢測裝置及方法 | |
CN113867812B (zh) | 一种bmc获取链路信息的方法、系统、设备以及介质 | |
TWI755184B (zh) | 電子裝置及其開機方法 | |
CN114265603A (zh) | 基于不对称分区的系统升级方法、装置和电子设备 | |
CN114579971A (zh) | 一种安全控制模组的启动方法及相关装置 | |
CN113672306A (zh) | 服务器组件自检异常恢复方法、装置、系统及介质 | |
CN106909382B (zh) | 输出不同类型系统启动信息的方法及装置 | |
CN115904831A (zh) | 一种服务器固件的启动方法及终端 | |
CN115098342A (zh) | 系统日志收集方法、系统、终端及存储介质 | |
CN115168146A (zh) | 一种异常检测方法和装置 | |
US11249661B2 (en) | Information processing apparatus, control method, and program | |
KR100907550B1 (ko) | 시리얼 eeprom의 손상된 데이터를 복구하기 위한장치 및 방법 | |
CN111783162A (zh) | 数据保护实现方法、装置及计算机设备 | |
CN115408204A (zh) | 芯片双固件备份启动方法、装置、电子设备及存储介质 | |
CN118467240A (zh) | 重定时器的故障排除方法 | |
JP2001222421A (ja) | フラッシュromカード、フラッシュrom、およびbios更新方法 | |
CN118093240A (zh) | 硬盘故障处理方法、装置、计算机设备、存储介质及程序产品 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |