Changes

Jump to navigation Jump to search

Dynamic recompilation

155 bytes added, 20:35, 5 December 2022
Example
* Updating of elapsed cycle counts on platforms with cycle count registers
* Management of interrupt checking
* Providing an interface to virtualized support hardware for example a [[GPU]]
* Optimizing higher level code structures to run efficiently on the target hardware (see below)
Suppose a program is being run in an emulator and needs to copy a null-terminated string. The program is compiled originally for a very simple processor. This processor can only copy a byte at a time, and must do so by first reading it from the source string into a register, then writing it from that register into the destination string. The original program might look something like this:
<source lang=asm> beginning:
mov A,[first string pointer] ; Put location of first character of source string
; in register A
mov B,[second string pointer] ; Put location of first character of destination string
; in register B
loop:
mov C,[A] ; Copy byte at address in register A to register C
mov [B],C ; Copy byte in register C to the address in register B
jnz loop ; If it wasn't 0 then we have more to copy, so go back
; and copy the next byte
end: ; If we didn't loop then we must have finished, ; so carry on with something else.</source>
The emulator might be running on a processor which is similar, but extremely good at copying strings, and the emulator knows it can take advantage of this.
Our new recompiled code might look something like this:
<source lang=asm> beginning:
mov A,[first string pointer] ; Put location of first character of source string
; in register A
mov B,[second string pointer] ; Put location of first character of destination string
; in register B
loop:
movs [B],[A] ; Copy 16 bytes at address in register A to address
; in register B, then increment A and B by 16
jnz loop ; If the zero flag isn't set then we haven't reached
; the end of the string, so go back and copy some more.
end: ; If we didn't loop then we must have finished, ; so carry on with something else.</source>
There is an immediate speed benefit simply because the processor doesn't have to load so many instructions to do the same task, but also because the movs instruction is likely to be optimized by the processor designer to be more efficient than the sequence used in the first example. (For example, it may make better use of [[Parallel computing|parallel execution]] in the processor to increment A and B while it is still copying bytes).
===Gaming===
*[[MAME]] uses dynamic recompilation in its CPU emulators for MIPS, SuperH, PowerPC and even the Voodoo graphics processing units.
*[[1964]], a an open-source [[Nintendo 64 emulators|Nintendo 64 emulator]] for [[wikipedia:x86|x86 ]] hardware.*Wii64, a [[Nintendo 64 emulators|Nintendo 64 emulator]] for the Nintendo Wii.
*WiiSX, a Sony PlayStation emulator for the Nintendo Wii.
*[[Mupen64Plus]], a an open-source, multi-platform , plugin-based Nintendo 64 emulator.<ref>[http://pandorawiki.org/Mupen64plus_dynamic_recompiler Mupen64Plus]</ref>*[[Yabause]], a an open-source multi-platform [[Sega Saturn emulators|Sega Saturn emulator]].<ref>[http://wiki.yabause.org/index.php5?title=SH2_dynamic_recompiler SH2]</ref>
*The backwards compatibility functionality of the [[Xbox 360 emulators|Xbox 360]] (i.e. running games written for the original [[Xbox emulators|Xbox]]) is widely assumed to use dynamic recompilation.
*[[PPSSPP]], a Sony an open-source, multi-platform [[PlayStation Portable emulators|Sony PlayStation Portable emulator]]. Recompilers for both x86 and ARM.*PSEmu Pro, a Sony [[PlayStation emulators|Sony PlayStation emulator]].
*[[UltraHLE]], the first [[Nintendo 64 emulators|Nintendo 64 emulators]] emulator to fully run commercial games.
*[[PCSX2]],<ref>[http://www.pcsx2.net PCSX 2PCSX2]</ref> a Sony an open-source, plugin-based [[PlayStation 2 emulators|Sony PlayStation 2 emulator]], has a recompiler called "microVU", the successor of "SuperVU".*[[Dolphin]], a an open-source [[GameCube emulators|Nintendo GameCube]] and [[Wii emulators|Wii emulator]], has a dynarec option.
*GCEmu,<ref>[http://sourceforge.net/projects/gcemu-project GCEmu]</ref> a [[GameCube emulators|Nintendo GameCube emulator]].
*[[nullDC]], a an open-source [[Sega Dreamcast emulators|Sega Dreamcast ]] and [[Sega NAOMI and variants|Naomi emulator]] for [[wikipedia:x86|x86]].
*GEM,<ref>{{cite web|url=http://gem.tni.nl/ |title=Gameboy Emulator for MSX &#124; The New Image |publisher=GEM |date= |accessdate=2014-01-12}}</ref> a [[Game Boy/Game Boy Color emulators|Nintendo Game Boy/Color]] emulator for [[MSX emulators|MSX]] uses an optimizing dynamic recompiler.
*[[DeSmuME]],<ref>[http://desmume.org/2013/04/30/desmume-0-9-9-released/ DeSmuME v0.9.9]</ref> a an open-source [[Nintendo DS emulators|Nintendo DS emulator]], has a dynarec option.*Soywiz's Psp,<ref>{{cite web|author=Publicado por Carlos Ballesteros Velasco |url=http://pspemu.soywiz.com/2013/07/release-soywizs-psp-emulator-2013-07-28.html |title=Soywiz's PSP Emulator: Release : Soywiz's Psp Emulator 2013-07-28 (r525) |publisher=Pspemu.soywiz.com |date=2013-07-28 |accessdate=2014-01-12}}</ref> a Sony [[PlayStation Portable emulators|Sony PlayStation Portable emulator]], has a dynarec option.
==See also==
Anonymous user

Navigation menu