CN110874259A - 程序执行方法、装置、设备和存储介质 - Google Patents
程序执行方法、装置、设备和存储介质 Download PDFInfo
- Publication number
- CN110874259A CN110874259A CN201811015357.1A CN201811015357A CN110874259A CN 110874259 A CN110874259 A CN 110874259A CN 201811015357 A CN201811015357 A CN 201811015357A CN 110874259 A CN110874259 A CN 110874259A
- Authority
- CN
- China
- Prior art keywords
- target
- basic block
- instruction sequence
- function code
- program
- 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.)
- Pending
Links
Images
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/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
-
- 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/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/45591—Monitoring or debugging support
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Devices For Executing Special Programs (AREA)
Abstract
本发明实施例提供了一种程序执行方法和装置,所述方法包括:检测虚拟机上运行的程序的目标基本块,确定与目标基本块功能相同的预置的目标指令序列,采用目标指令序列替代目标基本块,执行程序,由于目标指令序列是由物理机上可执行的目标函数代码编译得到,目标函数代码是针对物理机编写的,且与虚拟机上的目标基本块功能相同,直接对目标函数代码进行编译得到目标指令序列,使得其指令数量远低于二进制翻译得到的指令序列,避免了二进制翻译技术的指令膨胀问题,降低虚拟机对应物理机上执行的指令的数量,提高虚拟机运行效率。
Description
技术领域
本发明涉及应用程序技术领域,特别是涉及一种程序执行方法、一种程序执行装置、一种电子设备和一种可读存储介质。
背景技术
虚拟机(VM,Virtual Machine)主要通过软件(或者辅以少量硬件支持)的方法来虚拟出一台计算机,并且这台虚拟的计算机通常还支持一套对应的指令集,称为虚拟机指令集。这样的虚拟机也称为客户机(Guest Machine),。虚拟机依托于本地的物理机(HostMachine),通过其执行引擎对给定的虚拟机指令序列(目标程序)在本地机器上模拟执行。
虚拟机通常用于在不同的CPU之间实现软件的兼容。例如,基于RISC(ReducedInstruction Set Computer,精简指令集计算机)指令集的PC机和基于X86指令集的PC机是不兼容的,基于两种指令集的PC机的软件无法相互兼容,即基于X86指令集的PC机上运行的程序无法直接在基于RISC指令集的PC机上运行,同理,基于RISC指令集的PC机上运行的程序无法直接在基于X86指令集的PC机上运行。如此,需要采用虚拟机来实现程序软件在不同指令集PC机上的兼容运行。
图1是传统虚拟机的结构的示意图。其中,底层的是真实的物理机器,称为“Host”。虚拟机及其上的机器称为“Guest”。Host机器首先启动一个本地的操作系统(Host OS),然后再启动虚拟机,最后才能启动Guest OS。这种结构把虚拟机作为本地操作系统中的一个应用程序,其优点是开发和调试都很方便。因此现在的虚拟机都属于这种结构。
如果Host与Guest是不同的CPU指令集,那么Guest的软件无法直接在Host上运行,必须采用一种称为“二进制翻译”的技术,将Guest的机器指令转换成能够在Host上运行的、在功能上等价的机器指令。
二进制翻译(Dynamic Binary Translation,DBT)基于动态编译(DynamicCompilation)技术,在客户机程序执行时,二进制翻译器动态地解析并翻译即将被执行的代码。代码翻译和翻译后代码的运行是穿插进行的。
以基于MIPS(Microprocessor without interlocked piped stages,无内部互锁流水级的微处理器)指令的PC上运行X86虚拟机为例,图2是二进制翻译技术的基本流程的示意图。在虚拟机上执行一个X86应用程序时,X86应用程序由大量基本块组成,每一个基本块包含一定数量的机器指令(Machine Instruction)。这个X86机器指令要经过翻译模块,转换成同等功能的MIPS指令(即“本地指令”),保存到内存中的一个代码cache(寄存器)区域中,本地MIPS指令可以在真实的CPU上运行。
但是指令的翻译过程一般会导致指令数量“膨胀”,即翻译后的本地指令的数量大于翻译之前的X86指令。这是二进制翻译技术的一个固有特性。
表1:
表1为二进制翻译导致指令膨胀的一个例子,可见1条X86的add指令,要翻译成4条MIPS指令。所以可想而知,采用二进制翻译的技术的虚拟机系统,效率一般要低于真实的X86机器。
发明内容
本发明实施例所要解决的技术问题是提供一种程序执行方法及装置,以便避免了二进制翻译技术的指令膨胀问题,降低虚拟机对应物理机上执行的指令的数量,提高虚拟机运行效率。
为了解决上述问题,本发明公开了一种程序执行方法,包括:
检测虚拟机上运行的程序的目标基本块,其中,所述目标基本块包括预置有功能相同的目标指令序列的基本块;
确定与所述目标基本块功能相同的预置的目标指令序列,所述目标指令序列由物理机上可执行的目标函数代码编译得到;
采用所述目标指令序列替代所述目标基本块,执行所述程序。
可选地,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法包括:
检测所述程序中具有预设执行特性的特征函数代码;
根据所述特征函数代码,确定物理机上可执行的目标函数代码。
可选地,所述预设执行特性包括:所述特征函数代码在所述程序中的运行时间的占比高于预设比值。
可选地,所述根据所述特征函数代码,确定物理机上可执行的目标函数代码包括:
根据所述特征函数代码,确定所述特征函数代码的描述信息,所述描述信息包括:标识信息、输入信息、功能信息或输出信息中至少一种;
根据所述描述信息,确定物理机上可执行的目标函数代码。
可选地,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法还包括:
记录所述特征函数代码的内存地址信息;
所述检测虚拟机上运行的程序的目标基本块包括:
根据所述特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块。
可选地,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法包括:
根据所述目标函数代码,编译得到目标指令序列;
将所述目标指令序列添加到物理机操作系统中。
可选地,所述确定与所述目标基本块功能相同的预置的目标指令序列包括:
在所述物理机操作系统中,查找与所述目标基本块对应的目标指令序列。
相应的,本发明实施例还提供了一种程序执行装置,包括:
块检测模块,用于检测虚拟机上运行的程序的目标基本块,其中,所述目标基本块包括预置有功能相同的目标指令序列的基本块;
序列确定模块,用于确定与所述目标基本块功能相同的预置的目标指令序列,所述目标指令序列由物理机上可执行的目标函数代码编译得到;
执行模块,用于采用所述目标指令序列替代所述目标基本块,执行所述程序。
可选地,所述装置包括:
代码检测模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,检测所述程序中具有预设执行特性的特征函数代码;
代码确定模块,用于根据所述特征函数代码,确定物理机上可执行的目标函数代码。
可选地,所述预设执行特性包括:所述特征函数代码在所述程序中的运行时间的占比高于预设比值。
可选地,所述代码确定模块包括:
信息确定子模块,用于根据所述特征函数代码,确定所述特征函数代码的描述信息,所述描述信息包括:标识信息、输入信息、功能信息或输出信息中至少一种;
代码确定子模块,用于根据所述描述信息,确定物理机上可执行的目标函数代码。
可选地,所述装置还包括:
信息记录模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,记录所述特征函数代码的内存地址信息;
所述块检测模块包括:
块确定子模块,用于根据所述特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块。
可选地,所述装置包括:
编译模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,根据所述目标函数代码,编译得到目标指令序列;
序列添加模块,用于将所述目标指令序列添加到物理机操作系统中。
可选地,所述序列确定模块包括:
序列查找子模块,用于在所述物理机操作系统中,查找与所述目标基本块对应的目标指令序列。
相应的,本发明实施例还提供了一种电子设备,包括有存储器,以及一个或者一个以上的程序,其中一个或者一个以上程序存储于存储器中,且经配置以由一个或者一个以上处理器执行所述一个或者一个以上程序包含用于进行以下操作的指令:
检测虚拟机上运行的程序的目标基本块,其中,所述目标基本块包括预置有功能相同的目标指令序列的基本块;
确定与所述目标基本块功能相同的预置的目标指令序列,所述目标指令序列由物理机上可执行的目标函数代码编译得到;
采用所述目标指令序列替代所述目标基本块,执行所述程序。
相应的,本发明实施例还提供了一种可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行上述程序执行方法。
依据本发明实施例,通过检测虚拟机上运行的程序的目标基本块,确定与目标基本块功能相同的预置的目标指令序列,采用目标指令序列替代目标基本块,执行程序,由于目标指令序列是由物理机上可执行的目标函数代码编译得到,目标函数代码是针对物理机编写的,且与虚拟机上的目标基本块功能相同,直接对目标函数代码进行编译得到目标指令序列,使得其指令数量远低于二进制翻译得到的指令序列,避免了二进制翻译技术的指令膨胀问题,降低虚拟机对应物理机上执行的指令的数量,提高虚拟机运行效率。
附图说明
图1示出了传统虚拟机的结构的示意图;
图2示出了二进制翻译技术的基本流程的示意图;
图3示出了本发明实施例一的一种程序执行方法的步骤流程图;
图4示出了本发明实施例二的一种程序执行方法的步骤流程图;
图5示出了函数查找的示意图;
图6示出了本发明实施例三的一种程序执行装置实施例的结构框图;
图7示出了根据一示例性实施例示出的一种用于程序执行的电子设备的结构框图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
参照图3,示出了本发明实施例一的一种程序执行方法的步骤流程图,具体可以包括如下步骤:
步骤101,检测虚拟机上运行的程序的目标基本块。
基本块是指程序中一个顺序执行的语句序列,其中只有一个入口和一个出口,入口就是其中的第一个语句,出口就是其中的最后一个语句。对一个基本块来说,执行时只从其入口进入,从其出口退出。例如,在虚拟机上运行一个X86应用程序时,X86应用程序由大量基本块组成,每一个基本块包括一定数量的机器指令。
如果虚拟机和物理机是不同的CPU指令集时,那么虚拟机上运行的程序的基本块中的机器指令是无法在物理机上直接执行的。采用二进制翻译技术,将虚拟机的机器指令转换成能够在物理机上运行的、功能上相同的机器指令,一般会导致指令数量的膨胀,导致虚拟机系统的效率低于物理机系统的效率。
为此在物理机上预先准备与虚拟机上运行的函数具有相同功能的目标指令序列,当检测到虚拟机运行到预置有目标指令序列的函数对应的目标基本块时,即可直接调取物理上预置的目标指令序列来执行,避免对目标基本块进行二进制翻译。
在本发明实施例中,目标基本块包括预置有功能相同的目标指令序列的基本块,例如,目标基本块是程序中调用次数高、涉及大量计算操作、耗用运行时间长的基本块,或者其他任意适用的基本块,本发明实施例对此不做限制。
在本发明实施例中,检测虚拟机上运行的程序的目标基本块的实现方式可以包括:根据特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块,或者其他任意适用的方式,本发明实施例对此不做限制。
步骤102,确定与所述目标基本块功能相同的预置的目标指令序列。
在本发明实施例中,与目标基本块的功能相同,在物理机上可执行的函数代码,记为目标函数代码。例如,依据物理机的CPU指令集,编写的与目标基本块功能相同的目标函数代码。由目标函数代码可以编译得到目标指令序列,因此目标指令序列与目标基本块的功能相同,而且可以在物理机上执行。
在本发明实施例中,目标指令序列可以预置在物理机操作系统中,当虚拟机运行到目标基本块时,在物理机操作系统中,查找与目标基本块对应的目标指令序列,具体还可以包括任意适用的方式,来确定与目标基本块功能相同的预置的目标指令序列,本发明实施例对此不做限制。
步骤103,采用所述目标指令序列替代所述目标基本块,执行所述程序。
在本发明实施例中,确定目标指令序列后,采用目标指令序列替代目标基本块,在物理机上执行,也即是由物理机实际执行虚拟机上运行的程序,当然对于其他基本块,任然采用二进制翻译技术得到指令序列,进行执行,本发明旨在减少对于目标基本块的二进制翻译,继而避免二进制翻译导致的指令膨胀的问题。例如,对于目标基本块,不再使用虚拟机的二进制翻译模块进行模拟执行,而是直接调用物理机上相应平台的目标函数代码对应的目标指令序列,并将目标指令序列的执行结果直接作为目标基本块的返回结果。
依据本发明实施例,通过检测虚拟机上运行的程序的目标基本块,确定与目标基本块功能相同的预置的目标指令序列,采用目标指令序列替代目标基本块,执行程序,由于目标指令序列是由物理机上可执行的目标函数代码编译得到,目标函数代码是针对物理机编写的,且与虚拟机上的目标基本块功能相同,直接对目标函数代码进行编译得到目标指令序列,使得其指令数量远低于二进制翻译得到的指令序列,避免了二进制翻译技术的指令膨胀问题,降低虚拟机对应物理机上执行的指令的数量,提高虚拟机运行效率。
参照图4,示出了本发明实施例二的一种程序执行方法的步骤流程图,具体可以包括如下步骤:
步骤201,检测所述程序中具有预设执行特性的特征函数代码。
在本发明实施例中,为了减少预置目标指令序列的成本,不必对程序中所有的函数代码都预置对应的指令序列。根据需要检测程序中具有预设执行特性的特征函数代码,仅对特征函数代码,确定物理机上可执行的目标函数代码即可,再由目标函数代码编译得到目标指令序列。
在本发明实施例中,预设执行特性包括涉及计算操作多、调用次数高、耗用应用程序的运行时间长等,或者其他任意适用的执行特性,本发明实施例对此不做限制。例如,一个用于查看图片的应用程序,绝大部分运行时间是体现在图片数据的解码函数,在应用程序中都要编写jpeg、png、bmp等格式的图片解码函数,涉及大量的计算操作,调用次数高,耗用了应用程序绝大部分的运行时间,这样的函数都可以称为特征函数代码。对于虚拟机来说,只要对这样的特征函数代码进行模拟加速,往往就能够得到明显的提速效果。
在本发明实施例中,检测程序中具有预设执行特征的特征函数代码的方式可以包括多种,例如,采用自动化的性能分析工具(例如Intel Vtune,Linux下的gprof、Oprofile等等),将一个应用程序在性能分析工具中运行一遍,筛选出其中计算操作超过计算阈值、和/或调用次数超过次数阈值、和/或运行时间超过时间阈值的函数,确定为特征函数代码,或者其他任意适用的方式,本发明实施例对此不做限制。
在本发明实施例中,优选地,预设执行特性包括:特征函数代码在程序中的运行时间的占比高于预设比值。预设比值可以根据实际需要进行设定,例如,为开发者提供多种深度的优化选项,对应不同的预设比值,以筛选出不同数量的特征函数代码,优化深度越深,得到的特征函数代码的数量越多。
步骤202,记录所述特征函数代码的内存地址信息。
在本发明实施例中,为了后续检测目标基本块,需要先记录特征函数代码的内存地址信息。内存地址信息包括函数的内存入口地址,或者其他任意适用的地址信息,本发明实施例对此不做限制。
例如,任何应用程序本身都带有一个符号表,记录了这个应用程序包含的函数名称和内存入口地址。为了识别X86应用程序的特征函数代码,可以采用自动化的性能分析工具,将一个应用程序在性能分析工具中运行一遍,性能分析工具自动打印出每个函数执行的时间比例,其中占用时间比例高的函数即为热点函数(即特征函数代码)。对于要预置目标指令序列的应用程序,可以得到“热点函数列表”:
应用程序的热点函数列表={内存入口地址,函数名称}。
步骤203,根据所述特征函数代码,确定物理机上可执行的目标函数代码。
在本发明实施例中,特征函数代码是在虚拟机上运行的,依据虚拟机的CPU指令集编写而成,而目标函数代码是要在物理机上运行的,需要依据物理机的CPU指令集编写。根据特征函数代码,对应得到功能相同的目标函数代码。
在本发明实施例中,优选地,根据所述特征函数代码,确定物理机上可执行的目标函数代码的一种实现方式可以包括:根据特征函数代码,确定特征函数代码的描述信息,根据描述信息,确定物理机上可执行的目标函数代码。
描述信息包括:标识信息、输入信息、功能信息或输出信息中至少一种,描述信息用于描述特征函数代码所实现的功能,例如,对“热点函数列表”的每一个函数,一般可以通过函数名称、参数类型推测其功能。如jpeg、png、bmp等格式都是有标准的规范,数据的操作一般是有常规的方式。所以图片解码函数可以确定输入数据、计算功能、输出结果,从而得到“热点函数规格说明(即描述信息)”:热点函数规格说明={函数名称,输入数据,计算功能,输出结果}。
在确定特征函数代码的描述信息后,就可以根据特征函数代码的描述信息,编写源代码,即与特征函数代码功能相同的目标函数代码。
步骤204,根据所述目标函数代码,编译得到目标指令序列。
在本发明实施例中,目标函数代码是可以在物理机上运行的,具体需要将目标函数代码使用物理机的编译器编译成物理机上可执行的机器指令,即目标指令序列。目标指令序列的功能与目标函数代码完全等价,目标函数代码的功能与特征函数代码完全等价,因此目标指令序列的功能与特征函数代码完全等价。
步骤205,将所述目标指令序列添加到物理机操作系统中。
在本发明实施例中,编译得到的目标指令序列,需要添加到物理机操作系统中,以供虚拟机在需要时从物理机操作系统中调用。
步骤206,根据所述特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块。
在本发明实施例中,由于预先记录了特征函数代码的内存地址信息,因此在虚拟机运行到各个基本块时,根据记录的特征函数代码的内存地址信息和基本块的内存地址信息,通过比较,如果内存地址信息一致,就可以确定基本块是目标基本块。例如,如图5所示的函数查找示意图,虚拟机对于每一个要运行的基本块,将基本块的内存起始地址与“热点函数列表”中的内存入口地址相比较,确定这个基本块是否属于已知的热点函数(即特征函数代码),如果属于已知的热点函数,即表明基本块为有预置的目标指令序列的目标基本块。
步骤207,在所述物理机操作系统中,查找与所述目标基本块对应的目标指令序列。
在本发明实施例中,确定目标基本块后,在物理机操作系统中,查找与目标基本块对应的目标指令序列。例如,在物理机操作系统中,添加目标指令序列时,用特征函数代码的内存地址信息作为标识,用目标基本块的内存地址信息作为关键词,就可以搜索到对应的目标指令序列,具体可以包括任意适用的方式查找,本发明实施例对此不做限制。
步骤208,采用所述目标指令序列替代所述目标基本块,执行所述程序。
在本发明实施例中,此步骤的具体实现方式可以参见前述实施例中的描述,此处不另赘述。
依据本发明实施例,通过检测程序中具有预设执行特性的特征函数代码,记录特征函数代码的内存地址信息,根据特征函数代码,确定物理机上可执行的目标函数代码,根据目标函数代码,编译得到目标指令序列,将目标指令序列添加到物理机操作系统中,根据特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块,在物理机操作系统中,查找与目标基本块对应的目标指令序列,采用目标指令序列替代目标基本块,执行程序,由于目标指令序列是由物理机上可执行的目标函数代码编译得到,目标函数代码是针对物理机编写的,且与虚拟机上的目标基本块功能相同,直接对目标函数代码进行编译得到目标指令序列,使得其指令数量远低于二进制翻译得到的指令序列,避免了二进制翻译技术的指令膨胀问题,降低虚拟机对应物理机上执行的指令的数量,提高虚拟机运行效率。而且仅针对检测到的程序中的特征函数代码,预置目标指令序列,而不必对程序中所有的函数预置目标指令序列,减少了预置目标指令序列的成本。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
参照图6,示出了本发明实施例三的一种程序执行装置实施例的结构框图,具体可以包括如下模块:
块检测模块301,用于检测虚拟机上运行的程序的目标基本块,其中,所述目标基本块包括预置有功能相同的目标指令序列的基本块;
序列确定模块302,用于确定与所述目标基本块功能相同的预置的目标指令序列,所述目标指令序列由物理机上可执行的目标函数代码编译得到;
执行模块303,用于采用所述目标指令序列替代所述目标基本块,执行所述程序。
在本发明实施例中,优选地,所述装置包括:
代码检测模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,检测所述程序中具有预设执行特性的特征函数代码;
代码确定模块,用于根据所述特征函数代码,确定物理机上可执行的目标函数代码。
在本发明实施例中,优选地,所述预设执行特性包括:所述特征函数代码在所述程序中的运行时间的占比高于预设比值。
在本发明实施例中,优选地,所述代码确定模块包括:
信息确定子模块,用于根据所述特征函数代码,确定所述特征函数代码的描述信息,所述描述信息包括:标识信息、输入信息、功能信息或输出信息中至少一种;
代码确定子模块,用于根据所述描述信息,确定物理机上可执行的目标函数代码。
在本发明实施例中,优选地,所述装置还包括:
信息记录模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,记录所述特征函数代码的内存地址信息;
所述块检测模块包括:
块确定子模块,用于根据所述特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块。
在本发明实施例中,优选地,所述装置包括:
编译模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,根据所述目标函数代码,编译得到目标指令序列;
序列添加模块,用于将所述目标指令序列添加到物理机操作系统中。
在本发明实施例中,优选地,所述序列确定模块包括:
序列查找子模块,用于在所述物理机操作系统中,查找与所述目标基本块对应的目标指令序列。
依据本发明实施例,通过检测虚拟机上运行的程序的目标基本块,确定与目标基本块功能相同的预置的目标指令序列,采用目标指令序列替代目标基本块,执行程序,由于目标指令序列是由物理机上可执行的目标函数代码编译得到,目标函数代码是针对物理机编写的,且与虚拟机上的目标基本块功能相同,直接对目标函数代码进行编译得到目标指令序列,使得其指令数量远低于二进制翻译得到的指令序列,避免了二进制翻译技术的指令膨胀问题,降低虚拟机对应物理机上执行的指令的数量,提高虚拟机运行效率。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
图7是根据一示例性实施例示出的一种用于程序执行电子设备700的结构框图。例如,电子设备700可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图7,电子设备700可以包括以下一个或多个组件:处理组件702,存储器704,电源组件706,多媒体组件708,音频组件710,输入/输出(I/O)的接口712,传感器组件714,以及通信组件716。
处理组件702通常控制电子设备700的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理元件702可以包括一个或多个处理器720来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件702可以包括一个或多个模块,便于处理组件702和其他组件之间的交互。例如,处理部件702可以包括多媒体模块,以方便多媒体组件708和处理组件702之间的交互。
存储器704被配置为存储各种类型的数据以支持在设备700的操作。这些数据的示例包括用于在电子设备700上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器704可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电力组件704为电子设备700的各种组件提供电力。电力组件704可以包括电源管理系统,一个或多个电源,及其他与为电子设备700生成、管理和分配电力相关联的组件。
多媒体组件708包括在所述电子设备700和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件708包括一个前置摄像头和/或后置摄像头。当电子设备700处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件710被配置为输出和/或输入音频信号。例如,音频组件710包括一个麦克风(MIC),当电子设备700处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器704或经由通信组件716发送。在一些实施例中,音频组件710还包括一个扬声器,用于输出音频信号。
I/O接口712为处理组件702和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件714包括一个或多个传感器,用于为电子设备700提供各个方面的状态评估。例如,传感器组件714可以检测到设备700的打开/关闭状态,组件的相对定位,例如所述组件为电子设备700的显示器和小键盘,传感器组件714还可以检测电子设备700或电子设备700一个组件的位置改变,用户与电子设备700接触的存在或不存在,电子设备700方位或加速/减速和电子设备700的温度变化。传感器组件714可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件714还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件714还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件716被配置为便于电子设备700和其他设备之间有线或无线方式的通信。电子设备700可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信部件714经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信部件714还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备700可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器704,上述指令可由电子设备700的处理器720执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
一种非临时性计算机可读存储介质,当所述存储介质中的指令由终端的处理器执行时,使得终端能够执行一种程序执行方法,所述方法包括:
检测虚拟机上运行的程序的目标基本块,其中,所述目标基本块包括预置有功能相同的目标指令序列的基本块;
确定与所述目标基本块功能相同的预置的目标指令序列,所述目标指令序列由物理机上可执行的目标函数代码编译得到;
采用所述目标指令序列替代所述目标基本块,执行所述程序。
可选地,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法包括:
检测所述程序中具有预设执行特性的特征函数代码;
根据所述特征函数代码,确定物理机上可执行的目标函数代码。
可选地,所述预设执行特性包括:所述特征函数代码在所述程序中的运行时间的占比高于预设比值。
可选地,所述根据所述特征函数代码,确定物理机上可执行的目标函数代码包括:
根据所述特征函数代码,确定所述特征函数代码的描述信息,所述描述信息包括:标识信息、输入信息、功能信息或输出信息中至少一种;
根据所述描述信息,确定物理机上可执行的目标函数代码。
可选地,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法还包括:
记录所述特征函数代码的内存地址信息;
所述检测虚拟机上运行的程序的目标基本块包括:
根据所述特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块。
可选地,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法包括:
根据所述目标函数代码,编译得到目标指令序列;
将所述目标指令序列添加到物理机操作系统中。
可选地,所述确定与所述目标基本块功能相同的预置的目标指令序列包括:
在所述物理机操作系统中,查找与所述目标基本块对应的目标指令序列。
可选地,在所述检测虚拟机上运行的程序的目标基本块之后,所述方法包括:
针对除目标基本块之外的基本块,采用二进制翻译得到对应的指令序列。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或计算机程序产品。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本发明实施例的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本发明实施例范围的所有变更和修改。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
以上对本发明所提供的一种程序执行方法、一种程序执行装置,进行了详细介绍,本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。
Claims (16)
1.一种程序执行方法,其特征在于,包括:
检测虚拟机上运行的程序的目标基本块,其中,所述目标基本块包括预置有功能相同的目标指令序列的基本块;
确定与所述目标基本块功能相同的预置的目标指令序列,所述目标指令序列由物理机上可执行的目标函数代码编译得到;
采用所述目标指令序列替代所述目标基本块,执行所述程序。
2.根据权利要求1所述的方法,其特征在于,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法包括:
检测所述程序中具有预设执行特性的特征函数代码;
根据所述特征函数代码,确定物理机上可执行的目标函数代码。
3.根据权利要求2所述的方法,其特征在于,所述预设执行特性包括:所述特征函数代码在所述程序中的运行时间的占比高于预设比值。
4.根据权利要求2所述的方法,其特征在于,所述根据所述特征函数代码,确定物理机上可执行的目标函数代码包括:
根据所述特征函数代码,确定所述特征函数代码的描述信息,所述描述信息包括:标识信息、输入信息、功能信息或输出信息中至少一种;
根据所述描述信息,确定物理机上可执行的目标函数代码。
5.根据权利要求2所述的方法,其特征在于,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法还包括:
记录所述特征函数代码的内存地址信息;
所述检测虚拟机上运行的程序的目标基本块包括:
根据所述特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块。
6.根据权利要求1所述的方法,其特征在于,在所述检测虚拟机上运行的程序的目标基本块之前,所述方法包括:
根据所述目标函数代码,编译得到目标指令序列;
将所述目标指令序列添加到物理机操作系统中。
7.根据权利要求6所述的方法,其特征在于,所述确定与所述目标基本块功能相同的预置的目标指令序列包括:
在所述物理机操作系统中,查找与所述目标基本块对应的目标指令序列。
8.一种程序执行装置,其特征在于,包括:
块检测模块,用于检测虚拟机上运行的程序的目标基本块,其中,所述目标基本块包括预置有功能相同的目标指令序列的基本块;
序列确定模块,用于确定与所述目标基本块功能相同的预置的目标指令序列,所述目标指令序列由物理机上可执行的目标函数代码编译得到;
执行模块,用于采用所述目标指令序列替代所述目标基本块,执行所述程序。
9.根据权利要求8所述的装置,其特征在于,所述装置包括:
代码检测模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,检测所述程序中具有预设执行特性的特征函数代码;
代码确定模块,用于根据所述特征函数代码,确定物理机上可执行的目标函数代码。
10.根据权利要求9所述的装置,其特征在于,所述预设执行特性包括:所述特征函数代码在所述程序中的运行时间的占比高于预设比值。
11.根据权利要求9所述的装置,其特征在于,所述代码确定模块包括:
信息确定子模块,用于根据所述特征函数代码,确定所述特征函数代码的描述信息,所述描述信息包括:标识信息、输入信息、功能信息或输出信息中至少一种;
代码确定子模块,用于根据所述描述信息,确定物理机上可执行的目标函数代码。
12.根据权利要求9所述的装置,其特征在于,所述装置还包括:
信息记录模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,记录所述特征函数代码的内存地址信息;
所述块检测模块包括:
块确定子模块,用于根据所述特征函数代码的内存地址信息和各个基本块的内存地址信息,确定目标基本块。
13.根据权利要求8所述的装置,其特征在于,所述装置包括:
编译模块,用于在所述检测虚拟机上运行的程序的目标基本块之前,根据所述目标函数代码,编译得到目标指令序列;
序列添加模块,用于将所述目标指令序列添加到物理机操作系统中。
14.根据权利要求13所述的装置,其特征在于,所述序列确定模块包括:
序列查找子模块,用于在所述物理机操作系统中,查找与所述目标基本块对应的目标指令序列。
15.一种电子设备,其特征在于,包括有存储器,以及一个或者一个以上的程序,其中一个或者一个以上程序存储于存储器中,且经配置以由一个或者一个以上处理器执行所述一个或者一个以上程序包含用于进行以下操作的指令:
检测虚拟机上运行的程序的目标基本块,其中,所述目标基本块包括预置有功能相同的目标指令序列的基本块;
确定与所述目标基本块功能相同的预置的目标指令序列,所述目标指令序列由物理机上可执行的目标函数代码编译得到;
采用所述目标指令序列替代所述目标基本块,执行所述程序。
16.一种可读存储介质,其特征在于,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如方法权利要求1-7中一个或多个所述的程序执行方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811015357.1A CN110874259A (zh) | 2018-08-31 | 2018-08-31 | 程序执行方法、装置、设备和存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811015357.1A CN110874259A (zh) | 2018-08-31 | 2018-08-31 | 程序执行方法、装置、设备和存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN110874259A true CN110874259A (zh) | 2020-03-10 |
Family
ID=69715946
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811015357.1A Pending CN110874259A (zh) | 2018-08-31 | 2018-08-31 | 程序执行方法、装置、设备和存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110874259A (zh) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116610325A (zh) * | 2023-07-20 | 2023-08-18 | 龙芯中科技术股份有限公司 | 二进制翻译方法、装置、电子设备及存储介质 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1892602A (zh) * | 2005-07-01 | 2007-01-10 | 中国科学院计算技术研究所 | 一种二进制翻译中库函数调用的处理方法 |
CN101256504A (zh) * | 2008-03-17 | 2008-09-03 | 中国科学院计算技术研究所 | 一种支持x86虚拟机的risc处理器装置及方法 |
US7734895B1 (en) * | 2005-04-28 | 2010-06-08 | Massachusetts Institute Of Technology | Configuring sets of processor cores for processing instructions |
CN103793260A (zh) * | 2013-10-09 | 2014-05-14 | 中国电子设备系统工程公司研究所 | 一种平台虚拟化系统 |
CN105843664A (zh) * | 2016-04-20 | 2016-08-10 | 中国工程物理研究院计算机应用研究所 | 一种动态二进制翻译中基于代码热度的翻译缓存管理方法 |
-
2018
- 2018-08-31 CN CN201811015357.1A patent/CN110874259A/zh active Pending
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7734895B1 (en) * | 2005-04-28 | 2010-06-08 | Massachusetts Institute Of Technology | Configuring sets of processor cores for processing instructions |
CN1892602A (zh) * | 2005-07-01 | 2007-01-10 | 中国科学院计算技术研究所 | 一种二进制翻译中库函数调用的处理方法 |
CN101256504A (zh) * | 2008-03-17 | 2008-09-03 | 中国科学院计算技术研究所 | 一种支持x86虚拟机的risc处理器装置及方法 |
CN103793260A (zh) * | 2013-10-09 | 2014-05-14 | 中国电子设备系统工程公司研究所 | 一种平台虚拟化系统 |
CN105843664A (zh) * | 2016-04-20 | 2016-08-10 | 中国工程物理研究院计算机应用研究所 | 一种动态二进制翻译中基于代码热度的翻译缓存管理方法 |
Non-Patent Citations (3)
Title |
---|
廖银等: "动态二进制翻译中全寄存器直接映射方法", 《计算机应用与软件》 * |
石强: "面向国产处理器的二进制翻译关键优化技术研究", 《中国优秀博硕士学位论文全文数据库(硕士) 信息科技辑》 * |
高亚虎等: "一种基于二进制翻译的共享库文件移植技术", 《信息工程大学学报》 * |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116610325A (zh) * | 2023-07-20 | 2023-08-18 | 龙芯中科技术股份有限公司 | 二进制翻译方法、装置、电子设备及存储介质 |
CN116610325B (zh) * | 2023-07-20 | 2023-11-10 | 龙芯中科技术股份有限公司 | 二进制翻译方法、装置、电子设备及存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106991018B (zh) | 界面换肤的方法及装置 | |
CN109947671B (zh) | 一种地址转换方法、装置、电子设备及储存介质 | |
CN109725943B (zh) | 一种程序跳转方法、装置、电子设备及存储介质 | |
CN105183571A (zh) | 函数调用方法和装置 | |
CN111061452A (zh) | 用户界面的语音控制方法和装置 | |
CN113377370A (zh) | 一种文件处理方法、装置、电子设备及存储介质 | |
CN106293683B (zh) | 一种项目的编译方法及装置 | |
CN110874259A (zh) | 程序执行方法、装置、设备和存储介质 | |
CN111221593A (zh) | 一种动态加载方法及装置 | |
CN112667852B (zh) | 基于视频的搜索方法、装置、电子设备及存储介质 | |
CN108427568B (zh) | 用户界面的更新方法及装置 | |
CN108549570B (zh) | 用户界面的更新方法及装置 | |
CN107526683B (zh) | 应用程序功能冗余度的检测方法、装置及存储介质 | |
CN110673850A (zh) | 一种获取静态库的大小的方法及装置 | |
CN107193622B (zh) | 代码编译的处理方法、装置及终端 | |
CN112083981A (zh) | 一种页面视图组件的创建方法和装置 | |
CN112445484A (zh) | 一种寄存器处理方法、装置、电子设备及存储介质 | |
CN112181406A (zh) | 一种渲染引擎的共享方法和装置 | |
CN113946346B (zh) | 一种数据处理方法、装置、电子设备及存储介质 | |
CN111596949B (zh) | 一种开发应用程序的方法及装置 | |
CN114020505B (zh) | 一种数据处理方法、装置、电子设备及存储介质 | |
CN112346968B (zh) | 一种多媒体文件清晰度的自动化检测方法及装置 | |
CN114020694B (zh) | 一种头文件地址的获取方法、装置、电子设备及存储介质 | |
CN111880696B (zh) | 一种基于百科的数据处理方法及装置 | |
CN114416085A (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 | ||
CB02 | Change of applicant information |
Address after: 100095 Building 2, Longxin Industrial Park, Zhongguancun environmental protection technology demonstration park, Haidian District, Beijing Applicant after: Loongson Zhongke Technology Co.,Ltd. Address before: 100095 Building 2, Longxin Industrial Park, Zhongguancun environmental protection technology demonstration park, Haidian District, Beijing Applicant before: LOONGSON TECHNOLOGY Corp.,Ltd. |
|
CB02 | Change of applicant information | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20200310 |
|
RJ01 | Rejection of invention patent application after publication |