An emulation device 3 includes a storage unit 70 which stores information in which instruction information 710 including a type of an instruction 711 and an operand 712 included in emulation-execution-target-software 71, compiled instruction information 72 obtained by compiling the instruction information 710 capable of being emulated, and information 73 indicating a storage address of the compiled instruction information 72 are associated with, and a generation unit 80 which generates compiled software 81 that is compiled for the emulation-execution-target-software 71 capable of being emulated by converting the instruction information 710 into the subroutine-read-instruction-information which calls the compiled instruction information 72 associated with the instruction information 710 from the storage address.
| 
 | 8.  An emulation method for optimizing emulation of an emulation-execution-target-software written for a target environment for emulation in a host environment comprising:
 storing, in a target code space, instruction information for each instruction of the emulation-execution-target-software including a type of the instruction and an operand included in the instruction; storing, in a host code space, a subroutine program group, wherein each subroutine in the subroutine program group is a complied emulation code written in a host code for the each instruction of the emulation-execution-target-software using the stored instruction information; storing, in the host code space, a compiled software group comprising of sets of one or more compiled software, wherein the sets of one or more compiled software is a result obtained by compiling at least a part of the emulation-execution-target-software, wherein each instruction of the emulation-execution-target-software in the compiled software is replaced by a call to a corresponding subroutine from the subroutine program group written in the host code; storing, in the host code space, storage address of each of the one or more sets of the compiled software so that the emulation-execution-target-software can be emulated using the compiled software and the corresponding storage address; emulating the emulation-execution-target-software on the host by executing the one or more sets of compiled software, which in turn calls the corresponding subroutines of the compiled emulation code written in the host code; determining whether a number of times of execution of a compiled software of the one or more sets of compiled software exceeds a threshold value; and in response to the determination, obtaining the compiled software and updating call instructions to the subroutines in the compiled software with compiled emulation code of the subroutine, thereby causing improved speed of execution by an emulation processor executing the emulation-execution-target software that has been compiled and in which the compiled software has been updated with compiled emulation code of subroutines. 9.  A non-transitory computer readable recording medium storing an emulation program for optimizing emulation of an emulation-execution-target-software written for a target environment for emulation in a host environment, the program when executed by a computer causes the computer to perform a method, the method comprising:
 storing, in a target code space, instruction information for each instruction of the emulation-execution-target-software including a type of the instruction and an operand included in the instruction; storing, in a host code space, a subroutine program group, wherein each subroutine in the subroutine program group is a complied emulation code written in a host code for the each instruction of the emulation-execution-target-software using the stored instruction information; storing, in the host code space, a compiled software group comprising of sets of one or more compiled software, wherein the sets of one or more compiled software is a result obtained by compiling at least a part of the emulation-execution-target-software, wherein each instruction of the emulation-execution-target-software in the compiled software is replaced by a call to a corresponding subroutine from the subroutine program group written in the host code; storing, in the host code space, storage address of each of the one or more sets of the compiled software so that the emulation-execution-target-software can be emulated using the compiled software and the corresponding storage address; emulating the emulation-execution-target-software on the host by executing the one or more sets of compiled software, which in turn calls the corresponding subroutines of the compiled emulation code written in the host code; determining whether a number of times of execution of a compiled software of the one or more sets of compiled software exceeds a threshold value; and in response to the determination, obtaining the compiled software and updating call instructions to the subroutines in the compiled software with compiled emulation code of the subroutine, thereby causing improved speed of execution by an emulation processor executing the emulation-execution-target software that has been compiled and in which the compiled software has been updated with compiled emulation code of subroutines. 1.  An emulation device for optimizing emulation of an emulation-execution-target-software written for a target environment for emulation in a host environment comprising:
 a compilation processor, an emulation processor and an optimization processor; and a memory storing instructions to be executed by the processors by causing the processors to execute: storing, in a target code space, instruction information for each instruction of the emulation-execution-target-software including a type of the instruction and an operand included in the instruction; storing, in a host code space, a subroutine program group, wherein each subroutine in the subroutine program group is a complied emulation code written in a host code for the each instruction of the emulation-execution-target-software using the stored instruction information; storing, in the host code space, a compiled software group comprising of sets of one or more compiled software, wherein the sets of one or more compiled software is a result obtained by compiling at least a part of the emulation-execution-target-software, wherein each instruction of the emulation-execution-target-software in the compiled software is replaced by a call to a corresponding subroutine from the subroutine program group written in the host code; storing, in the host code space, storage address of each of the one or more sets of the compiled software so that the emulation-execution-target-software can be emulated using the compiled software and the corresponding storage address; emulating the emulation-execution-target-software on the host by executing the one or more sets of compiled software, which in turn calls the corresponding subroutines of the compiled emulation code written in the host code; determining whether a number of times of execution of a compiled software of the one or more sets of compiled software exceeds a threshold value; and in response to the determination, obtaining the compiled software and updating call instructions to the subroutines in the compiled software with compiled emulation code of the subroutine, thereby causing improved speed of execution by the emulation processor executing the emulation-execution-target software that has been compiled and in which the compiled software has been updated with compiled emulation code of subroutines. 2.  The emulation device according to  the processors store a compiled instruction information generated on the basis of a value indicated by the type of the instruction and a value indicated by the operand. 3.  The emulation device according to  with respect to two sets of the instruction information sequentially executed in the emulation-execution-target-software, when the preceding instruction information indicates an instruction other than a branch instruction, the processors generate the compiled software in which the preceding instruction information is converted into a subroutine-read-instruction-information and then the subsequent instruction information is converted into a subroutine-read-instruction-information, and when the preceding instruction information indicates a branch instruction, the processors generate the compiled software in which a return instruction that is an instruction to end the execution of the compiled software is inserted after the preceding instruction information. 4.  The emulation device according to  executing the emulation of the emulation-execution-target-software by using the compiled software; wherein generating one or more sets of the compiled software, associates the generated compiled software with a value that indicates an instruction pointer showing an execution address in the emulation-execution-target-software which is associated with the compiled software, and stores the generated compiled software; and reading out the compiled software as has been stored and execute the compiled software when the compiled software associated with the value indicated by the instruction pointer. 5.  The emulation device according to  the processors generate the compiled software obtained by compiling the instruction information indicated by the instruction pointer and executes the emulation of the instruction information indicated by the instruction pointer by an interpreter method when the compiled software associated with the value indicated by the instruction pointer is not stored; and the processors generate the compiled software by compiling the instruction information indicated by the instruction pointer according to the instruction. 6.  The emulation device according to  the processors register the value indicated by the instruction pointer showing the instruction information, that is a target of an instruction for generating the compiled software, in any of one or more entries that have been stored; and the processors generate the compiled software by compiling the instruction information specified by the value indicated by the instruction pointer registered in the entry. 7.  The emulation device according to  the processors update the number of times of execution when the compiled software is emulated, and add information indicating the operation to store the updated number of times of execution to the compiled software; and the processors refer to the number of times of execution as has been stored. | |||||||||||||||||||||||||||||||||
This application is based upon and claims the benefit of priority from Japanese Patent Application No. 2016-160017, filed on Aug. 17, 2016, the disclosure of which is incorporated herein in its entirety by reference.
The present invention relates to a technology for compiling software that is an execution target of emulation so that the software can be emulated.
In modern society, the architecture of a computer system rapidly progresses. However, for example, when there is no compatibility between the old and new architectures, the computer system with new architecture cannot use the software resources for the computer system with old architecture just as it is. In such case, the computer system with new architecture can use the software sources for the computer system with old architecture by performing emulation.
For example, because the software resources developed for a mainframe in the past can be used by a current open server by performing emulation, the enormous software resources developed for the mainframe can be effectively utilized. However, when software is executed by emulating the software, the execution speed decreases in comparison with a case in which the software is executed directly. Accordingly, in a case in which the software is executed by emulating the software, a technology to increase the execution speed of the software is awaited.
As a technology related to such technology, in a patent literature 1 (Japanese Patent Application Laid-open Publication No. 2010-140233), there is disclosed an emulation system including a compilation processor and an emulation processor. The compilation processor in this system reads out an instruction from a target code, analyzes it, and generates a host code for emulating the instruction. The emulation processor executes the host code in a compilation mode in which the host code is generated by the compilation processor. The emulation processor reads out the instruction from the next target code, analyzes it, and emulates the instruction in an interpreter mode in which the host code is not generated by the compilation processor.
Further, in a patent literature 2 (Japanese Patent No. 4713820), there is disclosed a program execution control device in which it is determined whether or not a method is not compiled when the method is called in the execution processing of a program. When the method is not compiled, this device executes a byte code of the method in an interpreter processing and also requests the compilation of the method. When the method has been already compiled, this device executes a native code of the method. This device performs the compilation of the method to which the compilation is requested in a task other than the task for executing the instruction such as the execution of the byte code in the interpreter processing or the execution of the native code.
As disclosed in the patent literature 1 and the patent literature 2, the execution speed of the software that is executed by emulation can be increased by performing both the compilation processing and the interpreter processing to the software that is an execution target. In this case, especially, the execution speed can be largely increased by the compilation processing. However, when the configuration disclosed in patent literature 1 and patent literature 2 is used, the execution speed of the software cannot be sufficiently increased by the compilation processing. Accordingly, a technology to further increase the execution speed of the software by the compilation processing is awaited. A main object of the present invention is to provide an emulation device or the like which can solve such problem.
An emulation device according to one aspect of the present invention includes: a storage unit configured to store information in which instruction information including a type of an instruction and an operand included in emulation-execution-target-software, compiled instruction information obtained by compiling the instruction information capable of being emulated, and information indicating a storage address of the compiled instruction information are associated with; and a generation unit configured to generate compiled software that is compiled for the emulation-execution-target-software capable of being emulated by converting the instruction information into subroutine-read-instruction-information which calls the compiled instruction information associated with the instruction information from the storage address.
From another point of view for achieving the object mentioned above, an emulation method according to one aspect of the present invention includes, in a case that information in which instruction information including a type of an instruction and an operand included in emulation-execution-target-software, compiled instruction information obtained by compiling the instruction information capable of being emulated, and information indicating a storage address of the compiled instruction information are associated with is stored in a storage unit: by an information processing device, generating compiled software that is compiled for the emulation-execution-target-software capable of being emulated by converting the instruction information into subroutine-read-instruction-information which calls the compiled instruction information associated with the instruction information from a storage address.
Further, from another point of view for achieving the object mentioned above, an emulation program according to one aspect of the present invention is a program which causes a computer which is able to access a storage unit storing information in which instruction information including a type of an instruction and an operand included in emulation-execution-target-software, compiled instruction information obtained by compiling the instruction information capable of being emulated, and information indicating a storage address of the compiled instruction information are associated with, to perform: a generation processing for generating the complied software that is compiled for the emulation-execution-target-software to be able to be emulated by converting the instruction information into subroutine-read-instruction-information which calls the compiled instruction information associated with the instruction information from the storage address.
Moreover, the present invention can be realized by a computer-readable non-transitory recording medium storing an emulation program (computer program).
The present invention can increase the execution speed of the software that is executed by emulation.
Exemplary features and advantages of the present invention will become apparent from the following detailed description when taken with the accompanying drawings in which:
An example embodiment of the present invention will be described in detail below with reference to a drawing.
The emulation device 1 according to this example embodiment is composed of the following components:
a compilation processor 10,
an emulation processor 20,
a main storage 30,
an input/output processor 40,
a system bus 50,
an input/output I/F (interface) 41,
a communication I/F 42,
a hard disk 43, and
a reader/writer 44.
As shown in 
The input/output processor 40 is connected to the input/output I/F 41, the communication I/F 42, the hard disk 43, and the reader/writer 44 so as to be communicable. The input/output I/F 41 is a device such as a keyboard, a mouse, a monitor device, or the like which inputs and outputs information. The input/output processor 40 reads a computer program and data recorded in various recording media 45 such as a CD-ROM and the like via the reader/writer 44 and then stores the read computer program and data in the main storage 30. The input/output processor 40 may download the computer program and data to be stored in the main storage 30 from the outside via the communication I/F 42 connected to a communication line such as the Internet or the like.
In this present application, an instruction code (in other words, an instruction code that can be executed by an information processing device with architecture different from that of the emulation device 1) included in software that is the target of emulation performed by the emulation device 1 is defined as a target code. In this present application, the instruction code which can be executed by the emulation device 1 without converting it is defined as a host code.
The main storage 30 according to this example embodiment includes a target code space 31, a target data space 32, a host code space 33, and a host data space 34 as an address space (a storage area).
The target code space 31 is the address space of the main storage 30 in which the software (program) composed of the target code is stored and emulation-execution-target-software 310 is stored therein. The emulation-execution-target-software 310 is the software that is the target of emulation performed by the emulation device 1.
The target data space 32 is the address space of the main storage 30 in which data composed of the target code is stored and data 320 for emulation-execution-target-software is stored therein. The data 320 for emulation-execution-target-software is data inputted or outputted when the emulation-execution-target-software 310 is executed.
The host code space 33 is the address space of the main storage 30 in which software composed of the host code is stored and a compilation program 330, an emulation program 331, an emulation code group 332, and a compiled software group 333 are stored therein. The compilation program 330 is a program used for a processing (generation processing) for generating software that is a compilation result obtained by compiling the emulation-execution-target-software 310 and executed by the compilation processor 10. The emulation program 331 is a program used for a processing (execution processing) for emulating the emulation-execution-target-software 310 and executed by the emulation processor 20.
The emulation code group 332 is a subroutine program group written in the host code for each instruction information included in the emulation-execution-target-software 310. The emulation code group 332 further includes a program written in the host code used when the emulation-execution-target-software 310 is emulated by a processing (interpreter processing) using an interpreter method. The compiled software group 333 is a program group that is a result obtained by compiling at least a part of the emulation-execution-target-software 310 so that it can be emulated.
The host data space 34 is the address space of the main storage 30 in which data composed of the host code is stored and data 340 for compilation program, data 341 for emulation program, data 342 for I/F (interface) between processors, and compiled software management information 343 are stored therein. The data 340 for compilation program is data inputted or outputted when the compilation program 330 is executed. The data 341 for emulation program is data inputted or outputted when the emulation program 331 is executed.
The data 342 for I/F between processors is the data inputted and outputted between the compilation processor 10 and the emulation processor 20 when these processors cooperate with each other and emulate the emulation-execution-target-software 310. The compiled software management information 343 is information (data) for managing each compiled software included in the compiled software group 333.
Each of the software and data stored in the main storage 30 mentioned above will be described later as needed.
The emulation processor 20 and the compilation processor 10 according to the first example embodiment will be described in detail below.
(Emulation Processor 20)
The emulation processor 20 according to this example embodiment reads out the emulation program 331 from the main storage 30, executes it, and emulates the emulation-execution-target-software 310.
In this example embodiment, an instruction sequence including one or more instructions included in the emulation-execution-target-software 310 is compiled by the compilation processor 10. A result of the compilation is stored in the main storage 30 as the compiled software group 333. In an example shown in 
When the emulation processor 20 emulates the instruction sequence composed of the instruction X, the instruction Y, and the instruction Z exemplarily shown in 
The emulation processor 20 may emulate the emulation-execution-target-software 310 by an interpreter method in which the emulation-execution-target-software 310 is emulated by analyzing the instruction included in the emulation-execution-target-software 310 one by one sequentially. Accordingly, when the compiled software 333-1 is not stored in the main storage 30, the emulation processor 20 emulates the instruction sequence composed of the instruction X, the instruction Y, and the instruction Z exemplarily shown in 
The compiled software management information 343 exemplarily shown in 
The emulation code group 332 is a program (software) group composed of the host code used when the emulation processor 20 emulates the instruction included in the emulation-execution-target-software 310. The emulation code group 332 includes compilation emulation codes 332000-000 to 332000-255 of an instruction 0x00 and an interpreter emulation code 332000-256 of the instruction 0x00 with respect to an instruction code “0x00”. Where, “0x” shows that the value is represented as a hexadecimal value. The emulation code group 332 includes compilation emulation codes 332255-000 to 332255-255 of an instruction 0xFF and an interpreter emulation code 332255-256 of the instruction 0xFF with respect to an instruction code “0xFF”. Similarly, the emulation code group 332 also includes the compilation emulation code and the interpreter emulation code with respect to the instruction codes “0x01” to “0xFE”.
The compilation emulation code 332000-000 of the instruction 0x00 is the compiled program for emulating the instruction information 3100 of which the instruction code is “0x00” and the operand is “0x00”. The compilation emulation code 332000-255 of the instruction 0x00 is the compiled program for emulating the instruction information 3100 of which the instruction code is “0x00” and the operand is “0xFF”. The interpreter emulation code 332000-256 of the instruction 0x00 is a program for emulating the instruction information 3100 of which the instruction code is “0x00” by the interpreter method. The compilation emulation code and the interpreter emulation code related to the instructions 0x01 to 0xFF included in the emulation code group 332 are the programs for emulating the instruction information 3100 like the emulation code related to the instruction 0x00 mentioned above.
When the emulation processor 20 executes the compiled software 333-1 exemplarily shown in 
The compiled software corresponding to the instruction sequence which starts from the address indicated by the instruction pointer 3410 in the emulation-execution-target-software 310 is not stored in the main storage 30 as the compiled software group 333, the emulation processor 20 instructs the compilation processor 10 to compile the instruction sequence. The emulation processor 20 transmits this instruction via a request buffer 3420 included in the data 342 for I/F between processors shown in 
The validity flag in the request buffer 3420 is information indicating whether or not the information stored in the entry is valid. When the validity flag indicates “0xFF”, the information is valid. When the validity flag indicates “0x00”, the information is invalid (in other words, the entry is unused). For example, when the emulation processor 20 instructs the compilation processor 10 to compile the instruction sequence of which a first instruction is the instruction X exemplarily shown in 
When the compiled software corresponding to the instruction sequence which starts from the address indicated by the instruction pointer 3410 in the emulation-execution-target-software 310 is not stored in the main storage 30 as the compiled software group 333, the emulation processor 20 emulates the instruction sequence by the interpreter method. In this processing, the emulation processor 20 refers to an instruction information management table 3421 included in the data 342 for I/F between processors.
(Compilation Processor 10)
The compilation processor 10 according to this example embodiment shown in 
The compilation processor 10 reads out the instruction in the emulation-execution-target-software 310 that is indicated by the compilation start address stored in the entry of which the validity flag indicates “0xFF” in the request buffer 3420 exemplarily shown in 
When the compilation processor 10 compiles the instruction X, the compilation processor 10 obtains the storage address of the compilation emulation code 332XXX-i (i is an integer from 0 to 255 specified by the operand) of the instruction 0xXX indicated by the compilation emulation code management table 3422-XXX that corresponds to the value indicated by the operand of the instruction X. The compilation processor 10 generates the Call instruction which calls the obtained storage address as the compiled software 333-1 exemplarily shown in 
The compilation processor 10 refers to the instruction information management table 3421 exemplarily shown in 
As exemplarily shown in 
The compilation processor 10 stores the generated compiled software 333-1 in the main storage 30, associates the storage address with the address of the instruction X in the emulation-execution-target-software 310, and registers them in the compiled software management information 343 exemplarily shown in 
Next, the operation (processing) of the emulation device 1 according to the first example embodiment will be described in detail with reference to flowcharts shown in 
The emulation processor 20 obtains the instruction information from a memory area corresponding to the address indicated by the instruction pointer 3410 in the emulation-execution-target-software 310 (step S101). When the instruction information shows that the instruction is not the branch instruction (No in step S102), the emulation processor 20 performs the emulation by using the interpreter emulation code specified by the instruction information (step S103). The emulation processor 20 updates the instruction pointer 3410 (step S104) and the processing goes back to step S101.
When the instruction information shows that the instruction is the branch instruction (Yes in step S102), the emulation processor 20 performs the processing similar to those in steps S103 and S104 (step S105). The emulation processor 20 confirms whether or not a vacant entry (unused entry) exists in the request buffer 3420 (step S106). When the vacant entry does not exist (No in step S107), the processing goes back to step S101.
When the vacant entry exists (Yes in step S107), the emulation processor 20 locks the compiled software management information 343 (step S108). The emulation processor 20 confirms whether or not the value indicated by the instruction pointer 3410 is registered in the compiled software management information 343 (step S109). The emulation processor 20 unlocks the compiled software management information 343 (step S110).
When the value indicated by the instruction pointer 3410 is registered (Yes in step S111), the emulation processor 20 performs the emulation by executing the compiled software 333-i associated with the value indicated by the instruction pointer 3410 (step S112) and the processing goes back to step S108.
When the value indicated by the instruction pointer 3410 is not registered (No in step S111), the emulation processor 20 sets the value indicated by the instruction pointer to the vacant entry in the request buffer 3420 as the compilation start address and sets the validity flag to “0xFF” (step S113). The emulation processor 20 transmits the compilation request to the compilation processor 10 (step S114) and the processing goes back to step S101.
The compilation processor 10 receives the compilation request from the emulation processor 20 (step S201). The compilation processor 10 confirms the validity flag of the request buffer 3420 (step S202). When all the validity flags indicate “0x00” (Yes in step S203), the compilation processor 10 returns to the idle state (step S213) and all the processing end.
When at least one of the validity flags does not indicate “0x00” (in other words, at least one of the validity flags indicates “0xFF”) (No in step S203), the compilation processor 10 locks the compiled software management information 343 (step S204). The compilation processor 10 confirms whether or not the address that is the same as the compilation start address stored in the entry of which the validity flag indicates “0xFF” exists in the compiled software management information 343 (step S205). The compilation processor 10 unlocks the compiled software management information 343 (step S206).
When the address that is the same as the compilation start address is registered in the compiled software management information 343 (Yes in step S207), the compilation processor 10 resets the validity flag of the entry of the request buffer 3420 storing the address (step S208) and the processing goes back to step S201.
When the address that is the same as the compilation start address is not registered in the compiled software management information 343 (No in step S207), the compilation processor 10 generates the compiled software 333-i obtained by compiling the portion starting from the compilation start address in the emulation-execution-target-software 310 (step S209). The compilation processor 10 locks the compiled software management information 343 (step S210). The compilation processor 10 associates the compilation start address with the storage address of the compiled software 333-i and registers them in the compiled software management information 343 (step S211). The compilation processor 10 unlocks the compiled software management information 343 (step S212) and the processing goes back to step S208.
The compilation processor 10 obtains the instruction information 3100 of the compilation start address in the emulation-execution-target-software 310 (step S301). The compilation processor 10 checks the instruction code included in the instruction information 3100 against the instruction information management table 3421 and obtains the compilation emulation code management table address (step S302). The compilation processor 10 refers to the compilation emulation code management table stored in the obtained address (step S303).
The compilation processor 10 obtains the compilation emulation code address associated with the value indicated by the operand included in the instruction information 3100 (step S304). The compilation processor 10 generates the compiled software 333-i including the Call instruction which calls the compilation emulation code that exists at the compilation emulation code address (step S305). The compilation processor 10 confirms the compilation end flag related to the instruction code included in the instruction information 3100 indicated by the instruction information management table 3421 (step S306).
When the compilation end flag indicates “CONTINUE” (Yes in step S307), the compilation processor 10 adds the instruction length related to the instruction code included in the instruction information 3100 indicated by the instruction information management table 3421 to the compilation start address (step S308) and the processing goes back to step S301. When the compilation end flag does not indicate “CONTINUE” (in other words, it indicate “END”) (No in step S307), the compilation processor 10 inserts the ret instruction in the last line of the generated compiled software and stores the compiled software in the main storage 30 (step S309). The processing in step S209 ends.
The emulation device 1 according to this example embodiment can increase the execution speed of the software that is executed by emulation. This is because the main storage 30 and the compilation processor 10 have the following function. Namely, the instruction information that is an emulation execution target, the emulation code group 332, and the storage address of the emulation code group 332 are associated with and stored in the main storage 30. The compilation processor 10 generates the compiled software group 333 of which the emulation execution target is compiled so that it can be emulated by converting the instruction information into subroutine-read-instruction-information which calls the emulation code. The subroutine-read-instruction-information is the instruction information which calls the emulation code associated with the instruction information 3100.
The effect realized by the emulation device 1 according to this example embodiment will be described in detail below.
A technology in which the execution speed of the software that is executed by emulation can be increased by performing both the compilation processing and the interpreter processing to the software that is the execution target of the emulation is known. In this technology, when the compilation processing is performed by copying the emulation code provided in advance for each instruction that is the compilation target whose size is for example, about tens of bytes for each instruction, a large amount of data has to be copied and whereby, a problem in which the compilation processing takes a long time occurs. Namely, when the emulation is performed, the execution speed of the compilation processing has to be increased.
In order to solve such problem, in the emulation device 1 according to this example embodiment, the instruction information 3100 including the type of an instruction and the operand included in the emulation-execution-target-software 310, the emulation code group 332 obtained by compiling the instruction information 3100 so that it can be emulated, and information indicating the storage address of the emulation code group 332 are associated with and stored in the main storage 30. The compilation processor 10 generates the compiled software group 333 of which the emulation-execution-target-software 310 is compiled so that it can be emulated by converting the instruction information 3100 into the subroutine-read-instruction-information which calls the emulation code associated with the instruction information 3100 from the storage address. Namely, the emulation device 1 performs the compilation processing by converting the instruction that is a compilation target into the subroutine read instruction which reads out the emulation code without copying the emulation code for each instruction that is the compilation target. Accordingly, in the emulation device 1 according to this example embodiment, by avoiding a long copy time required for copying the emulation code, the execution speed of the software that is executed by emulation can be increased.
Further, the emulation code group 332 according to this example embodiment is a code group generated on the basis of the value indicated by the type of an instruction and the value indicated by the operand included in the instruction information 3100. Namely, because the emulation code group 332 is the code that is optimally compiled on the basis of both the value indicated by the type of the instruction and the value indicated by the operand, the execution speed of the software can be increased in comparison with a case in which the emulation code group 332 is the code that is compiled on the basis of only the value indicated by the type of the instruction. Accordingly, the emulation device 1 according to this example embodiment can increase the execution speed of the software that is executed by emulation.
Further, the compilation processor 10 according to this example embodiment generates one compiled software 333-i for each instruction sequence in which the branch instruction is included as the last instruction in the emulation-execution-target-software 310. Because the instructions included in the instruction sequence are executed in an address order in the emulation-execution-target-software 310, these instructions can be integrated as one compiled software. Accordingly, the emulation device 1 according to this example embodiment can efficiently generate the compiled software group 333.
Further, the request buffer 3420 having a plurality of entries is stored in a host data space 34 in the main storage 30 according to this example embodiment as the data 342 for I/F between processors. When the emulation processor 20 instructs the compilation processor 10 to perform the compilation, the emulation processor 20 registers the compilation start address in the emulation-execution-target-software 310 in one of the vacant entries and sets the validity flag of this entry to “valid”. The compilation processor 10 starts to perform the compilation processing from the compilation start address registered in the entry whose validity flag indicates “valid”. Namely, the compilation processor 10 can perform the compilation processing asynchronously and concurrently with the emulation execution processing performed by the emulation processor 20. As a result, the emulation device 1 according to this example embodiment can increase the execution speed of the software that is executed by emulation.
Further, the emulation device 1 according to this example embodiment includes the compilation processor 10 which performs the generation processing by executing the compilation program 330 and the emulation processor 20 which performs the execution processing by executing the emulation program 331. However, the configuration for realizing the emulation device 1 is not limited to the above-mentioned configuration. For example, the emulation device 1 may include a generation unit (generation means) that is dedicated hardware for performing the generation processing and an execution unit (execution means) that is dedicated hardware for performing the execution processing.
The emulation device 2 according to this example embodiment includes an optimization processor 60 in addition to the elements included in the emulation device 1 according to the first example embodiment. A compilation program 335 in which a function is added to the compilation program 330 stored in the main storage 30 according to the first example embodiment is stored in the host code space 33 in the main storage 30 according to this example embodiment. Further, an optimization program 334 is stored in the host code space 33 according to this example embodiment in addition to the information stored in the main storage 30 according to the first example embodiment. Further, compiled software management information 344 in which information indicating the number of execution times of each of the sets of compiled software 333-1 to 333-n is added to the compiled software management information 343 according to the first example embodiment is stored in the host data space 34 in the main storage 30 according to this example embodiment.
The compilation program 335 is a program for performing the processing (generation processing) for generating software that is a compilation result obtained by compiling the emulation-execution-target-software 310 and executed by the compilation processor 10.
The compilation processor 10 according to this example embodiment performs the following processing by executing the compilation program 335 in addition to the processing performed by the compilation processor 10 according to the first example embodiment. Namely, when the compilation processor 10 according to this example embodiment generates the sets of compiled software 333-1 to 333-n exemplarily shown in 
The optimization program 334 is a program for performing a determination processing and the update processing that are processing for optimizing the environment in which the emulation-execution-target-software 310 is emulated by the emulation device 2 (processing for increasing the execution speed) and executed by the optimization processor 60.
Here, the determination processing is a processing for determining whether or not the number of execution times of emulating each of the compiled sets of software 333-1 to 333-n meets a criterion. As the criterion, for example, a criterion of “equal to or greater than a threshold value” or the like may be used.
The update processing mentioned above is a processing for updating the Call instruction (the subroutine read instruction) with the compilation emulation code called by the Call instruction in the compiled software 333-i (i is an integer from 1 to n) when it is determined in the determination processing that the number of execution times of the compiled software 333-i meets the criterion. For example, when the number of execution times of the compiled software 333-i shown in 
Next, the operation (processing) of the optimization processor 60 in the emulation device 2 according to the second example embodiment will be described in detail with reference to the flowcharts shown in 
The optimization processor 60 confirms the number of times of emulating the compiled software 333-i (i is an integer from 1 to n) by referring to the compiled software management information 344 (step S401). When the number of times is less than the threshold value (No in step S402), the processing goes back to step S401.
When the number of times is equal to or greater than the threshold value (Yes in step S402), the optimization processor 60 obtains the compiled software 333-i from a memory area corresponding to the storage address indicated by the compiled software management information 344 (step S403). The optimization processor 60 searches for a Call instruction statement included in the compiled software 333-i (step S404). When the Call instruction statement exists (Yes in step S405), the optimization processor 60 updates the Call instruction statement with the compilation emulation code called by the Call instruction statement (step S406) and the processing goes back to step S404.
When the Call instruction statement does not exist (No in step S405), the optimization processor 60 stores the updated compiled software 333-i in the main storage 30 (step S407). The optimization processor 60 locks the compiled software management information 343 (step S408). The optimization processor 60 updates the storage address of the compiled software 333-i in the compiled software management information 343 (step S409). The optimization processor 60 unlocks the compiled software management information 343 (step S410) and the processing goes back to step S401.
The emulation device 2 according to this example embodiment can increase the execution speed of the software that is executed by emulation. The reason is the same as that explained in the first example embodiment.
Further, as explained in the first example embodiment, when the compilation processing is performed by converting each instruction that is the compilation target into the subroutine read instruction for reading the emulation code, the time required for performing the compilation processing can be shortened. However, when the subroutine read instruction is executed, the processing for reading out the emulation code is performed and this takes an additional time. Accordingly, with respect to the instruction of which the number of execution times of the software that is executed by emulation is large, a problem in which the execution speed of the software that is executed by emulation decreases occurs due to the conversion into the subroutine read instruction by the compilation processing.
To solve such problem, in the emulation device 2 according to the second example embodiment, the compilation processor 10 generates the compiled software group 333 having a function to count the number of execution times of the software that is executed by emulation and store it in the main storage 30 by executing the compilation program 335. As a result, the number of execution times of each of the sets of compiled software 333-1 to 333-n is stored in the main storage 30 by the emulation processor 20. When the number of execution times of the compiled software 333-i is equal to or greater than the threshold value, the optimization processor 60 according to this example embodiment updates the Call instruction statement included in the compiled software 333-i with the compilation emulation code called by the Call instruction statement.
Namely, the emulation device 2 according to this example embodiment generates the compiled software group 333 in which the Call instruction statement is included in the instruction of which the number of execution times is less than the threshold value and the emulation code related to the instruction of which the number of execution times is equal to or greater than the threshold value is included in the instruction without changing it. Accordingly, the emulation device 2 according to this example embodiment can increase the execution speed of the software that is executed by emulation by shortening the time required to compile each instruction and the time required to execute the instruction in a balanced manner.
Further, the emulation device 2 according to this example embodiment includes the optimization processor 60 which performs the determination processing and the update processing by executing the optimization program 334. However, the configuration of the emulation device 2 is not limited to the configuration described above. For example, the emulation device 2 may include a determination unit (determination means) that is dedicated hardware for performing the determination processing and an update unit (update means) that is dedicated hardware for performing the update processing.
Storage unit 70 stores information in which instruction information 710 including a type of an instruction 711 and an operand 712 included in emulation-execution-target-software 71, compiled instruction information 72 obtained by compiling the instruction information 710 capable of being emulated, and information 73 indicating the storage address of the compiled instruction information 72 are associated with.
The generation unit 80 converts the instruction information 710 into the subroutine-read-instruction-information which calls the compiled instruction information 72 associated with the instruction information 710 from the storage address indicated by the information 73 indicating the storage address. By this processing, the generation unit 80 generates compiled software 81 obtained by compiling the emulation-execution-target-software 71 capable of being emulated.
The emulation device 3 according to this example embodiment can increase the execution speed of the software that is executed by emulation. This is because the storage unit 70 and the generation unit 80 have the following function. Namely, the instruction information 710 that is the emulation execution target, the compiled instruction information 72, and the information 73 indicating the storage address of the compiled instruction information are associated with and stored in the storage unit 70. The generation unit 80 generates the compiled software 81 obtained by compiling the emulation execution target so that it can be emulated by converting the instruction information 710 into the subroutine-read-instruction-information which calls the compiled instruction information 72.
While the present invention has been particularly shown and described with reference to example embodiments thereof, the invention is not limited to these embodiments. It will be understood by those of ordinary skill in the art that various changes in form and details may be made therein without departing from the spirit and scope of the present invention as defined by the claims.
Further, it is noted that the inventor's intent is to retain all equivalents of the claimed invention even when the claims are amended during prosecution.
| Patent | Priority | Assignee | Title | 
| 10684835, | Dec 11 2018 | Microsoft Technology Licensing, LLC | Improving emulation and tracing performance using compiler-generated emulation optimization metadata | 
| 10884720, | Oct 04 2018 | Microsoft Technology Licensing, LLC | Memory ordering annotations for binary emulation | 
| 11029929, | Jan 24 2019 | Red Hat, Inc. | Using emulation to improve startup time for just-in-time compilation | 
| 11880465, | Aug 28 2019 | Palo Alto Networks, Inc. | Analyzing multiple CPU architecture malware samples | 
| Patent | Priority | Assignee | Title | 
| 10133655, | Jun 12 2017 | SONY INTERACTIVE ENTERTAINMENT INC | Emulation of target system using JIT compiler and bypassing translation of selected target code blocks | 
| 5751982, | Mar 31 1995 | Apple Inc | Software emulation system with dynamic translation of emulated instructions for increased processing speed | 
| 5768593, | Mar 22 1996 | Microsoft Technology Licensing, LLC | Dynamic cross-compilation system and method | 
| 6848098, | Nov 18 1999 | Fujitsu Limited | Process and apparatus for optimizing program written in interpretive language for each callable program part base on frequency of executions | 
| 7389500, | Jul 08 2005 | Microsoft Technology Licensing, LLC | Selective pre-compilation of virtual code to enhance boot time emulator performance | 
| 20040003375, | |||
| 20050160407, | |||
| 20070226683, | |||
| 20070226714, | |||
| 20100169072, | |||
| JP1040112, | |||
| JP1124940, | |||
| JP2000231494, | |||
| JP2001142718, | |||
| JP2005202614, | |||
| JP2005346407, | |||
| JP2007018254, | |||
| JP2010140233, | |||
| JP4713820, | |||
| JP6202877, | |||
| JP7210397, | |||
| JP8123697, | 
| Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc | 
| Jul 14 2017 | KUNUGI, DAI | NEC PLATFORMS, LTD | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 043062/ | 0294 | |
| Jul 21 2017 | NEC PLATFORMS, Ltd. | (assignment on the face of the patent) | / | 
| Date | Maintenance Fee Events | 
| Oct 12 2022 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. | 
| Date | Maintenance Schedule | 
| Apr 23 2022 | 4 years fee payment window open | 
| Oct 23 2022 | 6 months grace period start (w surcharge) | 
| Apr 23 2023 | patent expiry (for year 4) | 
| Apr 23 2025 | 2 years to revive unintentionally abandoned end. (for year 4) | 
| Apr 23 2026 | 8 years fee payment window open | 
| Oct 23 2026 | 6 months grace period start (w surcharge) | 
| Apr 23 2027 | patent expiry (for year 8) | 
| Apr 23 2029 | 2 years to revive unintentionally abandoned end. (for year 8) | 
| Apr 23 2030 | 12 years fee payment window open | 
| Oct 23 2030 | 6 months grace period start (w surcharge) | 
| Apr 23 2031 | patent expiry (for year 12) | 
| Apr 23 2033 | 2 years to revive unintentionally abandoned end. (for year 12) |