用于卸载数据的方法、计算设备和计算机可读存储介质技术

技术编号:27058849 阅读:18 留言:0更新日期:2021-01-15 14:38
本公开涉及一种用于卸载数据的方法、计算设备和计算机可读存储介质。该方法包括:向命令队列发送命令包,命令包用于定义自图形处理器处卸载数据的卸载操作,命令包至少指示同步点和与同步点相关联的卸载操作命令包;响应于与同步点对应的同步指令被触发,通知同步引擎;同步引擎通知命令引擎同步点已经达到,以便命令引擎自命令队列获取与同步点相关联的卸载操作命令包;以及命令引擎解析与同步点相关联的卸载操作命令包,以便确定用于执行卸载操作命令包的对应卸载操作的卸载引擎。本公开能够有效提高计算设备整体性能和资源利用率。

【技术实现步骤摘要】
用于卸载数据的方法、计算设备和计算机可读存储介质
本公开的实施例总体上涉及信息处理领域,更具体地涉及一种用于卸载数据的方法、计算设备和计算机可读存储介质。
技术介绍
在传统的计算设备中,例如在配置有通用图形处理器(General-purposecomputingongraphicsprocessingunits,简称GPGPU)的计算设备中,通常利用处理图形任务的图形处理器(GraphicsProcessingUnit,GPU)来计算原本由中央处理器(CentralProcessingUnit,CPU)处理的通用计算任务。这些通用计算涉及的操作类型各种各样,有些操作与图形处理没有任何关系,这些操作对于GPU而言,并不是最适合的。上述由GPU来处理原本适于由其他组件(例如中央处理器)处理的操作的方案,比如对于GPU内存中数据预取(Preload)到二级缓存等操作,容易导致消耗大量的时间(GPU周期,即GPUcycle)与内存带宽(Memorybandwidth),进而降低GPU执行的效率,不利于计算设备整体性能和资源利用率的提升。综上,传统的计算设备存在容易导致降低GPU执行的效率,不利于计算设备整体性能和资源利用率的提升。
技术实现思路
本公开提供了一种用于卸载数据的方法、计算设备和计算机可读存储介质,能够有效提高计算设备整体性能和资源利用率。根据本公开的第一方面,提供了一种用于卸载数据的方法。该方法包括:向命令队列发送命令包,命令包用于定义自图形处理器处卸载数据的卸载操作,命令包至少指示同步点和与同步点相关联的卸载操作命令包;响应于与同步点对应的同步指令被触发,通知同步引擎;同步引擎通知命令引擎同步点已经达到,以便命令引擎自命令队列获取与同步点相关联的卸载操作命令包;以及命令引擎解析与同步点相关联的卸载操作命令包,以便确定用于执行卸载操作命令包的对应卸载操作的卸载引擎。根据本专利技术的第二方面,还提供了一种用于卸载数据的方法。该方法包括:命令引擎发送同步操作信息,同步操作信息用于定义自图形处理器处卸载数据的卸载操作,同步操作信息至少指示同步点和与同步点相关联的卸载操作类型和卸载操作的目标数据;响应于确定与同步点对应的同步指令被触发,通知同步引擎;同步引擎基于同步点,获取同步操作信息中的、与同步点相关联的卸载操作类型和卸载操作的目标数据;以及同步引擎基于卸载操作类型,确定用于执行与同步点相关联的对应卸载操作的卸载引擎。根据本专利技术的第三方面,还提供了一种用于卸载数据的方法。该方法包括:获取计算设备的设备供货商标识和设备标识,计算设备至少包括图形处理器和中央处理器;如果确定设备供货商标识为预定标识并且设备标识属于第一预定集合,本公开的第一方面的方法,以用于自图形处理器处卸载数据;以及如果确定设备供货商标识为预定标识并且设备标识属于第二预定集合,本公开的第二方面的方法,以用于自图形处理器卸载数据。根据本公开的第四方面,还提供了一种计算设备。该计算设备包括:至少一个处理器;以及与至少一个处理器通信连接的存储器;其中存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使计算设备能够本公开的第一方面的方法。根据本公开的第五方面,还提供了一种计算机可读存储介质。该计算机可读存储介质上存储有计算机程序,计算机程序被机器执行时执行本公开的第一方面的方法。在一些实施例中,所确定的、用于执行对应卸载操作的卸载引擎为图形处理器的组件和中央处理器中的一个。在一些实施例中,用于卸载数据的方法还包括:经由同步或者所确定的卸载引擎通知,所述命令引擎确定所述对应卸载操作被执行完毕;命令引擎通知同步引擎对应卸载操作已被完成;以及同步引擎通知程序核与同步点相关联的等待结束,以便程序核继续执行代码。在一些实施例中,在响应于与同步点对应的同步指令被触发通知同步引擎之前,方法还包括:程序核执行代码,以触发与同步点所对应的同步指令,代码所配置的同步点的数量和顺序与命令包所指示的同步点的数量和顺序对应一致。在一些实施例中,命令包是驱动程序基于编译器提供的信息而生成的,与同步点相关联的卸载操作命令包指示与同步点相关联的卸载操作类型和卸载操作的目标数据,卸载操作类型包括:卸载引擎标识和卸载操作号标识。在一些实施例中,确定用于执行卸载操作命令包的对应卸载操作的卸载引擎包括:命令引擎基于由卸载操作命令包所解析出的卸载引擎标识和卸载操作号标识,在多个卸载引擎中确定用于执行卸载操作命令包的对应卸载操作的卸载引擎。在一些实施例中,用于卸载数据的方法还包括:经由同步或者所确定的卸载引擎通知,所述命令引擎确定所述对应卸载操作被执行完毕;以及同步引擎通知程序核与同步点相关联的等待结束,以便程序核继续执行代码。在一些实施例中,用于卸载数据的方法还包括:命令引擎发送程序核的代码,代码被配置有一个或者多个同步点;以及程序核执行代码,以触发与同步点所对应的同步指令。在一些实施例中,同步操作信息为由编译器所产生的同步操作表,卸载操作类型包括:卸载引擎标识和卸载操作号标识。在一些实施例中,同步引擎基于卸载操作类型确定用于执行与同步点相关联的对应卸载操作的卸载引擎包括:同步引擎基于卸载引擎标识和卸载操作号标识,在多个卸载引擎中确定一个卸载引擎,以用于执行与同步点相关联的对应卸载操作,多个卸载引擎包括图形处理器中的组件和中央处理器中的至少两个。应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。附图说明图用于更好地理解本方案,不构成对本申请的限定。图1示意性示出了传统的计算设备的示意图。图2示出了用于实施根据本公开的实施例的用于卸载数据的方法的计算设备的示意图。图3示出了根据本公开的一些实施例的用于卸载数据的方法的示意图。图4示出了根据本公开的一些实施例的用于卸载数据的方法的流程图。图5示出了根据本公开的另一些实施例的用于卸载数据的方法的示意图。图6示出了根据本公开的另一些实施例的用于卸载数据的方法的流程图。图7示出了根据本公开的另一些实施例的用于卸载数据的方法的流程图。在各个附图中,相同或对应的标号表示相同或对应的部分。具体实施方式下面将参照附图更详细地描述本公开的优选实施例。虽然附图中显示了本公开的优选实施例,然而应该理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了使本公开更加透彻和完整,并且能够将本公开的范围完整地传达给本领域的技术人员。在本文中使用的术语“包括”及其变形表示开放性包括,即“包括但不限于”。除非特别申明,术语“或”表示“和/或”。术语“基于”表示“至少部分地基于”。术语“一个示例实施例”和“一个实施例”表示“至少一个示例实施例”。术语“另一实施例”表示“至少一个另外的实施例”。术语“第一”、“第二”等等可以指代不同的或相同本文档来自技高网...

【技术保护点】
1.一种用于卸载数据的方法,包括:/n向命令队列发送命令包,所述命令包用于定义自图形处理器处卸载数据的卸载操作,所述命令包至少指示同步点和与所述同步点相关联的卸载操作命令包;/n响应于与所述同步点对应的同步指令被触发,通知同步引擎;/n所述同步引擎通知命令引擎所述同步点已经达到,以便所述命令引擎自所述命令队列获取与所述同步点相关联的卸载操作命令包;以及/n所述命令引擎解析与所述同步点相关联的卸载操作命令包,以便确定用于执行所述卸载操作命令包的对应卸载操作的卸载引擎。/n

【技术特征摘要】
1.一种用于卸载数据的方法,包括:
向命令队列发送命令包,所述命令包用于定义自图形处理器处卸载数据的卸载操作,所述命令包至少指示同步点和与所述同步点相关联的卸载操作命令包;
响应于与所述同步点对应的同步指令被触发,通知同步引擎;
所述同步引擎通知命令引擎所述同步点已经达到,以便所述命令引擎自所述命令队列获取与所述同步点相关联的卸载操作命令包;以及
所述命令引擎解析与所述同步点相关联的卸载操作命令包,以便确定用于执行所述卸载操作命令包的对应卸载操作的卸载引擎。


2.根据权利要求1所述的方法,其中所确定的、用于执行对应卸载操作的卸载引擎为所述图形处理器的组件和中央处理器中的一个。


3.根据权利要求1所述的方法,还包括:
经由同步或者所确定的卸载引擎通知,所述命令引擎确定所述对应卸载操作被执行完毕;
所述命令引擎通知所述同步引擎所述对应卸载操作已被完成;以及
所述同步引擎通知程序核与所述同步点相关联的等待结束,以便所述程序核继续执行代码。


4.根据权利要求1所述的方法,其中在响应于与所述同步点对应的同步指令被触发通知同步引擎之前,所述方法还包括:
程序核执行代码,以触发与所述同步点所对应的同步指令,所述代码所配置的同步点的数量和顺序与所述命令包所指示的同步点的数量和顺序对应一致。


5.根据权利要求1所述的方法,其中所述命令包是驱动程序基于编译器提供的信息而生成的,与所述同步点相关联的卸载操作命令包指示与所述同步点相关联的卸载操作类型和卸载操作的目标数据,所述卸载操作类型包括:卸载引擎标识和卸载操作号标识。


6.根据权利要求5所述的方法,其中确定用于执行所述卸载操作命令包的对应卸载操作的卸载引擎包括:
所述命令引擎基于由所述卸载操作命令包所解析出的卸载引擎标识和卸载操作号标识,在多个卸载引擎中确定用于执行所述卸载操作命令包的对应卸载操作的卸载引擎。


7.一种用于卸载数据的方法,包括:
命令引擎发送同步操作信息,所述同步操作信息用于定义自图形处理器处卸载数据的卸载操作,所述同步操作信息至少指示同步点和与所述同步点相关联的卸载操作类型和卸载操作的目标数据;
响应于确定与所述同步点对应的同步指令被触发,通知同步引擎;
...

【专利技术属性】
技术研发人员:不公告发明人
申请(专利权)人:北京壁仞科技开发有限公司上海壁仞智能科技有限公司
类型:发明
国别省市:北京;11

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1