[go: up one dir, main page]

WO2018217377A1 - Selective acceleration of emulation - Google Patents

Selective acceleration of emulation Download PDF

Info

Publication number
WO2018217377A1
WO2018217377A1 PCT/US2018/029207 US2018029207W WO2018217377A1 WO 2018217377 A1 WO2018217377 A1 WO 2018217377A1 US 2018029207 W US2018029207 W US 2018029207W WO 2018217377 A1 WO2018217377 A1 WO 2018217377A1
Authority
WO
WIPO (PCT)
Prior art keywords
host
output
processing
host system
synchronization
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.)
Ceased
Application number
PCT/US2018/029207
Other languages
French (fr)
Inventor
Jacob STINE
Dmitri Tolstov
Geoffrey Norton
Takayuki Kazama
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Sony Interactive Entertainment Inc
Original Assignee
Sony Computer Entertainment Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Priority claimed from US15/607,302 external-priority patent/US10783008B2/en
Application filed by Sony Computer Entertainment Inc filed Critical Sony Computer Entertainment Inc
Priority to EP18806655.9A priority Critical patent/EP3630318B1/en
Priority to CN201880034784.6A priority patent/CN111656746B/en
Priority to JP2019565381A priority patent/JP6824446B2/en
Publication of WO2018217377A1 publication Critical patent/WO2018217377A1/en
Anticipated expiration legal-status Critical
Ceased legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45504Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
    • G06F9/45516Runtime code conversion or optimisation
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/30Interconnection arrangements between game servers and game devices; Interconnection arrangements between game devices; Interconnection arrangements between game servers
    • A63F13/35Details of game servers
    • A63F13/355Performing operations on behalf of clients with restricted processing capabilities, e.g. servers transform changing game scene into an encoded video stream for transmitting to a mobile phone or a thin client
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/30Interconnection arrangements between game servers and game devices; Interconnection arrangements between game devices; Interconnection arrangements between game servers
    • A63F13/35Details of game servers
    • A63F13/358Adapting the game course according to the network or server load, e.g. for reducing latency due to different connection speeds between clients
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/46Multiprogramming arrangements
    • G06F9/52Program synchronisation; Mutual exclusion, e.g. by means of semaphores
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/61Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
    • H04L65/612Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for unicast
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/61Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio
    • H04L65/613Network streaming of media packets for supporting one-way streaming services, e.g. Internet radio for the control of the source by the destination
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/60Network streaming of media packets
    • H04L65/75Media network packet handling
    • H04L65/762Media network packet handling at the source 
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/80Responding to QoS
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/131Protocols for games, networked simulations or virtual reality
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F2300/00Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
    • A63F2300/50Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterized by details of game servers
    • A63F2300/55Details of game data or player data management
    • A63F2300/5593Details of game data or player data management involving scheduling aspects

Definitions

  • the current disclosure relates to emulation of legacy programs. More specifically the current disclosure relates to accelerated processing during emulation of programs.
  • a target system e.g., a legacy device
  • a host system e.g. a different system or a more modern version of the target system
  • the reduced power of the target system may take the form of a slower clock speeds or system component response times.
  • Programs written for the target system may be dependent on the slower speeds of the target system. Due to this dependency emulated programs may not be able to take advantage of the full capabilities of the host system.
  • a cloud-based gaming system In a cloud-based gaming system the majority of the processing takes place on the cloud-based server. This allows the client device platform that is communicating with the cloud-based server to use less resources for processing the cloud based game.
  • Current techniques implement incremental buffering to make the game load faster and parallel processing between the server and the client. However as a result of this arrangement communication between the client device and the server must be synchronized. If the client device and the server are not synchronized it may result in unusual or unexpected device behavior.
  • FIG. 1 is a flow diagram of a method for selective acceleration of emulation according to an aspect of the present disclosure.
  • FIG. 2 is a flow diagram depicting method of detection of reduced need for synchronization and detecting a need for resynchronization according to aspects of the present disclosure.
  • FIG. 3 is a flow diagram showing selective acceleration of emulation over a network according to aspects of the present disclosure.
  • FIG 4 is a block diagram of a system that implements selective acceleration of emulation according aspects of the present disclosure.
  • a host system may implement a scheme for accelerating emulation of programs written for a target system on a host system 100.
  • the host system may carry out the emulation process by generating emulated program assets that can be processed by the host system to generate and utilize resulting outputs (referred to herein as host outputs).
  • the host system may generate the program assets or host outputs and transmit them to a remote system over the network for processing and/or utilization.
  • the target system code may be translated by the host system and the translated code may then be executed. During execution the host system may reduce the speed at which it processes instructions 101 in order to maintain synchronization between the outputs of the host system.
  • the audio and video of a program may be synchronized on a target but when that program is emulated at the full speed of the host system there will be a loss in synchronization because the audio processes faster than the video on the host system and the original program was not designed to account for this difference.
  • processor speed dependent elements of video or audio in a program for a target system that when run on a host system at the full speed of the host system cause the program to behave in ways that are unexpected by the user.
  • the host system synchronizes the processing of emulated assets and generation of host outputs with the speed of the emulated target system.
  • the host system may not provide any apparent improvement in running target system programs to an end user despite being a newer and more powerful device.
  • the host system implements a method for selective acceleration of processing as shown in FIG. 1.
  • the host system may detect when there is a decreased need of synchronization of processing of emulated program assets with the emulation of the target system, as indicated at 102.
  • There are a number of situations during emulation that may be characterized by a reduced need for emulation.
  • a common feature of many such situations is that the user experience is not affected, or is even enhanced, by a reduced level or complete lack of synchronization between processing of emulated program assets and generation of host outputs.
  • Some non- limiting examples of such situations include situations where audio, video, or haptic outputs need not be synchronized to other aspects of the emulation or with each other.
  • detecting reduced need for synchronization of processing emulated program assets and the host output at 102 may include detecting a pre-loaded mini-game with preloaded audio and video components. Such detection may be used to trigger acceleration of loading of mini-games.
  • a loading screen mini -game i. e. , a mini-game that can be played as another application loads
  • An example of a behavior which may be unique to a loading screen mini-game is loading large assets into video memory and without immediate usage by the video subsystem.
  • a repeating pattern of such unused allocations is a strong indication that background loading is occurring and that the behavior observed by the user is a mini-game or animated loading screen.
  • Heuristic criteria for determining asset allocation size, repeating patterns, and immediate usage may vary according to the emulated target architecture.
  • the host system may unlock synchronization with the emulation of the target system as indicated at 103, and accelerate processing of emulated program assets as indicated at 104.
  • the host may implement an output detection process 200 as shown in FIG. 2.
  • the output detection process may be split between detection of audio 202 and video 201.
  • the system may initially detect whether the display output is black or blank 203. Alternatively the host system detects whether the emulated program requires the host system to output an image to the screen 203. If an image output is detected the system may monitor the output to detect whether the required output is static 204. For instance the host system may monitor the video output for changes over a specified period of time, if no changes are found then the host system determines the screen is static 204.
  • the host system may monitor whether the emulated program requires the output of a static screen 204. If a static screen is not detected the host system may monitor the emulated program assets to determine whether the video output has already been loaded into memory 205. If the host system detects that the video output has been preloaded into memory the host system may further determine whether any additional processing of the video is required. In other embodiments if the host system detects repeated bulky memory allocations to the system or GPU memory that are not immediately used then the host system may accelerate processing of video. A preloaded video may be detected as a single or repeated memory allocation that is immediately used. It should be understood that a bulky memory allocation may be defined by the system automatically or by a user depending upon the application. The threshold for immediate use may vary depending on application, system architecture, etc.
  • the host system determines that there is a no display output 203 or a static output 204 or a preloaded video sequence 205 then the system will unlock the synchronization of processing video assets 103.
  • the synchronization of video assets may be between audio and video.
  • the synchronization may be between the processing clock speed of the emulated target system and processing of the video assets.
  • the emulated program may include processor clock speed dependent assets that when processed at a different clock speed than the target system will create user-perceived unwanted behavior.
  • user perceived unwanted behavior may be in a video game the characters move across the screen much faster than expected.
  • the synchronization may be between the processing of video assets on the host system and an emulator running over the network on a remote system.
  • the host system may be receiving emulated program assets from a server operating over the network.
  • the server sends a video asset to the host system may perform processes on the video asset and output the result to an display device.
  • the host system unlocks synchronization of processing of video assets 103 during times when a user of the system would not detect a change in program behavior due to the accelerated processing of video data.
  • the host system may unlock synchronization 103 and accelerate processing video assets 104 by processing emulated video assets at clock speed that is higher than that of the emulated target system.
  • the host system may unlock synchronizationl03 and accelerate processing 104 by processing emulated video assets at a higher rate than the playback rate of emulated audio assets.
  • the host system may unlock
  • synchronization 103 and accelerate the processing of emulated video assets 104 by processing the emulated video assets at a faster rate on the host system than a remote emulator transmitting emulated assets over the network.
  • the processing of emulated video assets will remain synchronized with emulation of the target system 206.
  • video assets were discussed the term is not limited to video and as used herein may refer to images displayed on a screen as well as data for rendering images or physics data for simulations or the like.
  • the host system may initially detect whether there is any sound output to the speakers 207. Alternatively the host system may monitor the emulated audio assets to determine whether audio output is required. If audio output is required the host system may determine whether the audio output is below a threshold 208. If the audio output is not below a threshold the host system may monitor the emulated audio assets to determine whether the audio is already loaded in to memory 209. If the host system determines that the audio is preloaded the host system may further detect whether any processing needs to be done on the audio. In other embodiments if the host system detects repeated bulky memory allocations to the system or GPU memory that are not immediately used then the host system may accelerate processing of audio. Preloaded audio may be detected as a single or repeated memory allocation that is immediately used. It should be understood that a bulky memory allocation may be defined by the system automatically or by a user depending upon the application. The threshold for immediate use may vary depending on application, system architecture, etc.
  • the host system will unlock processing of the audio assets 103.
  • audio processing may be locked to the rate of the video.
  • audio assets may be dependent on the clocks speed of the emulated target system and when processed at a different clock speed than the target system may result in user-perceived unwanted behavior.
  • user-perceived unwanted audio behavior might be music playing at a higher pitch due to the accelerated processing.
  • the synchronization may be between the processing of audio assets on the host system and an emulator running over the network on a remote system.
  • the host system may be receiving emulated audio assets from a server operating over the network. As soon as the server sends an audio asset to the host system, the host may perform processes on the audio asset and output the result to an output device (for instance speakers).
  • the host system unlocks synchronization of processing of audio assets during times when a user of the system would not detect a change in program behavior due to the accelerated processing of audio data.
  • the host system may unlock synchronization 103 and accelerate processing audio assets 104 by processing emulated audio assets at a clock speed that is higher than that of the emulated target system.
  • the host system may unlock synchronization 103 and accelerate processing of emulated audio assets 104 at a rate that is faster than the processing of emulated video assets.
  • the host system may unlock synchronization 103 and accelerate processing of emulated audio assets 104 by processing audio assets at a faster rate on the host system than a remote emulator emulates the target system and transmits emulated assets over the network.
  • the processing of emulated audio assets will remain synchronized with emulation of the target system 101.
  • audio assets were discussed the term is not limited sound files and as used herein may refer to music, contextual sounds, sounds from interactions within a simulated environment and the like.
  • the system may monitor output 210 to determine whether to resynchronize processing 105.
  • the system may monitor the processing of the emulated program assets to determine whether the emulated program requires the system to output information to an external device 211.
  • monitoring the processing of emulated program assets may include monitoring memory allocations to detect a change from allocation of bulky blocks of memory to use of those memory blocks to detect a change from outputting preloaded audio or video.
  • the system may monitor the program for a change in display data to be sent to a screen or for changes in sound data to be sent to the speakers or for changes in other data such as color data to be sent to controllers or communication data to be sent over the network.
  • the system will continue accelerated processing of the emulated program assets 103. If a change in output is required then the system will return to processing at the previous rate and resynchronize with the emulated target system 105. Once the system has resynchronized with targets 105 it may return to processing the synchronized program assets 101.
  • the unlocking of synchronization 103 is not limited to implementations of video and audio.
  • the disclosed method of detecting output 200 and accelerating processing 100 may be applied to other types of output for instance color information for lights connected to the host system or robotic manipulator control information and the like.
  • One possible example of implementation to robotic manipulator control information would be if the target system instructions were for an older style robotic device and the host device offers certain advantages, or has removed some particular mechanical process entirely. In such circumstances the emulation could be accelerated using the approach describe herein. In some situations, such target code instructions may be removed outright.
  • the techniques described herein may be applied to situations where the target instructions have other meaningful side effects, such that the instructions cannot be skipped, but need not be restricted to an established rate of execution that might have been established by the older style robotics.
  • Fig 3 depicts other aspects of the current disclosure; the host system 301 may implement the method to accelerate emulation 100 in conjunction with an emulator operating over a network 302.
  • the host system may receive emulated program assets 303 from the remote emulator 302, process the emulated program assets immediately and output the result 106 to external devices 305.
  • the processing of emulated program assets on the host system 301 may be synchronized with the emulation of the target system on the remote emulator 302.
  • the host system 301 may implement the method of acceleration of emulation 100, including accelerated streaming of program assets 107.
  • the host system 301 may provide feed-back 304 to the remote emulator 302 that includes information about the processing of emulated program assets 101, or 104.
  • the emulator may remain informed about the processing of emulated program assets on the host system and utilize this information when the host system resynchronizes 104 with the emulation of the target system on the emulator 302.
  • the host system may inform the remote emulator through the feedback 304.
  • the remote emulator may accelerate the rate at which the emulated program assets are sent 307 to the host system 107.
  • the emulated program assets that are sent 307 to the host system 301 at an accelerated rate may fill a buffer of the host system for further processing.
  • the program assets sent 307 at an accelerated rate 107 may be processed immediately in accordance with the accelerated processing 104 taking place on the host system 301.
  • the host system may continue to send feedback 304 to the remote emulator 302 to ensure that too many emulated program assets are not sent to the host system resulting in a buffer overflow condition.
  • the host system 301 may send feedback 304 to the remote emulator 302 indicating that additional emulated program assets are needed immediately to prevent buffer underflow or stalling. Additionally the feedback reports 304 may inform the remote emulator to suspend cheat detection or other rate dependent processes during accelerated processing of emulated program assets.
  • the host system 301 may send a feedback 304 to the remote emulator 302 to resynchronize 105 the emulation of the target system on the emulator with the processing of emulated assets on the host system 301.
  • an emulator 407 may be accessed by a host system 402 over a network 460.
  • the host system 402 may access alternative remote emulators 407 over the network 460 (herein referred to as remote emulators).
  • Emulators 407 may be identical to each other, or they may each be programed to emulate unique legacy programs 406 including unique legacy games 406. Additionally, the emulator 407 may be contained within the host system 402 and may communicate directly with the host system over an internal system bus 450'
  • the emulation of the target system may take place wholly on the host system 402.
  • the legacy program may be loaded in to the memory 436 of the host system 402 and the CPU 431 carries the out emulation program 433.
  • Host system 402 may include a central processor unit (CPU) 431.
  • a CPU 431 may include one or more processors, which may be configured according to, e.g., a dual-core, quad-core, multi-core, or Cell processor architecture.
  • Host system 402 may also include a memory 432 (e.g., RAM, DRAM, ROM, and the like).
  • the CPU 431 may execute a process-control program 433, portions of which may be stored in the memory 432.
  • the host system 402 may also include well-known support circuits 440, such as input/output (I/O) circuits 441, power supplies (P/S) 442, a clock (CLK) 443 and cache 444.
  • I/O input/output
  • P/S power supplies
  • CLK clock
  • the host system 402 may optionally include a mass storage device 434 such as a disk drive, CD-ROM drive, tape drive, or the like to store programs and/or data.
  • the host system 402 may also optionally include a display unit 437 and a user interface unit 438 to facilitate interaction between the Host System 402 and a user who requires direct access to the host system 402.
  • the display unit 437 may be in the form of a cathode ray tube (CRT) or flat panel screen that displays text, numerals, or graphical symbols.
  • the user interface unit 438 may include a keyboard, mouse, joystick, light pen, or other device.
  • a controller 445 may be connected to the Host System 402 through the I/O circuit 441 or it may be directly integrated into the Host System 402.
  • the controller 445 may facilitate interaction between the Host System 402 and a user.
  • the controller 445 may include a keyboard, mouse, joystick, light pen, hand-held controls or other device.
  • the controller 445 is also may be capable of generating a haptic response 446.
  • the haptic response 446 may be vibrations or any other feedback corresponding to the sense of touch.
  • the Host System 402 may include a network interface 439, configured to enable the use of Wi-Fi, an Ethernet port, or other communication methods.
  • the network interface 439 may incorporate suitable hardware, software, firmware or some combination of two or more of these to facilitate communication via an electronic communications network 460.
  • the network interface 439 may be configured to implement wired or wireless communication over local area networks and wide area networks such as the Internet.
  • the Host System 402 may send and receive data and/or requests for files via one or more data packets over the network 460.
  • the preceding components may exchange signals with each other via an internal system bus 450.
  • the Host System 402 may be a general purpose computer that becomes a special purpose computer when running code that implements embodiments of the present invention as described herein.
  • the emulator 407 may include a central processor unit (CPU) 431'.
  • a CPU 431' may include one or more processors, which may be configured according to, e.g., a dual-core, quad-core, multi-core, or Cell processor architecture.
  • the emulator 407 may also include a memory 432' (e.g., RAM, DRAM, ROM, and the like).
  • the CPU 431' may execute a process-control program 433', portions of which may be stored in the memory 432'.
  • the emulator 407 may also include well-known support circuits 440', such as input/output (I/O) circuits 441', power supplies (P/S) 442', a clock (CLK) 443' and cache 444'.
  • I/O input/output
  • P/S power supplies
  • CLK clock
  • the emulator 407 may optionally include a mass storage device 434' such as a disk drive, CD-ROM drive, tape drive, or the like to store programs and/or data.
  • the emulator 407 may also optionally include a display device 437' and user interface unit 438' to facilitate interaction between the emulator 407 and a user who requires direct access to the emulator 407.
  • a host system or engineer 402 may need direct access to the emulator 407 in order to program the emulator 407 to properly emulate a desired legacy program 406 or to add additional capabilities to a legacy program 406.
  • the display device 437' may be in the form of a cathode ray tube (CRT) or flat panel screen that displays text, numerals, or graphical symbols.
  • CTR cathode ray tube
  • the user interface unit 438' may include a keyboard, mouse, joystick, light pen, or other device.
  • the emulator 407 may include a network interface 439', configured to enable the use of Wi-Fi, an Ethernet port, or other communication methods.
  • the network interface 439' may incorporate suitable hardware, software, firmware or some combination of two or more of these to facilitate communication via the electronic communications network 460.
  • the network interface 439' may be configured to implement wired or wireless communication over local area networks and wide area networks such as the Internet.
  • the emulator 407 may send and receive data and/or requests for files via one or more data packets over the network 460.
  • the preceding components may exchange signals with each other via an internal system bus 450'.
  • the emulator 407 may be a general purpose computer that becomes a special purpose computer when running code that implements embodiments of the present invention as described herein.
  • Emulator 407 may access a legacy program 406 that has been selected by the Host System 402 for emulation through the internal system bus 450'.
  • the legacy programs may also be stored in the memory 432' or in the mass storage device 434'. Additionally, one or more legacy programs 406 may be stored at a remote location accessible to the emulator 407 over the network 460.
  • Each legacy game 406 contains game code 408. When the legacy game 106 is emulated, the game code 408 produces legacy game data 409.
  • a legacy program 406 may be any program that is not compatible with a target platform.
  • the legacy program 406 may have been designed to be played on Sony Computer Entertainment's PlayStation console, but the target platform is a home computer.
  • the legacy game 406 may have been designed to be played on a PlayStation 2 console, but the target platform is a PlayStation 3 console.
  • a legacy game 406 may have been designed to be played on a PlayStation console, but the target platform is a hand held console such as the PlayStation Vita from Sony Computer

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)

Abstract

Selective acceleration of emulation of programs written for a legacy computer system on a more modern computer system is disclosed. The host system processes emulated program assets that are synchronized with host outputs. When a reduced need for synchronization between the emulated program assets and a host output is detected, synchronization of processing of emulated program assets and the host output is unlocked and the host system accelerates processing of the emulated program assets for which the synchronization has been unlocked.

Description

SELECTIVE ACCELERATION OF EMULATION
CLAIM OF PRIORITY
This application claims the priority benefit of United States Patent Application Number 15/607,302 filed May 26, 2017, the entire contents of which are incorporated herein by reference.
FIELD OF THE INVENTION
The current disclosure relates to emulation of legacy programs. More specifically the current disclosure relates to accelerated processing during emulation of programs.
BACKGROUND OF THE INVENTION
In emulation of programs written for a target system (e.g., a legacy device) on a host system, (e.g. , a different system or a more modern version of the target system) often times the target system is less powerful than the host system. The reduced power of the target system may take the form of a slower clock speeds or system component response times. Programs written for the target system may be dependent on the slower speeds of the target system. Due to this dependency emulated programs may not be able to take advantage of the full capabilities of the host system.
In a cloud-based gaming system the majority of the processing takes place on the cloud-based server. This allows the client device platform that is communicating with the cloud-based server to use less resources for processing the cloud based game. Current techniques implement incremental buffering to make the game load faster and parallel processing between the server and the client. However as a result of this arrangement communication between the client device and the server must be synchronized. If the client device and the server are not synchronized it may result in unusual or unexpected device behavior.
With cloud based emulation of legacy games the client or host device is often significantly more powerful than the target system that the legacy game was programmed to run on. As a result improvements to the running of an emulated game could be achieved if the client device could accelerate the processing for emulation of games. Thus, there is a need in the art, for a way to accelerate processing of emulated games.
BRIEF DESCRIPTION OF THE DRAWINGS
Aspects of the present disclosure can be readily understood by considering the following detailed description in conjunction with the accompanying drawings, in which: FIG. 1 is a flow diagram of a method for selective acceleration of emulation according to an aspect of the present disclosure.
FIG. 2 is a flow diagram depicting method of detection of reduced need for synchronization and detecting a need for resynchronization according to aspects of the present disclosure. FIG. 3 is a flow diagram showing selective acceleration of emulation over a network according to aspects of the present disclosure.
FIG 4 is a block diagram of a system that implements selective acceleration of emulation according aspects of the present disclosure.
INTRODUCTION
Ordinarily when emulating a program written for a target system that is constrained by the power of the target system the output of the host system must be synchronized with the processing speed of the program assets on the target system. However during emulation of program assets for a target system on a host system there may be times when the host system does not need to be constrained by the processing speed of the target system. Within this window the host system may accelerate processing of program assets. Similarly emulation over a network may be constrained by the need for the client device and the server to be synchronized in order for the game to run correctly. This need for synchronization prohibits a more powerful client device from having improved performance when running emulated legacy games over the network. Thus according to aspects of the present disclosure performance of emulation of games over a network may be realized by accelerating processing of the emulated game at specific times within the application where
synchronization does not affect the performance of the game.
DESCRIPTION OF THE SPECIFIC EMBODIMENTS
Although the following detailed description contains many specific details for the purposes of illustration, anyone of ordinary skill in the art will appreciate that many variations and alterations to the following details are within the scope of the invention. Accordingly, the exemplary embodiments of the invention described below are set forth without any loss of generality to, and without imposing limitations upon, the claimed invention.
According to aspects of the present disclosure a host system may implement a scheme for accelerating emulation of programs written for a target system on a host system 100. The host system may carry out the emulation process by generating emulated program assets that can be processed by the host system to generate and utilize resulting outputs (referred to herein as host outputs). Alternatively, the host system may generate the program assets or host outputs and transmit them to a remote system over the network for processing and/or utilization. In the case of a host system implementing emulation, the target system code may be translated by the host system and the translated code may then be executed. During execution the host system may reduce the speed at which it processes instructions 101 in order to maintain synchronization between the outputs of the host system. For example the audio and video of a program may be synchronized on a target but when that program is emulated at the full speed of the host system there will be a loss in synchronization because the audio processes faster than the video on the host system and the original program was not designed to account for this difference. Similarly there may be processor speed dependent elements of video or audio in a program for a target system that when run on a host system at the full speed of the host system cause the program to behave in ways that are unexpected by the user. These problems all decrease the quality of emulation on a host system unless the system reduces the speed at which it processes the emulation. Thus to avoid loss of quality of emulation the host system synchronizes the processing of emulated assets and generation of host outputs with the speed of the emulated target system. As a result of this compromise the host system may not provide any apparent improvement in running target system programs to an end user despite being a newer and more powerful device.
To realize improved performance of target system programs on the host the host system implements a method for selective acceleration of processing as shown in FIG. 1. The host system may detect when there is a decreased need of synchronization of processing of emulated program assets with the emulation of the target system, as indicated at 102. There are a number of situations during emulation that may be characterized by a reduced need for emulation. A common feature of many such situations is that the user experience is not affected, or is even enhanced, by a reduced level or complete lack of synchronization between processing of emulated program assets and generation of host outputs. Some non- limiting examples of such situations include situations where audio, video, or haptic outputs need not be synchronized to other aspects of the emulation or with each other.
By way of example, and not by way of limitation, in certain implementations, detecting reduced need for synchronization of processing emulated program assets and the host output at 102 may include detecting a pre-loaded mini-game with preloaded audio and video components. Such detection may be used to trigger acceleration of loading of mini-games. For example a loading screen mini -game (i. e. , a mini-game that can be played as another application loads) can be identified by monitoring emulated program memory subsystems for uniquely identifiable behaviors indicative of non-visible asset preparation. An example of a behavior which may be unique to a loading screen mini-game is loading large assets into video memory and without immediate usage by the video subsystem. A repeating pattern of such unused allocations is a strong indication that background loading is occurring and that the behavior observed by the user is a mini-game or animated loading screen. Heuristic criteria for determining asset allocation size, repeating patterns, and immediate usage may vary according to the emulated target architecture.
If reduced need for synchronization is detected the host system may unlock synchronization with the emulation of the target system as indicated at 103, and accelerate processing of emulated program assets as indicated at 104. To detect whether the host system may unlock synchronization the host may implement an output detection process 200 as shown in FIG. 2. In the illustrated example, the output detection process may be split between detection of audio 202 and video 201.
For detection of video 201, the system may initially detect whether the display output is black or blank 203. Alternatively the host system detects whether the emulated program requires the host system to output an image to the screen 203. If an image output is detected the system may monitor the output to detect whether the required output is static 204. For instance the host system may monitor the video output for changes over a specified period of time, if no changes are found then the host system determines the screen is static 204.
Alternatively the host system may monitor whether the emulated program requires the output of a static screen 204. If a static screen is not detected the host system may monitor the emulated program assets to determine whether the video output has already been loaded into memory 205. If the host system detects that the video output has been preloaded into memory the host system may further determine whether any additional processing of the video is required. In other embodiments if the host system detects repeated bulky memory allocations to the system or GPU memory that are not immediately used then the host system may accelerate processing of video. A preloaded video may be detected as a single or repeated memory allocation that is immediately used. It should be understood that a bulky memory allocation may be defined by the system automatically or by a user depending upon the application. The threshold for immediate use may vary depending on application, system architecture, etc.
If during the above steps the host system determines that there is a no display output 203 or a static output 204 or a preloaded video sequence 205 then the system will unlock the synchronization of processing video assets 103. The synchronization of video assets may be between audio and video. Alternatively the synchronization may be between the processing clock speed of the emulated target system and processing of the video assets. For example the emulated program may include processor clock speed dependent assets that when processed at a different clock speed than the target system will create user-perceived unwanted behavior. By way of example and not by way of limitation user perceived unwanted behavior may be in a video game the characters move across the screen much faster than expected. In another embodiment the synchronization may be between the processing of video assets on the host system and an emulator running over the network on a remote system. In other words the host system may be receiving emulated program assets from a server operating over the network. As soon as the server sends a video asset to the host system may perform processes on the video asset and output the result to an display device. According to aspects of the current disclosure the host system unlocks synchronization of processing of video assets 103 during times when a user of the system would not detect a change in program behavior due to the accelerated processing of video data. By way of example and not by way of limitation, the host system may unlock synchronization 103 and accelerate processing video assets 104 by processing emulated video assets at clock speed that is higher than that of the emulated target system. In another embodiment the host system may unlock synchronizationl03 and accelerate processing 104 by processing emulated video assets at a higher rate than the playback rate of emulated audio assets. Similarly the host system may unlock
synchronization 103 and accelerate the processing of emulated video assets 104 by processing the emulated video assets at a faster rate on the host system than a remote emulator transmitting emulated assets over the network.
If the host system does not detect a preloaded video sequence or more processing is required on the preloaded video sequence, the processing of emulated video assets will remain synchronized with emulation of the target system 206. Though video assets were discussed the term is not limited to video and as used herein may refer to images displayed on a screen as well as data for rendering images or physics data for simulations or the like.
For detection of audio 202, the host system may initially detect whether there is any sound output to the speakers 207. Alternatively the host system may monitor the emulated audio assets to determine whether audio output is required. If audio output is required the host system may determine whether the audio output is below a threshold 208. If the audio output is not below a threshold the host system may monitor the emulated audio assets to determine whether the audio is already loaded in to memory 209. If the host system determines that the audio is preloaded the host system may further detect whether any processing needs to be done on the audio. In other embodiments if the host system detects repeated bulky memory allocations to the system or GPU memory that are not immediately used then the host system may accelerate processing of audio. Preloaded audio may be detected as a single or repeated memory allocation that is immediately used. It should be understood that a bulky memory allocation may be defined by the system automatically or by a user depending upon the application. The threshold for immediate use may vary depending on application, system architecture, etc.
If during the above steps it is determined that there is no audio 207 or the audio is below a threshold 208 or the audio is preloaded into memory 209 then the host system will unlock processing of the audio assets 103. As discussed above with respect to video, audio processing may be locked to the rate of the video. Similar to video, audio assets may be dependent on the clocks speed of the emulated target system and when processed at a different clock speed than the target system may result in user-perceived unwanted behavior. By way of example and not by way of limitation user-perceived unwanted audio behavior might be music playing at a higher pitch due to the accelerated processing. In another embodiment the synchronization may be between the processing of audio assets on the host system and an emulator running over the network on a remote system. In other words the host system may be receiving emulated audio assets from a server operating over the network. As soon as the server sends an audio asset to the host system, the host may perform processes on the audio asset and output the result to an output device (for instance speakers). According to aspects of the current disclosure the host system unlocks synchronization of processing of audio assets during times when a user of the system would not detect a change in program behavior due to the accelerated processing of audio data. By way of example and not by way of limitation, the host system may unlock synchronization 103 and accelerate processing audio assets 104 by processing emulated audio assets at a clock speed that is higher than that of the emulated target system. The host system may unlock synchronization 103 and accelerate processing of emulated audio assets 104 at a rate that is faster than the processing of emulated video assets. Similarly the host system may unlock synchronization 103 and accelerate processing of emulated audio assets 104 by processing audio assets at a faster rate on the host system than a remote emulator emulates the target system and transmits emulated assets over the network.
If the host system does not detect a preloaded audio or more processing is required on the preloaded audio 206, the processing of emulated audio assets will remain synchronized with emulation of the target system 101. Though audio assets were discussed the term is not limited sound files and as used herein may refer to music, contextual sounds, sounds from interactions within a simulated environment and the like.
According to aspects of the current disclosure while the host system is accelerating processing 104, the system may monitor output 210 to determine whether to resynchronize processing 105. The system may monitor the processing of the emulated program assets to determine whether the emulated program requires the system to output information to an external device 211. In some embodiments monitoring the processing of emulated program assets may include monitoring memory allocations to detect a change from allocation of bulky blocks of memory to use of those memory blocks to detect a change from outputting preloaded audio or video. By way of example and not by way of limitation the system may monitor the program for a change in display data to be sent to a screen or for changes in sound data to be sent to the speakers or for changes in other data such as color data to be sent to controllers or communication data to be sent over the network. If no change is detected the system will continue accelerated processing of the emulated program assets 103. If a change in output is required then the system will return to processing at the previous rate and resynchronize with the emulated target system 105. Once the system has resynchronized with targets 105 it may return to processing the synchronized program assets 101.
According to aspects of the present disclosure the unlocking of synchronization 103 is not limited to implementations of video and audio. The disclosed method of detecting output 200 and accelerating processing 100 may be applied to other types of output for instance color information for lights connected to the host system or robotic manipulator control information and the like. One possible example of implementation to robotic manipulator control information would be if the target system instructions were for an older style robotic device and the host device offers certain advantages, or has removed some particular mechanical process entirely. In such circumstances the emulation could be accelerated using the approach describe herein. In some situations, such target code instructions may be removed outright. In addition the techniques described herein may be applied to situations where the target instructions have other meaningful side effects, such that the instructions cannot be skipped, but need not be restricted to an established rate of execution that might have been established by the older style robotics. Fig 3 depicts other aspects of the current disclosure; the host system 301 may implement the method to accelerate emulation 100 in conjunction with an emulator operating over a network 302. In the case of a remote emulator 302 the host system may receive emulated program assets 303 from the remote emulator 302, process the emulated program assets immediately and output the result 106 to external devices 305. Thus in the described configuration the processing of emulated program assets on the host system 301 may be synchronized with the emulation of the target system on the remote emulator 302. To realize improvements in the operation of emulated programs on the host system, the host system 301 may implement the method of acceleration of emulation 100, including accelerated streaming of program assets 107. The host system 301 may provide feed-back 304 to the remote emulator 302 that includes information about the processing of emulated program assets 101, or 104. Thus the emulator may remain informed about the processing of emulated program assets on the host system and utilize this information when the host system resynchronizes 104 with the emulation of the target system on the emulator 302.
In other embodiments when the host system 301 detects 200 that it may unlock
synchronization of processing of emulated program assets 103, the host system may inform the remote emulator through the feedback 304. In response the remote emulator may accelerate the rate at which the emulated program assets are sent 307 to the host system 107. The emulated program assets that are sent 307 to the host system 301 at an accelerated rate may fill a buffer of the host system for further processing. Alternatively the program assets sent 307 at an accelerated rate 107 may be processed immediately in accordance with the accelerated processing 104 taking place on the host system 301. During this process the host system may continue to send feedback 304 to the remote emulator 302 to ensure that too many emulated program assets are not sent to the host system resulting in a buffer overflow condition. Likewise the host system 301 may send feedback 304 to the remote emulator 302 indicating that additional emulated program assets are needed immediately to prevent buffer underflow or stalling. Additionally the feedback reports 304 may inform the remote emulator to suspend cheat detection or other rate dependent processes during accelerated processing of emulated program assets.
Once the host system 301 determines that an output is required by the emulated program it may send a feedback 304 to the remote emulator 302 to resynchronize 105 the emulation of the target system on the emulator with the processing of emulated assets on the host system 301.
The block diagram shown in FIG. 4 schematically illustrates certain aspects of the present disclosure within the particular context of remote emulation. In this example, an emulator 407 may be accessed by a host system 402 over a network 460. The host system 402 may access alternative remote emulators 407 over the network 460 (herein referred to as remote emulators). Emulators 407 may be identical to each other, or they may each be programed to emulate unique legacy programs 406 including unique legacy games 406. Additionally, the emulator 407 may be contained within the host system 402 and may communicate directly with the host system over an internal system bus 450'
Alternatively the emulation of the target system may take place wholly on the host system 402. In this case the legacy program may be loaded in to the memory 436 of the host system 402 and the CPU 431 carries the out emulation program 433.
Host system 402 may include a central processor unit (CPU) 431. By way of example, a CPU 431 may include one or more processors, which may be configured according to, e.g., a dual-core, quad-core, multi-core, or Cell processor architecture. Host system 402 may also include a memory 432 (e.g., RAM, DRAM, ROM, and the like). The CPU 431 may execute a process-control program 433, portions of which may be stored in the memory 432. The host system 402 may also include well-known support circuits 440, such as input/output (I/O) circuits 441, power supplies (P/S) 442, a clock (CLK) 443 and cache 444. The host system 402 may optionally include a mass storage device 434 such as a disk drive, CD-ROM drive, tape drive, or the like to store programs and/or data. The host system 402 may also optionally include a display unit 437 and a user interface unit 438 to facilitate interaction between the Host System 402 and a user who requires direct access to the host system 402. The display unit 437 may be in the form of a cathode ray tube (CRT) or flat panel screen that displays text, numerals, or graphical symbols. The user interface unit 438 may include a keyboard, mouse, joystick, light pen, or other device. A controller 445 may be connected to the Host System 402 through the I/O circuit 441 or it may be directly integrated into the Host System 402. The controller 445 may facilitate interaction between the Host System 402 and a user. The controller 445 may include a keyboard, mouse, joystick, light pen, hand-held controls or other device. The controller 445 is also may be capable of generating a haptic response 446. By way of example and not by way of limitation, the haptic response 446 may be vibrations or any other feedback corresponding to the sense of touch. The Host System 402 may include a network interface 439, configured to enable the use of Wi-Fi, an Ethernet port, or other communication methods.
The network interface 439 may incorporate suitable hardware, software, firmware or some combination of two or more of these to facilitate communication via an electronic communications network 460. The network interface 439 may be configured to implement wired or wireless communication over local area networks and wide area networks such as the Internet. The Host System 402 may send and receive data and/or requests for files via one or more data packets over the network 460.
The preceding components may exchange signals with each other via an internal system bus 450. The Host System 402 may be a general purpose computer that becomes a special purpose computer when running code that implements embodiments of the present invention as described herein.
The emulator 407 may include a central processor unit (CPU) 431'. By way of example, a CPU 431' may include one or more processors, which may be configured according to, e.g., a dual-core, quad-core, multi-core, or Cell processor architecture. The emulator 407 may also include a memory 432' (e.g., RAM, DRAM, ROM, and the like). The CPU 431' may execute a process-control program 433', portions of which may be stored in the memory 432'. The emulator 407 may also include well-known support circuits 440', such as input/output (I/O) circuits 441', power supplies (P/S) 442', a clock (CLK) 443' and cache 444'. The emulator 407 may optionally include a mass storage device 434' such as a disk drive, CD-ROM drive, tape drive, or the like to store programs and/or data. The emulator 407 may also optionally include a display device 437' and user interface unit 438' to facilitate interaction between the emulator 407 and a user who requires direct access to the emulator 407. By way of example and not by way of limitation a host system or engineer 402 may need direct access to the emulator 407 in order to program the emulator 407 to properly emulate a desired legacy program 406 or to add additional capabilities to a legacy program 406. The display device 437' may be in the form of a cathode ray tube (CRT) or flat panel screen that displays text, numerals, or graphical symbols. The user interface unit 438' may include a keyboard, mouse, joystick, light pen, or other device. The emulator 407 may include a network interface 439', configured to enable the use of Wi-Fi, an Ethernet port, or other communication methods. The network interface 439' may incorporate suitable hardware, software, firmware or some combination of two or more of these to facilitate communication via the electronic communications network 460. The network interface 439' may be configured to implement wired or wireless communication over local area networks and wide area networks such as the Internet. The emulator 407 may send and receive data and/or requests for files via one or more data packets over the network 460.
The preceding components may exchange signals with each other via an internal system bus 450'. The emulator 407 may be a general purpose computer that becomes a special purpose computer when running code that implements embodiments of the present invention as described herein. Emulator 407 may access a legacy program 406 that has been selected by the Host System 402 for emulation through the internal system bus 450'. There may be more than one legacy program 406 stored in the emulator. The legacy programs may also be stored in the memory 432' or in the mass storage device 434'. Additionally, one or more legacy programs 406 may be stored at a remote location accessible to the emulator 407 over the network 460. Each legacy game 406 contains game code 408. When the legacy game 106 is emulated, the game code 408 produces legacy game data 409.
By way of example, a legacy program 406 may be any program that is not compatible with a target platform. By way of example and not by way of limitation, the legacy program 406 may have been designed to be played on Sony Computer Entertainment's PlayStation console, but the target platform is a home computer. By way of example, the legacy game 406 may have been designed to be played on a PlayStation 2 console, but the target platform is a PlayStation 3 console. Further, by way of example and not by way of limitation, a legacy game 406 may have been designed to be played on a PlayStation console, but the target platform is a hand held console such as the PlayStation Vita from Sony Computer
Entertainment.
While the above is a complete description of the preferred embodiment of the present invention, it is possible to use various alternatives, modifications and equivalents. Therefore, the scope of the present invention should be determined not with reference to the above description but should, instead, be determined with reference to the appended claims, along with their full scope of equivalents. Any feature described herein, whether preferred or not, may be combined with any other feature described herein, whether preferred or not. In the claims that follow, the indefinite article "A", or "An" refers to a quantity of one or more of the item following the article, except where expressly stated otherwise. The appended claims are not to be interpreted as including means-plus-function limitations, unless such a limitation is explicitly recited in a given claim using the phrase "means for."

Claims

WHAT IS CLAIMED IS : 1. In synchronized emulation of programs for a target system on a host system in which the target system is slower than the host system and one or more emulated program assets for the target system is synchronized with one or more host outputs of the host system, a method for selective acceleration of processing of emulated program assets on the host system, the method comprising:
a) processing the synchronized emulated program assets on the host system;
b) detecting reduced need for synchronization between the emulated program assets and a host output;
c) unlocking synchronization of processing of the one or more emulated program assets and the one or more host outputs;
d) accelerating processing on the host system of those of the one or more emulated program assets for which synchronization has been unlocked.
2. The method of claim 1 further comprising:
e) detecting an imminent need for synchronized host output;
f) resynchronizing processing of emulated program assets and the host outputs.
3. The method of claim 2 wherein: the accelerated processing of emulated program assets in d) further comprises receiving emulated program assets over the network at an accelerated rate.
4. The method of claim 3 wherein receiving emulated program assets over the network further comprises sending a signal over the network to unlock synchronization and wherein f) further comprises sending feedback over the network to resume synchronized emulation.
5. The method of claim 1 wherein detecting reduced need for synchronization of processing emulated program assets and the host output in b) includes detecting decreased video output.
6. The method of claim 5 wherein the decreased video output is a blank or black screen.
7. The method of claim 5 wherein the decreased video output is a static image.
8. The method of claim 5 wherein the decreased video output is a preloaded video sequence or loop.
9. The method of claim 5 wherein unlocking synchronization in c) is only performed on video components and accelerating processing in d) is only performed on video components.
10. The method of claim 1 wherein detecting reduced need for synchronization of processing emulated program assets and host output in b) includes detecting decreased audio output.
11. The method of claim 10 wherein decreased audio output is no audio signal.
12. The method of claim 10 wherein decreased audio output is an audio signal below a
threshold.
13. The method of claim 10 wherein decreased audio output is a preloaded audio sequence or loop.
14. The method of claim 10 wherein unlocking synchronization in c) is only performed on audio components and accelerating processing in d) is only performed on audio components.
15. The method of claim 1 wherein detecting reduced need for synchronization of processing emulated program assets and the host output in b) comprises detecting a pre-loaded mini- game with preloaded audio and video components.
16. The method of claim 2 wherein detecting an imminent need for host output in e)
comprises detecting a communication output to a controller.
17. The method of claim 2 wherein detecting an imminent need for host output in e)
comprises detecting a communication output with a server on the network.
18. The method of claim 2 wherein detecting an imminent need for host output in e)
comprises detecting a communication output with a display device.
19. The method of claim 2 wherein detecting an imminent need for host output in e)
comprises detecting a communication output an audio output device.
20. A non-transitory computer-readable medium containing executable instructions that when executed cause a computer system to implement method for selective acceleration of processing of emulated one or more program assets that are synchronized to one or more host outputs of the host system, the method comprising:
a) processing the synchronized emulated program assets on the host system;
b) detecting reduced need for synchronization of processing of the one or more emulated program assets with a host output;
c) unlocking synchronization of the one or more emulated program assets and the one or more host outputs;
d) accelerating processing on the host system of those emulated program assets of the one or more program assets for which synchronization has been unlocked.
PCT/US2018/029207 2010-12-16 2018-04-24 Selective acceleration of emulation Ceased WO2018217377A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
EP18806655.9A EP3630318B1 (en) 2017-05-26 2018-04-24 Selective acceleration of emulation
CN201880034784.6A CN111656746B (en) 2017-05-26 2018-04-24 Simulated selective acceleration
JP2019565381A JP6824446B2 (en) 2017-05-26 2018-04-24 Selective acceleration of emulation

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US42394410P 2010-12-16 2010-12-16
US15/607,302 US10783008B2 (en) 2017-05-26 2017-05-26 Selective acceleration of emulation
US15/607,302 2017-05-26

Publications (1)

Publication Number Publication Date
WO2018217377A1 true WO2018217377A1 (en) 2018-11-29

Family

ID=64409543

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2018/029207 Ceased WO2018217377A1 (en) 2010-12-16 2018-04-24 Selective acceleration of emulation

Country Status (1)

Country Link
WO (1) WO2018217377A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN118069374A (en) * 2024-04-18 2024-05-24 清华大学 Data center intelligent training simulation transaction acceleration method, device, equipment and medium

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020109680A1 (en) * 2000-02-14 2002-08-15 Julian Orbanes Method for viewing information in virtual space
US20050081218A1 (en) * 2003-08-26 2005-04-14 Acott Troy Steven Configurable simulation of virtual machine behavior
US20060281556A1 (en) * 2005-05-12 2006-12-14 Microsoft Corporation System and method for distributing updates to runtime systems without destabilizing compatibility
US20140004956A1 (en) * 2012-06-29 2014-01-02 Sony Computer Entertainment Inc. Adding triggers to cloud-based emulated games
US20140094299A1 (en) 2012-09-28 2014-04-03 Victor Octav Suba Mura Method and apparatus for improving efficiency wihout increasing latency in emulation of a legacy application title
US20140094314A1 (en) * 2012-09-28 2014-04-03 Brian Michael Christopher Watson Method for creating a mini-game

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020109680A1 (en) * 2000-02-14 2002-08-15 Julian Orbanes Method for viewing information in virtual space
US20050081218A1 (en) * 2003-08-26 2005-04-14 Acott Troy Steven Configurable simulation of virtual machine behavior
US20060281556A1 (en) * 2005-05-12 2006-12-14 Microsoft Corporation System and method for distributing updates to runtime systems without destabilizing compatibility
US7685593B2 (en) * 2005-05-12 2010-03-23 Microsoft Corporation Systems and methods for supporting multiple gaming console emulation environments
US20140004956A1 (en) * 2012-06-29 2014-01-02 Sony Computer Entertainment Inc. Adding triggers to cloud-based emulated games
US20140094299A1 (en) 2012-09-28 2014-04-03 Victor Octav Suba Mura Method and apparatus for improving efficiency wihout increasing latency in emulation of a legacy application title
US20140094314A1 (en) * 2012-09-28 2014-04-03 Brian Michael Christopher Watson Method for creating a mini-game

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN118069374A (en) * 2024-04-18 2024-05-24 清华大学 Data center intelligent training simulation transaction acceleration method, device, equipment and medium

Similar Documents

Publication Publication Date Title
US9248374B2 (en) Replay and resumption of suspended game
US11724205B2 (en) Suspending state of cloud-based legacy applications
US9454282B2 (en) Sending application input commands over a network
US9717989B2 (en) Adding triggers to cloud-based emulated games
US10293251B2 (en) Pre-loading translated code in cloud based emulated applications
US9656163B2 (en) Haptic enhancements for emulated video game not originally designed with haptic capabilities
EP2888651B1 (en) Method for creating a mini-game
US20140004941A1 (en) Conversion of haptic events into screen events
CN101065171B (en) Information processing apparatus and data processing method
AU2021236140B2 (en) Peer-to-peer multiplayer cloud gaming architecture
US10717002B2 (en) Game device, method for controlling game device
US9658776B2 (en) Compression of state information for data transfer over cloud-based networks
US11013993B2 (en) Pre-loading translated code in cloud based emulated applications
CN110399214B (en) Method and device for optimizing display card load and computer equipment
US8478855B1 (en) Application control translation
WO2018217377A1 (en) Selective acceleration of emulation
EP3630318B1 (en) Selective acceleration of emulation
WO2014052206A1 (en) Replay and resumption of suspended game
EP4270189A1 (en) Method of optimizing execution of a function on a control system and apparatus for the same
US20170065884A1 (en) Game device, game system, control method, and control program

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 18806655

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 2019565381

Country of ref document: JP

Kind code of ref document: A

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2018806655

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2018806655

Country of ref document: EP

Effective date: 20200102