CN111682991A - 总线错误消息的处理方法及装置 - Google Patents
总线错误消息的处理方法及装置 Download PDFInfo
- Publication number
- CN111682991A CN111682991A CN202010470150.4A CN202010470150A CN111682991A CN 111682991 A CN111682991 A CN 111682991A CN 202010470150 A CN202010470150 A CN 202010470150A CN 111682991 A CN111682991 A CN 111682991A
- Authority
- CN
- China
- Prior art keywords
- error message
- bus error
- pcie
- return value
- function
- 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.)
- Granted
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L2012/40208—Bus networks characterized by the use of a particular bus standard
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Debugging And Monitoring (AREA)
Abstract
本公开涉及一种总线错误消息的处理方法、装置、电子设备及计算机可读介质。该处理方法包括:在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;调用所述回调函数生成返回值;根据所述返回值进行所述总线错误消息的处理。本公开涉及的总线错误消息的处理方法、装置、电子设备及计算机可读介质,能够在出现PCIe总线错误消息的情况下恢复驱动程序的执行,最大程度的提高驱动代码以及整个系统的可靠性。
Description
技术领域
本公开涉及计算机信息处理领域,具体而言,涉及一种总线错误消息的处理方法、装置、电子设备及计算机可读介质。
背景技术
PCIe总线作为一种系统总线,在设计上经常把PCIe设备的特定寄存器直接映射到CPU的地址空间,这样驱动程序可以像访问内存一样直接访问PCIe设备的寄存器,并且PCIe设备也可以作为总线主(BusMaster)发起DMA操作去访问CPURAM,可以大大提高了数据处理的效率。虽然说把PCIe设备寄存器映射到CPU地址空间是一个好的设计,但某些情况下这样设计有可能出现问题。例如在PCIe接口的板卡被突然拔出时,链路会断开或者PCIe设备出现问题无法响应,如果在这个时候有驱动程序正在访问PCIe设备的寄存器,就会出现总线错误,触发异常,后果如何有可能无法预料。
现有技术中,在由于PCIe设备触发CPU的总线错误异常时,一般是由操作系统或者bootloader接管当前流程,但是接管之后如何处理并不确定,操作系统或者bootloader很可能会复位系统以进行恢复,但很多情况下总线错误并不致命,不一定需要这样做。
因此,需要一种新的总线错误消息的处理方法、装置、电子设备及计算机可读介质。
在所述背景技术部分公开的上述信息仅用于加强对本公开的背景的理解,因此它可以包括不构成对本领域普通技术人员已知的现有技术的信息。
发明内容
有鉴于此,本公开提供一种总线错误消息的处理方法、装置、电子设备及计算机可读介质,能够在出现PCIe总线错误消息的情况下恢复驱动程序的执行,最大程度的提高驱动代码以及整个系统的可靠性。
本公开的其他特性和优点将通过下面的详细描述变得显然,或部分地通过本公开的实践而习得。
根据本公开的一方面,提出一种总线错误消息的处理方法,该方法包括:在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;调用所述回调函数生成返回值;根据所述返回值进行所述总线错误消息的处理。
在本公开的一种示例性实施例中,还包括:在系统内核启动时,PCIe系统申请用于存储PCIe异常处理表的内存;其中,所述PCIe系统中包括多个PCIe设备。
在本公开的一种示例性实施例中,还包括:在PCIe设备驱动初始化时,将其相关的多个处理函数作为表项注册到所述PCIe异常处理表;其中,多个处理函数包括:读操作函数、读异常处理函数、写操作函数、写异常处理函数。
在本公开的一种示例性实施例中,还包括:根据自定义操作生成所述读异常处理函数和所述写异常处理函数。
在本公开的一种示例性实施例中,根据所述异常指令地址获取所述PCIe设备的异常处理回调函数,包括:根据所述异常指令地址在所述PCIe异常处理表中进行检索,获取所述异常处理回调函数。
在本公开的一种示例性实施例中,调用所述回调函数生成返回值,包括:获取第一入参和第二入参;将所述第一入参和所述第二入参传入所述异常处理回调函数以获取产生所述总线错误消息对应的PCIe设备地址;基于所述异常处理回调函数和所述总线错误消息对应的PCIe设备地址生成返回值。
在本公开的一种示例性实施例中,获取第一入参和第二入参,包括:将所述总线错误消息的异常上下文以作为所述第一入参;将所述异常指令地址作为所述第二入参。
在本公开的一种示例性实施例中,基于所述异常处理回调函数和所述总线错误消息对应的PCIe设备地址生成返回值,包括:获取所述异常处理函数中的修复函数;基于所述修复函数对所述PCIe设备地址进行操作以生成所述返回值。
在本公开的一种示例性实施例中,基于所述修复函数对所述PCIe设备地址进行操作以生成所述返回值,包括:读取所述PCIe设备的寄存器状态,确定所述总线错误消息的原因;根据原因生成所述返回值。
在本公开的一种示例性实施例中,基于所述修复函数对所述PCIe设备地址进行操作以生成所述返回值,包括:复位所述PCIe设备以修复所述所述总线错误消息;根据修复结果生成所述返回值。
在本公开的一种示例性实施例中,根据所述返回值进行所述总线错误消息的处理,包括:在所述返回值为第一数值时,恢复所述总线错误消息的驱动代码执行流;在所述返回值为第二数值时,执行系统修复。
根据本公开的一方面,提出一种总线错误消息的处理装置,该装置包括:地址模块,用于在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;函数模块,用于根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;调用模块,用于调用所述回调函数生成返回值;处理模块,用于根据所述返回值进行所述总线错误消息的处理。
根据本公开的一方面,提出一种电子设备,该电子设备包括:一个或多个处理器;存储装置,用于存储一个或多个程序;当一个或多个程序被一个或多个处理器执行,使得一个或多个处理器实现如上文的方法。
根据本公开的一方面,提出一种计算机可读介质,其上存储有计算机程序,该程序被处理器执行时实现如上文中的方法。
根据本公开的总线错误消息的处理方法、装置、电子设备及计算机可读介质,在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;调用所述回调函数生成返回值;根据所述返回值进行所述总线错误消息的处理的方式,能够在出现PCIe总线错误消息的情况下恢复驱动程序的执行,最大程度的提高驱动代码以及整个系统的可靠性。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性的,并不能限制本公开。
附图说明
通过参照附图详细描述其示例实施例,本公开的上述和其它目标、特征及优点将变得更加显而易见。下面描述的附图仅仅是本公开的一些实施例,对于本领域的普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是根据一示例性实施例示出的一种总线错误消息的处理方法的流程图。
图2是根据另一示例性实施例示出的一种总线错误消息的处理方法的流程图。
图3是根据另一示例性实施例示出的一种总线错误消息的处理方法的流程图。
图4是根据另一示例性实施例示出的一种总线错误消息的处理方法的示意图。
图5是根据一示例性实施例示出的一种总线错误消息的处理装置的框图。
图6是根据一示例性实施例示出的一种电子设备的框图。
图7是根据一示例性实施例示出的一种计算机可读介质的框图。
具体实施方式
现在将参考附图更全面地描述示例实施例。然而,示例实施例能够以多种形式实施,且不应被理解为限于在此阐述的实施例;相反,提供这些实施例使得本公开将全面和完整,并将示例实施例的构思全面地传达给本领域的技术人员。在图中相同的附图标记表示相同或类似的部分,因而将省略对它们的重复描述。
此外,所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施例中。在下面的描述中,提供许多具体细节从而给出对本公开的实施例的充分理解。然而,本领域技术人员将意识到,可以实践本公开的技术方案而没有特定细节中的一个或更多,或者可以采用其它的方法、组元、装置、步骤等。在其它情况下,不详细示出或描述公知方法、装置、实现或者操作以避免模糊本公开的各方面。
附图中所示的方框图仅仅是功能实体,不一定必须与物理上独立的实体相对应。即,可以采用软件形式来实现这些功能实体,或在一个或多个硬件模块或集成电路中实现这些功能实体,或在不同网络和/或处理器装置和/或微控制器装置中实现这些功能实体。
附图中所示的流程图仅是示例性说明,不是必须包括所有的内容和操作/步骤,也不是必须按所描述的顺序执行。例如,有的操作/步骤还可以分解,而有的操作/步骤可以合并或部分合并,因此实际执行的顺序有可能根据实际情况改变。
应理解,虽然本文中可能使用术语第一、第二、第三等来描述各种组件,但这些组件不应受这些术语限制。这些术语乃用以区分一组件与另一组件。因此,下文论述的第一组件可称为第二组件而不偏离本公开概念的教示。如本文中所使用,术语“及/或”包括相关联的列出项目中的任一个及一或多者的所有组合。
本领域技术人员可以理解,附图只是示例实施例的示意图,附图中的模块或流程并不一定是实施本公开所必须的,因此不能用于限制本公开的保护范围。
图1是根据一示例性实施例示出的一种总线错误消息的处理方法的流程图。总线错误消息的处理方法10至少包括步骤S102至S108。
如图1所示,在S102中,在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址。
其中,PCIe:Peripheral Component Interconnect Express,一种高速串行计算机扩展总线标准,支持主动电源管理,错误报告,端对端的可靠性传输,热插拔以及服务质量(QoS)等功能。主要用于芯片与芯片或者板卡与板卡之间的高速数据通信,在PC,服务器以及通信电信(ICT)领域应用广泛。Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。
在本公开的实施例中,以PCIe设备运行在Linux系统上产生的总线错误消息的处理步骤为例,对本公开的思想进行阐述,但是本公开的解决问题的思想可以应该在其他系统和其他计算机扩展总线的错误处理方面,本公开不以此为限。
在S104中,根据所述异常指令地址获取所述PCIe设备的异常处理回调函数。更具体的,可根据所述异常指令地址在所述PCIe异常处理表中进行检索,获取所述异常处理回调函数。
其中,PCIe异常处理表是实现建立的,预存在Linux系统内存中的表格,表的大小由PCIe设备的数量决定,每个表项可包括两个字段,异常指令地址和异常回调函数。根据异常指令地址可在PCIe异常处理表中检索到期对应的异常回调函数。
在S106中,调用所述回调函数生成返回值。具体可例如,获取第一入参和第二入参;将所述第一入参和所述第二入参传入所述异常处理回调函数以获取产生所述总线错误消息对应的PCIe设备地址;基于所述异常处理回调函数和所述总线错误消息对应的PCIe设备地址生成返回值。其中,第一入参可为异常上下文,在Linux内核中为structpt_regs指针,第二入参可为引发异常的指令地址。
“调用所述回调函数生成返回值”的详细内容将在图3对应的实施例中进行说明。
在S108中,根据所述返回值进行所述总线错误消息的处理。回调函数的返回值确定是恢复发生异常前的驱动代码执行流,还是执行系统复位以修复PCIe设备的错误。
在一个实施例中,可例如,在所述返回值为第一数值时,恢复所述总线错误消息的驱动代码执行流;在一个实施例中,可例如,在所述返回值为第二数值时,执行系统修复。
在Linux系统正常运行情况下,回调函数不会执行。当Linux系统中的PCIe设备出现错误时,就会触发这些用户自定义的回调函数,以最大程度的修复错误,提高系统的健壮性。
根据本公开的总线错误消息的处理方法,在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;调用所述回调函数生成返回值;根据所述返回值进行所述总线错误消息的处理的方式,能够在出现PCIe总线错误消息的情况下恢复驱动程序的执行,最大程度的提高驱动代码以及整个系统的可靠性。
应清楚地理解,本公开描述了如何形成和使用特定示例,但本公开的原理不限于这些示例的任何细节。相反,基于本公开公开的内容的教导,这些原理能够应用于许多其它实施例。
图2是根据另一示例性实施例示出的一种总线错误消息的处理方法的流程图。图2所示的流程20是对图1所示的流程的补充描述。
如图2所示,在S202中,根据自定义操作生成读异常处理函数和写异常处理函数。驱动程序对PCIe寄存器的基本操作有读和写两种,两种操作通过单条指令就可以实现。更具体的,可用汇编指令实现读和写两个操作的函数;还可对应于读操作和写操作生成两个负责进行异常处理的回调函数。
在S204中,在系统内核启动时,PCIe系统申请用于存储PCIe异常处理表的内存。其中,所述PCIe系统中包括多个PCIe设备。可在Linux内核启动的时候,PCI系统申请一段内存作为PCIe异常处理表,异常处理表的大小由PCIe设备的数量决定,每个表项至少包括两个字段,异常指令地址和异常回调函数。
在S206中,在PCIe设备驱动初始化时,将其相关的多个处理函数作为表项注册到所述PCIe异常处理表。其中,多个处理函数包括:读操作函数、读异常处理函数、写操作函数、写异常处理函数。
可把读操作的函数地址和读操作异常处理回调函数的地址作为一个表项放入PCIe异常处理表里,再对写操作执行同样的操作。这样可以使得子啊PCIe设备出现错误时,驱动访问导致的异常,可以根据异常指令地址,从PCIe异常处理表里检索,找到并回调对应的回调函数。
图3是根据另一示例性实施例示出的一种总线错误消息的处理方法的流程图。图3所示的流程30是对图2所示的流程中S102“”的详细描述。
如图3所示,在S302中,将所述总线错误消息的异常上下文以作为所述第一入参。在Linux内核中,第一入参可为structpt_regs指针。
在S304中,将所述异常指令地址作为所述第二入参。
在S306中,将所述第一入参和所述第二入参传入所述异常处理回调函数以获取产生所述总线错误消息对应的PCIe设备地址。
在S308中,获取所述异常处理函数中的修复函数。修复函数可为用户自定义生成的,根据用户的自定义在调用修复函数时,可执行用户自定义的操作。
在S310中,基于所述修复函数对所述PCIe设备地址进行操作以生成所述返回值。在一个实施例中,可例如:读取所述PCIe设备的寄存器状态,确定所述总线错误消息的原因;根据原因生成所述返回值。在一个实施例中,可例如:复位所述PCIe设备以修复所述所述总线错误消息;根据修复结果生成所述返回值。
图4是根据另一示例性实施例示出的一种总线错误消息的处理方法的示意图。图4所示的流程40是对图2所示的流程的详细描述。如图4所示,在产生总线错误消息的时候,可传入两个参数,一个是异常上下文,另一个是引发异常的指令地址。回调函数可根据这两个参数找到出错的PCIe设备地址,之后可以根据用户的自动以进行用户自己定义的操作,例如读取状态寄存器,检测下错误的原因,甚至是通过复位PCIe设备去修复问题。如果无法修复可以返回特定的值,表示无法修复,交由操作系统处理。然后根据回调函数的返回值确定是恢复发生异常前的驱动代码执行流,还是执行系统复位以修复PCIe设备的错误。
在本公开的总线错误消息的处理方法,通过软件方式去捕获PCIe设备错误触发的异常,并尝试回调用户自定义的函数去修复错误,尽量避免通过复位方式解决,提高系统的健壮性。
本领域技术人员可以理解实现上述实施例的全部或部分步骤被实现为由CPU执行的计算机程序。在该计算机程序被CPU执行时,执行本公开提供的上述方法所限定的上述功能。所述的程序可以存储于一种计算机可读存储介质中,该存储介质可以是只读存储器,磁盘或光盘等。
此外,需要注意的是,上述附图仅是根据本公开示例性实施例的方法所包括的处理的示意性说明,而不是限制目的。易于理解,上述附图所示的处理并不表明或限制这些处理的时间顺序。另外,也易于理解,这些处理可以是例如在多个模块中同步或异步执行的。
下述为本公开装置实施例,可以用于执行本公开方法实施例。对于本公开装置实施例中未披露的细节,请参照本公开方法实施例。
图5是根据一示例性实施例示出的一种总线错误消息的处理装置的框图。如图5所示,总线错误消息的处理装置50包括:地址模块502,函数模块504,调用模块506,处理模块508。
地址模块502用于在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;
函数模块504用于根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;函数模块504还用于根据所述异常指令地址在所述PCIe异常处理表中进行检索,获取所述异常处理回调函数。
调用模块506用于调用所述回调函数生成返回值;调用模块506还用于获取第一入参和第二入参;将所述第一入参和所述第二入参传入所述异常处理回调函数以获取产生所述总线错误消息对应的PCIe设备地址;基于所述异常处理回调函数和所述总线错误消息对应的PCIe设备地址生成返回值。
处理模块508用于根据所述返回值进行所述总线错误消息的处理。处理模块508还用于在所述返回值为第一数值时,恢复所述总线错误消息的驱动代码执行流;处理模块508还用于在所述返回值为第二数值时,执行系统修复。
根据本公开的总线错误消息的处理装置,在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;调用所述回调函数生成返回值;根据所述返回值进行所述总线错误消息的处理的方式,能够在出现PCIe总线错误消息的情况下恢复驱动程序的执行,最大程度的提高驱动代码以及整个系统的可靠性。
图6是根据一示例性实施例示出的一种电子设备的框图。
下面参照图6来描述根据本公开的这种实施方式的电子设备600。图6显示的电子设备600仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图6所示,电子设备600以通用计算设备的形式表现。电子设备600的组件可以包括但不限于:至少一个处理单元610、至少一个存储单元620、连接不同系统组件(包括存储单元620和处理单元610)的总线630、显示单元640等。
其中,所述存储单元存储有程序代码,所述程序代码可以被所述处理单元610执行,使得所述处理单元610执行本说明书上述电子处方流转处理方法部分中描述的根据本公开各种示例性实施方式的步骤。例如,所述处理单元610可以执行如图1,图2,图3中所示的步骤。
所述存储单元620可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(RAM)6201和/或高速缓存存储单元6202,还可以进一步包括只读存储单元(ROM)6203。
所述存储单元620还可以包括具有一组(至少一个)程序模块6205的程序/实用工具6204,这样的程序模块6205包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
总线630可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理单元或者使用多种总线结构中的任意总线结构的局域总线。
电子设备600也可以与一个或多个外部设备600’(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该电子设备600交互的设备通信,和/或与使得该电子设备600能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口650进行。并且,电子设备600还可以通过网络适配器660与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。网络适配器660可以通过总线630与电子设备600的其它模块通信。应当明白,尽管图中未示出,可以结合电子设备600使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,如图7所示,根据本公开实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、或者网络设备等)执行根据本公开实施方式的上述方法。
所述软件产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以为但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
所述计算机可读存储介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。可读存储介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。可读存储介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、有线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言的任意组合来编写用于执行本公开操作的程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、C++等,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(LAN)或广域网(WAN),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该设备执行时,使得该计算机可读介质实现如下功能:在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;调用所述回调函数生成返回值;根据所述返回值进行所述总线错误消息的处理。
本领域技术人员可以理解上述各模块可以按照实施例的描述分布于装置中,也可以进行相应变化唯一不同于本实施例的一个或多个装置中。上述实施例的模块可以合并为一个模块,也可以进一步拆分成多个子模块。
通过以上的实施例的描述,本领域的技术人员易于理解,这里描述的示例实施例可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本公开实施例的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、移动终端、或者网络设备等)执行根据本公开实施例的方法。
以上具体地示出和描述了本公开的示例性实施例。应可理解的是,本公开不限于这里描述的详细结构、设置方式或实现方法;相反,本公开意图涵盖包含在所附权利要求的精神和范围内的各种修改和等效设置。
Claims (12)
1.一种总线错误消息的处理方法,其特征在于,包括:
在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;
根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;
调用所述回调函数生成返回值;
根据所述返回值进行所述总线错误消息的处理。
2.如权利要求1所述的处理方法,其特征在于,还包括:
在系统内核启动时,PCIe系统申请用于存储PCIe异常处理表的内存;
其中,所述PCIe系统中包括多个PCIe设备。
3.如权利要求2所述的处理方法,其特征在于,还包括:
在PCIe设备驱动初始化时,将其相关的多个处理函数作为表项注册到所述PCIe异常处理表;
其中,多个处理函数包括:读操作函数、读异常处理函数、写操作函数、写异常处理函数。
4.如权利要求3所述的处理方法,其特征在于,还包括:
根据自定义操作生成所述读异常处理函数和所述写异常处理函数。
5.如权利要求2所述的处理方法,其特征在于,根据所述异常指令地址获取所述PCIe设备的异常处理回调函数,包括:
根据所述异常指令地址在所述PCIe异常处理表中进行检索,获取所述异常处理回调函数。
6.如权利要求1所述的处理方法,其特征在于,调用所述回调函数生成返回值,包括:
获取第一入参和第二入参;
将所述第一入参和所述第二入参传入所述异常处理回调函数以获取产生所述总线错误消息对应的PCIe设备地址;
基于所述异常处理回调函数和所述总线错误消息对应的PCIe设备地址生成返回值。
7.如权利要求6所述的处理方法,其特征在于,获取第一入参和第二入参,包括:
将所述总线错误消息的异常上下文以作为所述第一入参;
将所述异常指令地址作为所述第二入参。
8.如权利要求6所述的处理方法,其特征在于,基于所述异常处理回调函数和所述总线错误消息对应的PCIe设备地址生成返回值,包括:
获取所述异常处理函数中的修复函数;
基于所述修复函数对所述PCIe设备地址进行操作以生成所述返回值。
9.如权利要求8所述的处理方法,其特征在于,基于所述修复函数对所述PCIe设备地址进行操作以生成所述返回值,包括:
读取所述PCIe设备的寄存器状态,确定所述总线错误消息的原因;
根据原因生成所述返回值。
10.如权利要求8所述的处理方法,其特征在于,基于所述修复函数对所述PCIe设备地址进行操作以生成所述返回值,包括:
复位所述PCIe设备以修复所述所述总线错误消息;
根据修复结果生成所述返回值。
11.如权利要求1所述的处理方法,其特征在于,根据所述返回值进行所述总线错误消息的处理,包括:
在所述返回值为第一数值时,恢复所述总线错误消息的驱动代码执行流;
在所述返回值为第二数值时,执行系统修复。
12.一种总线错误消息的处理装置,其特征在于,包括:
地址模块,用于在读写PCIe设备产生总线错误消息时,获取所述总线错误消息对应的异常指令地址;
函数模块,用于根据所述异常指令地址获取所述PCIe设备的异常处理回调函数;
调用模块,用于调用所述回调函数生成返回值;
处理模块,用于根据所述返回值进行所述总线错误消息的处理。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010470150.4A CN111682991B (zh) | 2020-05-28 | 2020-05-28 | 总线错误消息的处理方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010470150.4A CN111682991B (zh) | 2020-05-28 | 2020-05-28 | 总线错误消息的处理方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111682991A true CN111682991A (zh) | 2020-09-18 |
CN111682991B CN111682991B (zh) | 2022-08-12 |
Family
ID=72453027
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010470150.4A Active CN111682991B (zh) | 2020-05-28 | 2020-05-28 | 总线错误消息的处理方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111682991B (zh) |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101539883A (zh) * | 2009-05-05 | 2009-09-23 | 北京和利时系统工程有限公司 | 嵌入式系统的错误追踪方法和装置 |
CN105988905A (zh) * | 2015-02-12 | 2016-10-05 | 中兴通讯股份有限公司 | 异常处理方法及装置 |
CN108111328A (zh) * | 2016-11-24 | 2018-06-01 | 腾讯科技(深圳)有限公司 | 一种异常处理方法及装置 |
CN109918230A (zh) * | 2019-02-20 | 2019-06-21 | 杭州迪普科技股份有限公司 | 一种业务板卡异常恢复方法及系统 |
CN109977061A (zh) * | 2017-12-28 | 2019-07-05 | 中兴通讯股份有限公司 | 一种中断处理方法及中断处理装置 |
US10437754B1 (en) * | 2016-09-23 | 2019-10-08 | Amazon Technologies, Inc. | Diagnostic fault management controller for distributed computing |
CN110519098A (zh) * | 2019-08-30 | 2019-11-29 | 新华三信息安全技术有限公司 | 一种异常单板的处理方法及装置 |
CN110955598A (zh) * | 2019-11-20 | 2020-04-03 | 杭州迪普科技股份有限公司 | 一种内核态程序的断点处理方法及装置 |
-
2020
- 2020-05-28 CN CN202010470150.4A patent/CN111682991B/zh active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101539883A (zh) * | 2009-05-05 | 2009-09-23 | 北京和利时系统工程有限公司 | 嵌入式系统的错误追踪方法和装置 |
CN105988905A (zh) * | 2015-02-12 | 2016-10-05 | 中兴通讯股份有限公司 | 异常处理方法及装置 |
US10437754B1 (en) * | 2016-09-23 | 2019-10-08 | Amazon Technologies, Inc. | Diagnostic fault management controller for distributed computing |
CN108111328A (zh) * | 2016-11-24 | 2018-06-01 | 腾讯科技(深圳)有限公司 | 一种异常处理方法及装置 |
CN109977061A (zh) * | 2017-12-28 | 2019-07-05 | 中兴通讯股份有限公司 | 一种中断处理方法及中断处理装置 |
CN109918230A (zh) * | 2019-02-20 | 2019-06-21 | 杭州迪普科技股份有限公司 | 一种业务板卡异常恢复方法及系统 |
CN110519098A (zh) * | 2019-08-30 | 2019-11-29 | 新华三信息安全技术有限公司 | 一种异常单板的处理方法及装置 |
CN110955598A (zh) * | 2019-11-20 | 2020-04-03 | 杭州迪普科技股份有限公司 | 一种内核态程序的断点处理方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN111682991B (zh) | 2022-08-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11392461B2 (en) | Method and apparatus for processing information | |
US7165170B2 (en) | System and method for firmware to export pre-boot data into the operating system runtime environment | |
US9262283B2 (en) | Method for reading kernel log upon kernel panic in operating system | |
US9563439B2 (en) | Caching unified extensible firmware interface (UEFI) and/or other firmware instructions in a non-volatile memory of an information handling system (IHS) | |
CN111538659B (zh) | 业务场景的接口测试方法、系统、电子设备和存储介质 | |
US20140033180A1 (en) | Establishing cloud debug breakpoints assigned to users | |
US10514972B2 (en) | Embedding forensic and triage data in memory dumps | |
CN112559140B (zh) | 数据一致性的事务控制方法、系统、设备及存储介质 | |
CN110688096A (zh) | 包含插件的应用程序的构建方法、装置、介质及电子设备 | |
CN114765051A (zh) | 内存测试方法及装置、可读存储介质、电子设备 | |
CN110688111A (zh) | 业务流程的配置方法、装置、服务器和存储介质 | |
CN112363938A (zh) | 数据处理方法、装置、电子设备和存储介质 | |
US20080183659A1 (en) | Method and system for determining device criticality in a computer configuration | |
US8230413B2 (en) | Detecting incorrect versions of files | |
US20070150866A1 (en) | Displaying parameters associated with call statements | |
CN111682991B (zh) | 总线错误消息的处理方法及装置 | |
US8819494B2 (en) | Automatically changing parts in response to tests | |
CN107168776B (zh) | 一种事件统计方法、装置、设备及存储介质 | |
US11314582B2 (en) | Systems and methods for dynamically resolving hardware failures in an information handling system | |
CN109710495B (zh) | 一种信息处理方法及电子设备 | |
CN115374074A (zh) | 日志处理方法、装置、存储介质及电子设备 | |
JP2001331342A (ja) | 情報処理装置のエラー表示方法、及びそのプログラムを記録した記録媒体 | |
CN110851332A (zh) | 一种日志文件的处理方法、装置、设备和介质 | |
CN113791925B (zh) | 内存映象文件的存储方法及装置 | |
CN112416695B (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 |