The present invention relates to application transfer systems, application transfer methods, terminals, and programs, and more particularly to application transfer systems, application transfer methods, terminals, and programs which can transfer an application between any devices.
Conventionally, there are a need for users playing a game on a home personal computer (PC) to continue the game while traveling with transportation of some kind. A method based on this need is disclosed in, e.g., Japanese Unexamined Patent Application Publication No. 2012-517767 (Patent Literature 1). According to Patent Literature 1, by operation of content-transfer user interface control on the user's mobile phone, state information of the game is transferred to the phone and the player can resume the game on a small screen.
PTL 1: Japanese Unexamined Patent Application Publication No. 2012-517767
Conventional methods for continuing an application such as a game on a different device includes the above method. According to the above method, the user plays a game on a home PC as the user's input information is sent to a cloud processor and the cloud processor interacts with the game and sends a corresponding MPEG stream back to the user's PC. The user switches the destination for the game to his/her mobile phone to continue the game on the mobile phone.
In this method, however, connection to the cloud system is necessary, which complicates the configuration and increases the cost.
The present invention was developed to solve the above problem, and it is an object of the present invention to provide an application transfer system, an application transfer method, a terminal, and a program which can transfer an application between any devices.
An application transfer system transfers an application between first and second terminals each having a predetermined OS. The first terminal includes transmitting means for transmitting to the second terminal a request to transfer the application and information specifying the OS. The second terminal includes virtualization software that virtualizes operation of an OS different from the OS of the second terminal, receiving means for receiving the transfer request, determining means for determining if the OS for the application received by the receiving means is the same as the OS of the second terminal, and control means for performing control to execute the application as it is if it is determined by the determining means that the OS for the application requested to be transferred is the same as the OS of the second terminal, and to start the virtualization software to execute the application if it is determined by the determining means that the OS for the application requested to be transferred is different from the OS of the second terminal.
Preferably, the transmitting means transmits, to the second terminal, accompanying information that defines a state at a time the application is transferred.
It is preferable that the accompanying information include information indicating an executed part of a program at a time execution of the program on the first terminal is stopped and a state of the application at the time execution of the program on the first terminal is stopped.
The accompanying information may include a memory size being used by the application.
The first terminal may have the virtualization software.
Another aspect of the present invention is directed to a method for transferring an application. The application transfer method transfers an application between first and second terminals each having a predetermined OS and a memory. The method includes the steps of: transmitting from the first terminal to the second terminal a request to transfer the application; receiving by the second terminal the transfer request from the first terminal; determining by the second terminal if the OS that runs the application requested to be transferred is the same as the OS of the second terminal; and executing the application as it is if it is determined that the OS for the application requested to be transferred is the same as the OS of the second terminal, and starting virtualization software to execute the application if it is determined that the OS for the application requested to be transferred is different from the OS of the second terminal.
Still another aspect of the present invention is directed to a terminal that receives from an external terminal having a predetermined OS an application running on the external terminal, and that can run the application. The terminal includes: virtualization software that virtualizes operation of an OS different from an OS of the terminal; receiving means for receiving from the external terminal a request to transfer the application and information specifying the OS of the external terminal; determining means for determining if the OS for the application received by the receiving means is the same as the OS of the terminal; and control means for performing control to execute the application as it is if it is determined by the determining means that the OS for the application requested to be transferred is the same as the OS of the terminal, and to start the virtualization software to execute the application if it is determined by the determining means that the OS for the application requested to be transferred is different from the OS of the terminal.
Yet another aspect of the present invention is directed to a program that causes a second terminal as a computer to receive an application running on an external first terminal having a predetermined OS and to run the application. The second terminal includes virtualization software that virtualizes operation of an OS different from an OS of the second terminal. The program is run as receiving means for receiving from the first terminal a request to transfer the application and information specifying the OS of the first terminal, determining means for determining if the OS for the application received by the receiving means is the same as the OS of the second terminal, and control means for performing control to execute the application as it is if it is determined by the determining means that the OS for the application requested to be transferred is the same as the OS of the second terminal, and to start the virtualization software to execute the application if it is determined by the determining means that the OS for the application requested to be transferred is different from the OS of the second terminal.
In an application transfer system that transfers an application between first and second terminals each having a predetermined OS, the second terminal that has received a transfer request executes the application as it is if the application can run on the OS of the second terminal, and otherwise, starts software for virtualizing an OS to execute the application.
As a result, an application transfer system, an application transfer method, a terminal, and a program can be provided which can transfer an application between any devices.
An embodiment of a method for transferring an application according to the present invention will be described below with reference to the accompanying drawings.
The CPU 11 and the OSA of the mobile terminal 10 and the CPU 21 and the OSB of the car navigation system 20 can execute a map application, and the communication units 15, 25 can transmit and receive the application.
First, the internal operation of the OSA in the mobile terminal 10 will be described.
When the user operates the operation unit 12 etc. of the mobile terminal 10 to start the application, the OSA copies data of the application stored in the SD card 40 to the unused area 32 in the main memory 31. An application area 35 is thus created in the main memory 31, as shown on the left side of the figure.
The CPU 11 starts the application and starts operation specific to each application after initialization. Since a work area specific to each application is required, the application requests the OSA to allocate the memory to the application.
The OS allocates the memory of a requested size to the application as a work area. This state is shown in
When the user terminates the application, the OS releases the work area and the area allocated to the application. Allocation of the main memory in this state is the same as that shown in
Next, a method for transferring an application from the mobile terminal 10 to the car navigation system 20 will be described.
Referring to
If the user decides to transfer the application and inputs this decision via the operation unit 12 of the terminal A shown in
In response to the transfer request, the terminal B sends an acknowledge signal to the terminal A to acknowledge the transfer request (YES in S22, S23).
In response to the transfer request acknowledge signal, the terminal A sends the application and its accompanying information to the terminal B and terminates the application (YES in S16, S17, S18). The terminal A sends, wired or wirelessly, the application and the accompanying information directly to the terminal B without using a server on a network etc. The accompanying information includes information on the OS that runs the application.
The routine returns to S15 if the terminal A does not receive the acknowledge signal from the terminal B within a certain period.
In response to the application and the accompanying information, the terminal B performs predetermined processing (S24). The accompanying information will be described later.
The predetermined processing that is performed by the CPU 21 of the terminal B in S24 will be described below.
What is determined in S31 is not whether the OS of the terminal B is physically the same as the OS that runs the application, but whether the OS of the terminal B can run the application. The CPU 21 operates as determining means and control means.
Specific processing to be performed in the case where the OS (OSB) of the terminal B can run the application (S32 in
Since the OS of the terminal A is equivalent to that of the terminal B, the system area is the same between the main memories of the terminals A, B. The OS of the terminal A copies, wirelessly or wired, the application 35 and the work area 36 shown in
In order for the user to continue the application on the terminal B from the operating state of the application on the terminal A, the terminal A need also transfer the work area as well. Transferring only the application to the terminal B is equivalent to starting the application on the terminal B, and the application is started from its initial state.
That is, transferring both the application and the work area allows the user to continue the application on the terminal B from the operating state of the application on the terminal A.
In other words, transferring both the application and the work area makes the state in the memory which is recognized by the application on the terminal B exactly the same as that in the memory of the terminal A before transfer of the application.
Specific processing to be performed in the case where the OS (OSB) of the terminal B cannot run the application will be described below (S33 in
Similarly, the terminal B includes hardware B, the OSB that can run on the hardware B, virtualization software 73 that runs on the OSB, and an application 74 that runs on the virtualization software 73. The OSB includes an OS kernel 71 and libraries 72.
The virtualization software 73 installed in the terminal B absorbs the difference between the terminals A, B. In other words, although the application is actually being run on the terminal B, the virtualization software 73 behaves to the application as if the application were being run on the terminal A. In the figure, the terminal B has different hierarchy from the terminal A in the level of the virtualization software 73 and the levels lower than the virtualization software 73 (the libraries 72, the kernel 71, and the hardware 70). However, since the virtualization software 73 performs the same operation as the terminal A, the program can run even on the different hardware.
Examples of the virtualization software include VMware that can execute Linux (registered trademark) applications on Windows (registered trademark) and can execute Windows applications on Linux and that is widely used for the purpose of virtualization of web servers etc., QEMU that can emulate Windows or Linux software and can virtualize hardware together with a part of peripheral hardware, and BlueStacks that can execute Android applications on Windows or Mac.
In the case where a game application is transferred from the terminal A, the virtualization software 73 on the terminal B, instead of the application framework 63, reads the transferred game application 74 onto the memory, not shown, and executes the application 63 from the operating state of the application on the terminal A. Since the work area for storing the progress of the game is transferred simultaneously with the application, the memory is allocated to the application 74 so as to reproduce the state before the transfer.
The above embodiment is described with respect to the case where a game application is transferred. However, the present invention is not limited to this, and map display of a map application may be transferred. In this case, the terminal B reads and executes the map application in a manner similar to that described above. The application requests to obtain a current position via the libraries 72. In fact, it is the virtualization software 73 that receives this request. Since the terminal B operates in exactly the same manner as that of the terminal A and returns the same data as that of the terminal A to the application, the application cannot recognize that it is running on the virtualization software. The terminal B sends the current position to the application via the virtualization software.
The accompanying information will be described below. In the present embodiment, the user can stop executing an application program and can resume the application program on a different terminal. For this purpose, exactly the same state as that at the time execution of the application program is stopped need be reproduced on the terminal to which the application program is transferred, and various accompanying information need be simultaneously transferred in addition to the application program itself and the OS that runs the application program. Such information is herein collectively referred to as the “accompanying information.”
The accompanying information other than the OS includes the following information.
(1) Internal Processing Information of the Application Program
In order to stop a program on one terminal and resume the program on a different terminal after transfer of the program, information on the execution state of the program on the one terminal and information on the state at that time the program is stopped are required. Accordingly, the accompanying information is internal information such as the executed part of the program at the time the program is stopped and the state of the application at that time.
(2) Information on the Size of the Work Area Secured for the Application and the Data in this Work Area
The accompanying information is the data in the memory secured for the application and the size of this memory.
Such information is required to reproduce exactly the same memory data on the virtualization software of the terminal to which the application is transferred.
(3) Data in Video Memory
Data in a video memory is transferred so that the virtualization software of the terminal to which the application is transferred can use the data displayed on the screen of the terminal from which the application is transferred.
(4) Unique User ID for the Application
In specific OSs, a unique user ID is sometimes assigned to each application for security purposes. If application software can access an area allocated to different application software, software such as viruses can be easily created. As measures against this, in the specific OSs, a different user ID is assigned to each application. A memory area allocated to one application cannot basically be accessed by an application with a different user ID, which is advantageous in terms of security.
The user ID can never change during execution of the application. Accordingly, in this application transfer method, the same user ID need be assigned even after transfer of the application to resume the application. The user ID is therefore transferred together with the application.
(5) Data Storage Folder for the Application and Data in the Data Storage Folder
A data storage folder is allocated to each application. The data storage folder is similar to the work area described in (2), but is different from the work area in (2) in that data is temporarily stored in the work area and is erased when the application is terminated, whereas data in the data storage folder is retained even after the power is off. For example, in the case of an email application, since data of an email message is stored in this area, the email massage does not disappear even if the email application is terminated and restarted.
(6) Resources of the Application
The term “resources” refers to image data and data such as music which are used in the application. For example, data such as an icon image representing a specific application, a character or logo that is displayed on a menu screen, and background music and sound effects of games is treated as separate from the application itself, but this data is necessary to execute the application. Accordingly, this data need be transferred simultaneously with the application.
The specific OSs are not described in the present embodiment. However, for example, the terminal A operates as follows if it is Android.
Android OS is made of the following five layers. (a) Linux kernel, (b) standard libraries, (c) Android Runtime (an execution environment for executing an application), (d) application framework, and (e) applications.
The Linux kernel (a) processes the most basic part that is close to hardware and that implements basic functions such as memory and process management. This is substantially the same as common personal computers. The applications do not directly interact with the kernel.
The standard libraries (b) are code for implementing various functions. For example, Surface Manager handles display of graphics, and MediaFrameWork plays back video and audio. FreeType is a library for displaying various character fonts in any size.
Android Runtime (c) is an environment for executing an application and provides a basic application program interface (API). This runtime directly executes the applications.
The application framework (d) performs management such as starting, stopping, termination, etc. of the applications. The application framework (d) also notifies the applications of the state of the terminal. The applications directly access only application framework (d) and the libraries (b) and do not access the kernel (a).
An operation example of a common application on Android will be described below with reference to
The following example is the case where the game application 64 is started.
When the user sends a command to start the game application 64, the application framework 63 reads this application onto the memory to execute the application via the Android Runtime 62a. The application requires a work area in order to store the progress of the game therein. A virtual machine in the Android Runtime 62a therefore secures the memory as the work area to allocate the memory to the game application. The allocated memory is used during execution of the application and is released when operation of the application is terminated (management of the memory is returned to the Android Runtime 62a).
An operation example of map display by a map application will be described below.
When the map application is started, the application 64 is read and executed in a manner similar to that described above. In order to display a map, the latitude and longitude of a current position need be obtained via GPS. The application therefore requests to obtain the current position via core libraries in the Android Runtime 62a. The current position is read from a GPS chip via the Linux kernel and is sent to the application via the Android Runtime 62a.
The receiving terminal B will be described. The terminal B has the virtualization software 73 as described above, and the virtualization software 73 can similarly perform all the functions of the application framework, the libraries, and the core libraries of Android on the hardware of the terminal B.
The following operation is performed in the case where the game application 64 is transferred.
The virtualization software 73 on the terminal B, instead of the application framework 63, reads the transferred game application 74 onto the memory and executes the application from the operating state of the application on the terminal A. A work area for storing the progress of the game is also transferred simultaneously with the application, and the memory is allocated to the application 74 so as to reproduce the state before the transfer.
The following operation is performed when the map display by the map application is transferred. The map application is read and executed in a manner similar to that in the above example. The application 74 requests to obtain a current position via the core libraries in the Android Runtime 62a. In fact, it is not the Android Runtime 62a but the virtualization software 73 that receives this request. However, since the virtualization software 73 operates in exactly the same manner as that of the Android Runtime 62a and returns the same data as that of the Android Runtime 62a to the application, the application cannot recognize that it is running on the virtualization software 72. The terminal B sends the current position to the application via the virtualization software 73. How the data of the current position is actually implemented depends on the specifications of the terminal B as described above.
The above embodiment is described with respect to the case where only the terminal B has virtualization software. However, the present invention is not limited to this, and both terminals A, B may have virtualization software and functions of the terminal from which an application is transferred. In this configuration, desired transfer can be bidirectionally made between the terminals A, B. Moreover, an application executed on the terminal A can be transferred back to the terminal A after being transferred to and executed on the terminal B and all the operating state can be transferred.
The above embodiment is described with respect to the case where the specific OS is Android. However, the present invention is not limited to this, and similar processing can be carried out on any OS.
The above embodiment is described with respect to the case where an application is transferred between a mobile terminal and a car navigation system and the case where map information is displayed by using GPS. However, the present invention is not limited to this. The present invention is also applicable to the case where the user washing a movie on a mobile terminal transfers the movie to a large screen TV and the case where the user playing a game on a mobile terminal transfers the game to a large screen TV.
Although the embodiment of the present invention is described above with reference to the accompanying drawings, the present invention is not limited to the illustrated embodiment. Various modifications and variations can be made to the illustrated embodiment within a scope that is the same as, or equivalent to, that of the present invention.
Since the application transfer system can transfer an application between any terminals, the present invention can be advantageously used as an application transfer system.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2013/053849 | 2/18/2013 | WO | 00 |