CN112685341B - 一种存储系统适配器的配置方法、装置、设备及存储介质 - Google Patents
一种存储系统适配器的配置方法、装置、设备及存储介质 Download PDFInfo
- Publication number
- CN112685341B CN112685341B CN202011568343.XA CN202011568343A CN112685341B CN 112685341 B CN112685341 B CN 112685341B CN 202011568343 A CN202011568343 A CN 202011568343A CN 112685341 B CN112685341 B CN 112685341B
- Authority
- CN
- China
- Prior art keywords
- adapter
- target
- slot
- information
- node
- 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 50
- 238000013507 mapping Methods 0.000 claims abstract description 15
- 230000006870 function Effects 0.000 claims description 7
- 238000004590 computer program Methods 0.000 claims description 6
- 239000000835 fiber Substances 0.000 claims description 4
- 238000012545 processing Methods 0.000 description 9
- 238000011161 development Methods 0.000 description 7
- 238000012423 maintenance Methods 0.000 description 6
- 238000013473 artificial intelligence Methods 0.000 description 4
- 238000004891 communication Methods 0.000 description 4
- 238000010586 diagram Methods 0.000 description 4
- 230000009471 action Effects 0.000 description 3
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 230000008569 process Effects 0.000 description 3
- 230000006978 adaptation Effects 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000009877 rendering Methods 0.000 description 2
- 230000002776 aggregation Effects 0.000 description 1
- 238000004220 aggregation Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000010801 machine learning Methods 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 230000001052 transient effect Effects 0.000 description 1
Classifications
-
- 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
- Stored Programmes (AREA)
Abstract
本发明公开了一种存储系统适配器的配置方法、装置、设备及存储介质,在存储控制器上,仅基于内核态进行待配置适配器的识别工作,通过将内核态创建的设备节点和分配的适配器资源映射到用户态,从而在用户态模式下利用设备节点和适配器资源映射对待配置适配器进行初始化和配置,无需针对内核态开发维护适配器初始化和配置相关的内核驱动模块代码,减少了内核态需要面向用户态提供调用的接口,从而简化了内核态所需开发维护的内核驱动模块代码,且用户态的代码要求不如内核态严苛,因而降低了存储系统适配器的配置工作的复杂度,提高了存储系统适配器的配置工作的效率,降低了适配器的开发成本和维护成本。
Description
技术领域
本发明涉及存储系统技术领域,特别是涉及一种存储系统适配器的配置方法、装置、设备及存储介质。
背景技术
集群存储中后端存储的聚合以及前端的集群都需要依托各种硬件拓扑,这种物理上的连接需要各种适配器(Adapter)的支持,才能高效的发挥作用。传统的适配器的配置工作(识别,初始化和配置)是在存储控制器的内核态实现的,作为内核驱动模块加载进内核代码中。随着AI、云服务的发展,对集群存储的效率和复杂性要求也越来越高。这种设计模式对于不断演进的存储系统也越来越凸显出开发成本过高,容易导致内核崩溃,后期升级维护成本也过高等弊端。
如何提高存储系统适配器的配置工作的效率,降低适配器的开发成本和维护成本,是本领域技术人员需要解决的技术问题。
发明内容
本发明的目的是提供一种存储系统适配器的配置方法、装置、设备及存储介质,用于提高存储系统适配器的配置工作的效率,降低适配器的开发成本和维护成本。
为解决上述技术问题,本发明提供一种存储系统适配器的配置方法,基于存储控制器,包括:
加载内核态的适配器驱动识别得到所述存储控制器的槽位上连接的待配置适配器的类型,并根据所述待配置适配器的类型为所述待配置适配器创建设备节点以及为所述待配置适配器分配适配器资源;
运行用户态的存储核心协议栈主程序,根据所述设备节点对应的槽位唯一标识和所述待配置适配器对应的槽位唯一标识,确定与所述待配置适配器对应的目标设备节点以及与所述待配置适配器对应的目标适配器资源后,将所述目标设备节点和所述目标适配器资源映射至用户态;
在用户态模式下,利用所述目标设备节点和所述目标适配器资源对所述待配置适配器进行初始化和配置。
可选的,所述槽位唯一标识具体为基本输入输出系统预先为所述槽位配置的总线号。
可选的,所述运行用户态的存储核心协议栈主程序,根据所述设备节点对应的槽位唯一标识和所述待配置适配器对应的槽位唯一标识,确定与所述待配置适配器对应的目标设备节点以及与所述待配置适配器对应的目标适配器资源,具体包括:
运行所述存储核心协议栈主程序调用预设的解析脚本解析槽位信息文件,得到各所述槽位的信息;
根据所述槽位的信息扫描PCIE子系统下的总线信息,确定所述待配置适配器的信息;
根据所述待配置适配器的信息构造与所述待配置适配器对应的结构体对象;
根据所述待配置适配器的信息遍历所述内核态对应的设备路径下的设备节点信息,确定总线号与所述待配置适配器一致的所述设备节点为所述目标设备节点;
确定与所述目标设备节点对应的适配器资源为所述目标适配器资源;
其中,所述槽位的信息包括所述槽位的总线基地址、所述槽位所能挂载的适配器类型和所述槽位的端口信息;所述待配置适配器的信息包括所述待配置适配器连接的槽位的总线号、所述待配置适配器的类型、所述待配置适配器对应的设备信息以及所述待配置适配器的功能信息。
可选的,所述根据所述待配置适配器的信息遍历所述内核态对应的设备路径下的设备节点信息,确定总线号与所述待配置适配器一致的所述设备节点为所述目标设备节点,具体包括:
确定所述设备路径下与所述待配置适配器的类型一致的所述设备节点为待选设备节点;
确定与所述待配置适配器的总线号一致的所述待选设备节点为所述目标设备节点。
可选的,所述适配器资源具体包括总线空间和寄存器存储空间。
可选的,所述在用户态模式下,利用所述目标设备节点和所述目标适配器资源对所述待配置适配器进行初始化和配置,具体包括:
在所述用户态模式下,根据所述待配置适配器的类型确定所述待配置适配器对应的业务场景和所述待配置适配器对应的业务逻辑;
根据所述业务场景和所述业务逻辑,利用所述目标设备节点和所述目标适配器资源对所述待配置适配器进行初始化和配置。
可选的,所述存储控制器具体为光纤通道控制器,所述待配置适配器具体为串行连接小型计算机系统接口适配器。
为解决上述技术问题,本发明还提供一种存储系统适配器的配置装置,包括:
识别单元,用于加载内核态的适配器驱动识别得到所述存储控制器的槽位上连接的待配置适配器的类型,并根据所述待配置适配器的类型为所述待配置适配器创建设备节点以及为所述待配置适配器分配适配器资源;
映射单元,用于运行用户态的存储核心协议栈主程序,根据所述设备节点对应的槽位唯一标识和所述待配置适配器对应的槽位唯一标识,确定与所述待配置适配器对应的目标设备节点以及与所述待配置适配器对应的目标适配器资源后,将所述目标设备节点和所述目标适配器资源映射至用户态;
配置单元,用于在用户态模式下,利用所述目标设备节点和所述目标适配器资源对所述待配置适配器进行初始化和配置。
为解决上述技术问题,本发明还提供一种存储系统适配器的配置设备,包括:
存储器,用于存储指令,所述指令包括上述任意一项所述存储系统适配器的配置方法的步骤;
处理器,用于执行所述指令。
为解决上述技术问题,本发明还提供一种存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现如上述任意一项所述存储系统适配器的配置方法的步骤。
本发明所提供的存储系统适配器的配置方法,在存储控制器上,首先基于内核态的适配器驱动识别存储控制器的槽位上连接的待配置适配器的类型,据此创建设备节点和分配适配器资源;而后运行用户态的存储核心协议栈主程序,将获取到的待配置适配器对应的槽位唯一标识和设备节点对应的槽位唯一标识进行匹配,确定与待配置适配器对应的目标设备节点和目标适配器资源后,将目标设备节点和目标适配器资源映射到用户态,从而在用户态模式下利用目标设备节点和目标适配器资源对待配置适配器进行初始化和配置。应用本发明提供的存储系统适配器的配置方法,以用户态取代内核态进行适配器的初始化和配置工作,无需针对内核态开发维护相关的内核驱动模块代码,减少了内核态需要面向用户态提供调用的接口,从而简化了内核态所需开发维护的内核驱动模块代码,且用户态的代码要求不如内核态严苛,因而降低了存储系统适配器的配置工作的复杂度,提高了存储系统适配器的配置工作的效率,降低了适配器的开发成本和维护成本。
本发明还提供一种存储系统适配器的配置装置、设备及存储介质,具有上述有益效果,在此不再赘述。
附图说明
为了更清楚的说明本发明实施例或现有技术的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单的介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的一种存储系统适配器的配置方法的流程图;
图2为本发明实施例提供的一种图1中步骤S102的具体实施方式的流程图;
图3为本发明实施例提供的一种存储系统适配器的配置装置的结构示意图;
图4为本发明实施例提供的一种存储系统适配器的配置设备的结构示意图。
具体实施方式
本发明的核心是提供一种存储系统适配器的配置方法、装置、设备及存储介质,用于提高存储系统适配器的配置工作的效率,降低适配器的开发成本和维护成本。
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
图1为本发明实施例提供的一种存储系统适配器的配置方法的流程图。
如图1所示,基于存储控制器,本发明实施例提供的存储系统适配器的配置方法包括:
S101:加载内核态的适配器驱动识别得到存储控制器的槽位上连接的待配置适配器的类型,并根据待配置适配器的类型为待配置适配器创建设备节点以及为待配置适配器分配适配器资源。
S102:运行用户态的存储核心协议栈主程序,根据设备节点对应的槽位唯一标识和待配置适配器对应的槽位唯一标识,确定与待配置适配器对应的目标设备节点以及与待配置适配器对应的目标适配器资源后,将目标设备节点和目标适配器资源映射至用户态。
S103:在用户态模式下,利用目标设备节点和目标适配器资源对待配置适配器进行初始化和配置。
在后端存储中,存储控制器之间,存储控制器与盘柜之间,存储控制器与主机之间都需要通过相应的适配器相连,例如光纤通道(Fiber Channel,FC)控制器和串行连接小型计算机系统接口(Serial Attached SCS,SAS)之前的适配器。这些适配器有的配置于外插卡中,有的集成在存储控制器的主板上。
在实际应用中,适配器均通过PCIE总线连接到存储控制器所在的存储系统中,每个连接点都是一个槽位(slot),每个槽位都有槽位号,根据PCIE总线的规则,约定配置每个槽位的总线号(bus号),存储控制器上电后,基本输入输出系统(Basic Input OutputSystem,BIOS)会根据配置的各PCIE总线的总线号,Linux系统将每个槽位挂载到PCIE子系统中。
现有的适配器配置工作在内核态完成,内核态的适配器驱动代码较为复杂。而本发明实施例中,仅将对待配置适配器的识别工作在内核态完成,内核态的适配器驱动代码较为简单。具体来说,如步骤S101,在存储控制器上加载内核态的适配器驱动识别得到存储控制器的各槽位上连接的待配置适配器的类型,从而根据待配置适配器的类型为待配置适配器创建设备节点以及为待配置适配器分配适配器资源。其中,设备节点作为适配器对应的驱动模块,与连接有适配器的插槽一一对应,适配器资源与设备节点一一对应。适配器资源具体可以包括总线空间和寄存器存储空间。
存储核心协议栈主程序是用户态的应用程序,本发明实施例通过编辑该程序实现步骤S102和步骤S103。
对于步骤S102来说,存储核心协议栈主程序需要根据各槽位上的待配置适配器的类型对待配置适配器进行初始化和配置,但在进行这些工作前,需要先将待配置适配器的适配器资源映射到用户态,故需要先找到与待配置适配器对应的设备节点,将设备节点对应的适配器资源映射到用户态,才能够在用户态模式下利用适配器资源对待配置适配器做初始化和配置。而建立待配置适配器与设备节点的对应关系,依赖于其共同对应的槽位,因此需要根据设备节点对应的槽位唯一标识和待配置适配器对应的槽位唯一标识,确定与待配置适配器对应的目标设备节点以及与待配置适配器对应的目标适配器资源,进而将目标设备节点和目标适配器资源映射至用户态。槽位唯一标识可以采用基本输入输出系统预先为槽位配置的总线号。
对于步骤S103来说,在用户态模式下,利用目标设备节点和目标适配器资源对待配置适配器进行初始化和配置,从而将目标设备节点与待配置适配器进行适配。步骤S103具体可以包括:在用户态模式下,根据待配置适配器的类型确定待配置适配器对应的业务场景和待配置适配器对应的业务逻辑;根据业务场景和业务逻辑,利用目标设备节点和目标适配器资源对待配置适配器进行初始化和配置。
由此,配置适配器的主要工作都是在用户态完成的,没有频繁的系统调用,效率更高,更安全,也更贴合业务场景和逻辑。
本发明实施例提供的存储系统适配器的配置方法,在存储控制器上,首先基于内核态的适配器驱动识别存储控制器的槽位上连接的待配置适配器的类型,据此创建设备节点和分配适配器资源;而后运行用户态的存储核心协议栈主程序,将获取到的待配置适配器对应的槽位唯一标识和设备节点对应的槽位唯一标识进行匹配,确定与待配置适配器对应的目标设备节点和目标适配器资源后,将目标设备节点和目标适配器资源映射到用户态,从而在用户态模式下利用目标设备节点和目标适配器资源对待配置适配器进行初始化和配置。应用本发明实施例提供的存储系统适配器的配置方法,以用户态取代内核态进行适配器的初始化和配置工作,无需针对内核态开发维护相关的内核驱动模块代码,减少了内核态需要面向用户态提供调用的接口,从而简化了内核态所需开发维护的内核驱动模块代码,且用户态的代码要求不如内核态严苛,因而降低了存储系统适配器的配置工作的复杂度,提高了存储系统适配器的配置工作的效率,降低了适配器的开发成本和维护成本。
图2为本发明实施例提供的一种图1中步骤S102的具体实施方式的流程图。
在上述实施例的基础上,在本发明实施例提供的存储系统适配器的配置方法中,如图2所示,步骤S102:运行用户态的存储核心协议栈主程序,根据设备节点对应的槽位唯一标识和待配置适配器对应的槽位唯一标识,确定与待配置适配器对应的目标设备节点以及与待配置适配器对应的目标适配器资源后,将目标设备节点和目标适配器资源映射至用户态,具体可以包括:
S201:运行存储核心协议栈主程序调用预设的解析脚本解析槽位信息文件,得到各槽位的信息。
S202:根据槽位的信息扫描PCIE子系统下的总线信息,确定待配置适配器的信息。
S203:根据待配置适配器的信息构造与待配置适配器对应的结构体对象。
S204:根据待配置适配器的信息遍历内核态对应的设备路径下的设备节点信息,确定总线号与待配置适配器一致的设备节点为目标设备节点。
S205:确定与目标设备节点对应的适配器资源为目标适配器资源。
S206:将目标设备节点和目标适配器资源映射至用户态。
其中,槽位的信息包括槽位的总线基地址、槽位所能挂载的适配器类型和槽位的端口信息;待配置适配器的信息包括待配置适配器连接的槽位的总线号、待配置适配器的类型、待配置适配器对应的设备信息以及待配置适配器的功能信息。
在具体实施中,对于步骤S201和步骤S202来说,槽位的信息,包括槽位的总线基地址、槽位所能挂载的适配器类型和槽位的端口信息,会预先记录在一个文件中,即槽位信息文件。存储控制器运行存储核心协议栈主程序从系统中调用槽位信息文件,利用预先编写的解析脚本解析槽位信息文件,从而得到各槽位的信息。存储控制器运行存储核心协议栈主程序扫描PCIE子系统(路径为“/sys/bus/pci/devices/”)下的总线信息,得到每个槽位上连接的待配置适配器的类型及其BDF(对应的槽位总线号bus,待配置适配器对应的设备信息device,待配置适配器的功能信息function)信息。
对于步骤S203来说,存储控制器运行存储核心协议栈主程序将待配置适配器的信息保存至特定的文件中,基于存储核心协议栈主程序中预先配置的平台接口模块,将该特定的文件中的信息解析到特定的结构体中,即构造与待配置适配器对应的结构体对象,该结构体对象主要包含待配置适配器对应的槽位的信息、待配置适配器的类型和待配置适配器的BDF信息。
对于步骤S204来说,存储控制器运行存储核心协议栈主程序,根据待配置适配器的信息遍历内核态对应的设备(/dev)路径下的设备节点信息,确定总线号与待配置适配器一致的设备节点为目标设备节点。为便于快速确定目标设备节点,步骤S204具体可以包括:确定设备路径下与待配置适配器的类型一致的设备节点为待选设备节点(即在设备路径下寻找待配置适配器的类型的设备节点);确定与待配置适配器的总线号一致的待选设备节点为目标设备节点。
对于步骤S205来说,根据设备节点与适配器资源的对应关系,即可确定与目标设备节点对应的适配器资源为目标适配器资源。
在上述实施例的基础上,本发明实施例以存储控制器具体为光纤通道控制器,待配置适配器具体为串行连接小型计算机系统接口适配器为为例,进行实际场景的说明。
则基于存储控制器,本发明实施例提供的存储系统适配器的配置方法具体包括:
基本输入输出系统根据槽位的约定规则配置PCIE的总线号,Linux系统将每个槽位挂载到PCIE子系统中;
加载内核态的适配器驱动,为待配置适配器分配适配器资源,主要为给待配置适配器的寄存器分配内存;
运行用户态的存储核心协议栈主程序,根据槽位的总线基地址、槽位所能挂载的适配器类型和槽位的端口信息,扫描/sys/bus/pci/devices/路径下的总线信息,得到各个槽位上所连接待配置适配器的类型和BDF信息,并保存在特定的文件中;
存储核心协议栈主程序中预先配置的平台接口模块将待配置适配器的类型和BDF信息解析到特定的结构体中,结构体包含的主要信息为:待配置适配器对应的槽位的信息、待配置适配器的类型和待配置适配器的BDF信息;
在将目标设备节点SAS模块适配待配置适配器时,从平台接口模块保存的信息中获取待配置适配器的槽位号和总线号,遍历内核态对应的设备/dev路径下文件名以“sasChip”开始的设备节点,读取开设备节点的总线号,如果等于该槽位上的总线号,则找到了目标设备节点;
对目标设备节点做映射,将它的总线空间和寄存器存储空间映射到用户态,在用户态模式下初始化并配置待配置适配器。
上文详述了存储系统适配器的配置方法对应的各个实施例,在此基础上,本发明还公开了与上述方法对应的存储系统适配器的配置装置、设备及存储介质。
图3为本发明实施例提供的一种存储系统适配器的配置装置的结构示意图。
如图3所示,本发明实施例提供的存储系统适配器的配置装置包括:
识别单元301,用于加载内核态的适配器驱动识别得到存储控制器的槽位上连接的待配置适配器的类型,并根据待配置适配器的类型为待配置适配器创建设备节点以及为待配置适配器分配适配器资源;
映射单元302,用于运行用户态的存储核心协议栈主程序,根据设备节点对应的槽位唯一标识和待配置适配器对应的槽位唯一标识,确定与待配置适配器对应的目标设备节点以及与待配置适配器对应的目标适配器资源后,将目标设备节点和目标适配器资源映射至用户态;
配置单元303,用于在用户态模式下,利用目标设备节点和目标适配器资源对待配置适配器进行初始化和配置。
由于装置部分的实施例与方法部分的实施例相互对应,因此装置部分的实施例请参见方法部分的实施例的描述,这里暂不赘述。
图4为本发明实施例提供的一种存储系统适配器的配置设备的结构示意图。
如图4所示,本发明实施例提供的存储系统适配器的配置设备包括:
存储器410,用于存储指令,所述指令包括上述任意一项实施例所述的存储系统适配器的配置方法的步骤;
处理器420,用于执行所述指令。
其中,处理器420可以包括一个或多个处理核心,比如3核心处理器、8核心处理器等。处理器420可以采用数字信号处理DSP(Digital Signal Processing)、现场可编程门阵列FPGA(Field-Programmable Gate Array)、可编程逻辑阵列PLA(Programmable LogicArray)中的至少一种硬件形式来实现。处理器420也可以包括主处理器和协处理器,主处理器是用于对在唤醒状态下的数据进行处理的处理器,也称中央处理器CPU(CentralProcessing Unit);协处理器是用于对在待机状态下的数据进行处理的低功耗处理器。在一些实施例中,处理器420可以集成有图像处理器GPU(Graphics Processing Unit),GPU用于负责显示屏所需要显示的内容的渲染和绘制。一些实施例中,处理器420还可以包括人工智能AI(Artificial Intelligence)处理器,该AI处理器用于处理有关机器学习的计算操作。
存储器410可以包括一个或多个存储介质,该存储介质可以是非暂态的。存储器410还可包括高速随机存取存储器,以及非易失性存储器,比如一个或多个磁盘存储设备、闪存存储设备。本实施例中,存储器410至少用于存储以下计算机程序411,其中,该计算机程序411被处理器420加载并执行之后,能够实现前述任一实施例公开的存储系统适配器的配置方法中的相关步骤。另外,存储器410所存储的资源还可以包括操作系统412和数据413等,存储方式可以是短暂存储或者永久存储。其中,操作系统412可以为Windows。数据413可以包括但不限于上述方法所涉及到的数据。
在一些实施例中,存储系统适配器的配置设备还可包括有显示屏430、电源440、通信接口450、输入输出接口460、传感器470以及通信总线480。
本领域技术人员可以理解,图4中示出的结构并不构成对存储系统适配器的配置设备的限定,可以包括比图示更多或更少的组件。
本申请实施例提供的存储系统适配器的配置设备,包括存储器和处理器,处理器在执行存储器存储的程序时,能够实现如上所述的存储系统适配器的配置方法,效果同上。
需要说明的是,以上所描述的装置、设备实施例仅仅是示意性的,例如,模块的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个模块或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或模块的间接耦合或通信连接,可以是电性,机械或其它的形式。作为分离部件说明的模块可以是或者也可以不是物理上分开的,作为模块显示的部件可以是或者也可以不是物理模块,即可以位于一个地方,或者也可以分布到多个网络模块上。可以根据实际的需要选择其中的部分或者全部模块来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能模块可以集成在一个处理模块中,也可以是各个模块单独物理存在,也可以两个或两个以上模块集成在一个模块中。上述集成的模块既可以采用硬件的形式实现,也可以采用软件功能模块的形式实现。
集成的模块如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,执行本发明各个实施例所述方法的全部或部分步骤。
为此,本发明实施例还提供一种存储介质,该存储介质上存储有计算机程序,计算机程序被处理器执行时实现如存储系统适配器的配置方法的步骤。
该存储介质可以包括:U盘、移动硬盘、只读存储器ROM(Read-Only Memory)、随机存取存储器RAM(Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
本实施例中提供的存储介质所包含的计算机程序能够在被处理器执行时实现如上所述的存储系统适配器的配置方法的步骤,效果同上。
以上对本发明所提供的一种存储系统适配器的配置方法、装置、设备及存储介质进行了详细介绍。说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似部分互相参见即可。对于实施例公开的装置、设备及存储介质而言,由于其与实施例公开的方法相对应,所以描述的比较简单,相关之处参见方法部分说明即可。应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以对本发明进行若干改进和修饰,这些改进和修饰也落入本发明权利要求的保护范围内。
还需要说明的是,在本说明书中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
Claims (10)
1.一种存储系统适配器的配置方法,其特征在于,基于存储控制器,包括:
加载内核态的适配器驱动识别得到所述存储控制器的槽位上连接的待配置适配器的类型,并根据所述待配置适配器的类型为所述待配置适配器创建设备节点以及为所述待配置适配器分配适配器资源;
运行用户态的存储核心协议栈主程序,根据所述设备节点对应的槽位唯一标识和所述待配置适配器对应的槽位唯一标识,确定与所述待配置适配器对应的目标设备节点以及与所述待配置适配器对应的目标适配器资源后,将所述目标设备节点和所述目标适配器资源映射至用户态;
在用户态模式下,利用所述目标设备节点和所述目标适配器资源对所述待配置适配器进行初始化和配置。
2.根据权利要求1所述的配置方法,其特征在于,所述槽位唯一标识具体为基本输入输出系统预先为所述槽位配置的总线号。
3.根据权利要求2所述的配置方法,其特征在于,所述运行用户态的存储核心协议栈主程序,根据所述设备节点对应的槽位唯一标识和所述待配置适配器对应的槽位唯一标识,确定与所述待配置适配器对应的目标设备节点以及与所述待配置适配器对应的目标适配器资源,具体包括:
运行所述存储核心协议栈主程序调用预设的解析脚本解析槽位信息文件,得到各所述槽位的信息;
根据所述槽位的信息扫描PCIE子系统下的总线信息,确定所述待配置适配器的信息;
根据所述待配置适配器的信息构造与所述待配置适配器对应的结构体对象;
根据所述待配置适配器的信息遍历所述内核态对应的设备路径下的设备节点信息,确定总线号与所述待配置适配器一致的所述设备节点为所述目标设备节点;
确定与所述目标设备节点对应的适配器资源为所述目标适配器资源;
其中,所述槽位的信息包括所述槽位的总线基地址、所述槽位所能挂载的适配器类型和所述槽位的端口信息;所述待配置适配器的信息包括所述待配置适配器连接的槽位的总线号、所述待配置适配器的类型、所述待配置适配器对应的设备信息以及所述待配置适配器的功能信息。
4.根据权利要求3所述的配置方法,其特征在于,所述根据所述待配置适配器的信息遍历所述内核态对应的设备路径下的设备节点信息,确定总线号与所述待配置适配器一致的所述设备节点为所述目标设备节点,具体包括:
确定所述设备路径下与所述待配置适配器的类型一致的所述设备节点为待选设备节点;
确定与所述待配置适配器的总线号一致的所述待选设备节点为所述目标设备节点。
5.根据权利要求1所述的配置方法,其特征在于,所述适配器资源具体包括总线空间和寄存器存储空间。
6.根据权利要求1所述的配置方法,其特征在于,所述在用户态模式下,利用所述目标设备节点和所述目标适配器资源对所述待配置适配器进行初始化和配置,具体包括:
在所述用户态模式下,根据所述待配置适配器的类型确定所述待配置适配器对应的业务场景和所述待配置适配器对应的业务逻辑;
根据所述业务场景和所述业务逻辑,利用所述目标设备节点和所述目标适配器资源对所述待配置适配器进行初始化和配置。
7.根据权利要求1所述的配置方法,其特征在于,所述存储控制器具体为光纤通道控制器,所述待配置适配器具体为串行连接小型计算机系统接口适配器。
8.一种存储系统适配器的配置装置,其特征在于,包括:
识别单元,用于加载内核态的适配器驱动识别得到所述存储控制器的槽位上连接的待配置适配器的类型,并根据所述待配置适配器的类型为所述待配置适配器创建设备节点以及为所述待配置适配器分配适配器资源;
映射单元,用于运行用户态的存储核心协议栈主程序,根据所述设备节点对应的槽位唯一标识和所述待配置适配器对应的槽位唯一标识,确定与所述待配置适配器对应的目标设备节点以及与所述待配置适配器对应的目标适配器资源后,将所述目标设备节点和所述目标适配器资源映射至用户态;
配置单元,用于在用户态模式下,利用所述目标设备节点和所述目标适配器资源对所述待配置适配器进行初始化和配置。
9.一种存储系统适配器的配置设备,其特征在于,包括:
存储器,用于存储指令,所述指令包括权利要求1至7任意一项所述存储系统适配器的配置方法的步骤;
处理器,用于执行所述指令。
10.一种存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至7任意一项所述存储系统适配器的配置方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011568343.XA CN112685341B (zh) | 2020-12-25 | 2020-12-25 | 一种存储系统适配器的配置方法、装置、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011568343.XA CN112685341B (zh) | 2020-12-25 | 2020-12-25 | 一种存储系统适配器的配置方法、装置、设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112685341A CN112685341A (zh) | 2021-04-20 |
CN112685341B true CN112685341B (zh) | 2024-02-23 |
Family
ID=75452336
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011568343.XA Active CN112685341B (zh) | 2020-12-25 | 2020-12-25 | 一种存储系统适配器的配置方法、装置、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112685341B (zh) |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101615106A (zh) * | 2008-06-23 | 2009-12-30 | 国际商业机器公司 | 用于虚拟化sas存储适配器的方法和系统 |
US8566573B1 (en) * | 2010-11-08 | 2013-10-22 | Qlogic, Corporation | Selectable initialization for adapters |
CN106227470A (zh) * | 2016-08-05 | 2016-12-14 | 浪潮(北京)电子信息产业有限公司 | 一种存储资源管理方法及装置 |
CN111399771A (zh) * | 2020-02-28 | 2020-07-10 | 苏州浪潮智能科技有限公司 | 一种mcs存储系统的协议配置方法、装置及设备 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8505032B2 (en) * | 2010-06-23 | 2013-08-06 | International Business Machines Corporation | Operating system notification of actions to be taken responsive to adapter events |
-
2020
- 2020-12-25 CN CN202011568343.XA patent/CN112685341B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101615106A (zh) * | 2008-06-23 | 2009-12-30 | 国际商业机器公司 | 用于虚拟化sas存储适配器的方法和系统 |
US8566573B1 (en) * | 2010-11-08 | 2013-10-22 | Qlogic, Corporation | Selectable initialization for adapters |
CN106227470A (zh) * | 2016-08-05 | 2016-12-14 | 浪潮(北京)电子信息产业有限公司 | 一种存储资源管理方法及装置 |
CN111399771A (zh) * | 2020-02-28 | 2020-07-10 | 苏州浪潮智能科技有限公司 | 一种mcs存储系统的协议配置方法、装置及设备 |
Also Published As
Publication number | Publication date |
---|---|
CN112685341A (zh) | 2021-04-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109474467B (zh) | 网络自动化管理方法、装置、存储介质及电子设备 | |
US9280493B2 (en) | Method and device for enumerating input/output devices | |
US10282190B2 (en) | System and method for updating a UEFI image in an information handling system | |
CN105824678A (zh) | 一种操作系统安装方法及装置 | |
CN111176790A (zh) | 云平台物理主机的主动维护方法、装置及可读存储介质 | |
CN111078353A (zh) | 存储设备的操作方法及物理服务器 | |
CN110502282B (zh) | 多路ntb卡的加载方法、装置、设备及可读存储介质 | |
CN114185607B (zh) | Arm服务器中pci设备的启动控制方法、装置及设备 | |
CN105389190A (zh) | 一种操作系统启动的方法、装置及系统 | |
CN111061541A (zh) | 一种创建虚拟机的方法、系统、计算机存储介质及终端 | |
CN111124437A (zh) | 一种基于OpenStack的裸机资源配置信息获取方法、系统及设备 | |
CN112685341B (zh) | 一种存储系统适配器的配置方法、装置、设备及存储介质 | |
CN113296878A (zh) | 一种容器处理方法、装置、电子设备及系统 | |
US11113088B2 (en) | Generating and managing groups of physical hosts associated with virtual machine managers in an information handling system | |
CN115562801A (zh) | 一种多cpu架构虚拟机pci总线地址管理方法及设备 | |
CN113296876B (zh) | 虚拟机的设备直通方法、设备及存储介质 | |
CN115150268A (zh) | Kubernetes集群的网络配置方法、装置、及电子设备 | |
CN115129648A (zh) | 车载监控板pcie总线转usb总线的方法及装置 | |
CN110327626B (zh) | 虚拟服务器创建方法及装置 | |
CN103197915B (zh) | 一种处理敏感指令的方法、装置以及物理机 | |
CN110532040A (zh) | 固件程序的加载方法及装置、存储介质和电子设备 | |
CN110704163A (zh) | 一种服务器及其虚拟化存储方法和装置 | |
CN116243994B (zh) | 一种存储设备的驱动加载方法、操作系统启动方法及系统 | |
CN111698141A (zh) | 报文的转发方法及装置 | |
CN111163187B (zh) | 虚拟机网络端口的mac地址生成方法和装置 |
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 |