Misplaced Pages

Emulator: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 09:15, 28 February 2014 editCodename Lisa (talk | contribs)55,077 edits Emulation versus simulation: WP:NOTMANUAL← Previous edit Latest revision as of 13:24, 21 December 2024 edit undoKvng (talk | contribs)Extended confirmed users, New page reviewers108,347 edits rm emulator not illustrated 
(350 intermediate revisions by more than 100 users not shown)
Line 1: Line 1:
{{Short description|System allowing a device to imitate another}}
{{About|emulators in ]|a line of digital musical instruments|E-mu Emulator|the Transformers character|Circuit Breaker (Transformers)#Shattered Glass|other uses|Emulation (disambiguation)}}
{{About|emulators in ]|a line of digital musical instruments|E-mu Emulator|other uses|Emulation (disambiguation)}}
{{Distinguish|Simulator}}

] emulates the ] of DOS.]] ] emulates the ] of DOS.]]
In ], an '''emulator''' is hardware or software or both that duplicates (or ''emulates'') the functions of one computer system (the ''guest'') in another computer system (the ''host''), different from the first one, so that the emulated behavior closely resembles the behavior of the real system (the guest). This focus on exact reproduction of behavior is in contrast to some other forms of ], in which an abstract model of a system is being simulated. For example, a computer simulation of a hurricane or a chemical reaction is not emulation.


In ], an '''emulator''' is ] or ] that enables one ] (called the ''host'') to behave like another computer system (called the ''guest''). An emulator typically enables the host system to run software or use peripheral devices designed for the guest system.
==Emulators in computing==
Emulation refers to the ability of a ] in an electronic device to emulate (or imitate) another program or device.
{{rquote|right|"Can a Commodore 64 emulate MS-DOS?"


Many ], for example, are designed to emulate ] ] printers because so much software is written for HP printers. If a non-HP printer emulates an HP printer, any software written for a real HP printer will also run in the non-HP printer emulation and produce equivalent printing. Since at least the 1990s, many ] enthusiasts and hobbyists have used emulators to play classic ]s from the 1980s using the games' original 1980s machine code and data, which is interpreted by a current-era system, and to emulate old ] (see ]).
Yes, it's possible for a 64 to emulate an IBM PC, in the same sense that it's possible to bail out ] with a teaspoon.|Letter to ''Compute!'' and editorial answer, April 1988<ref name="compute198804">{{cite news | url=https://archive.org/stream/1988-04-compute-magazine/Compute_Issue_095_1988_Apr#page/n43/mode/2up | title=MS-DOS Emulation For The 64 | work=Compute! | date=April 1988 | accessdate=10 November 2013 | author=Warick, Mike | pages=43}}</ref>}}


A hardware emulator is an emulator which takes the form of a hardware device. Examples include the DOS-compatible card installed in some 1990s-era ] computers, such as the ] or ], that allowed them to run ] (PC) software programs and ]-based ]s. The ] implies that theoretically, any operating environment can be emulated within any other environment, assuming memory limitations are ignored. However, in practice, it can be quite difficult, particularly when the exact behavior of the system to be emulated is not documented and has to be deduced through ]. It also says nothing about timing constraints; if the emulator does not perform as quickly as it did using the original hardware, the software inside the emulation may run much more slowly (possibly triggering timer interrupts that alter behavior).
'''Emulation''' refers to the ability of a ] in an electronic device to '''emulate''' (imitate) another program or device. Many ], for example, are designed to emulate ] ] printers because so much software is written for HP printers. If a non-HP printer emulates an HP printer, any software written for a real HP printer will also run in the non-HP printer emulation and produce equivalent printing.


{{rquote|right|"Can a ] emulate ]?"
A '''hardware emulator''' is an emulator which takes the form of a hardware device. Examples include the DOS-compatible card installed in some old-world Macintoshes like Centris 610 or Performa 630 that allowed them to run PC programs and ]-based ]s.


Yes, it's possible for a 64 to emulate an IBM PC , in the same sense that it's possible to bail out ] with a ].|Letter to ''Compute!'' and editorial answer, April 1988<ref name="compute198804">{{cite news | url=https://archive.org/stream/1988-04-compute-magazine/Compute_Issue_095_1988_Apr#page/n43/mode/2up | title=MS-DOS Emulation For The 64 | work=Compute! | date=April 1988 | access-date=10 November 2013 | author=Warick, Mike | pages=43}}</ref>}}
In a theoretical sense, the ] implies that any operating environment can be emulated within any other. However, in practice, it can be quite difficult, particularly when the exact behavior of the system to be emulated is not documented and has to be deduced through ]. It also says nothing about timing constraints; if the emulator does not perform as quickly as the original hardware, the emulated software may run much more slowly than it would have on the original hardware, possibly triggering time interrupts that alter performance.


==Types==
==Emulation in preservation==
] emulator, which is in turn running a ] emulator]]
Emulation is a strategy in ] to combat ]. Emulation focuses on recreating an original computer environment, which can be time-consuming and difficult to achieve, but valuable because of its ability to maintain a closer connection to the authenticity of the digital object.<ref>{{Cite web
|url=http://www.kb.nl/hrd/dd/dd_projecten/projecten_emulatiewatis-en.html
|title=What is emulation?
|accessdate=2007-12-11
|work=Koninklijke Bibliotheek}}</ref>


] running on the ] Game Boy emulator on ], itself running on ] on a modern ] system]]
Emulation addresses the original ] and ] environment of the digital object, and recreates it on a current machine.<ref>van der Hoeven, Jeffrey, Bram Lohman, and Remco Verdegem. "Emulation for Digital Preservation in Practice: The Results." The International Journal of Digital Curation 2.2 (2007): 123-132.</ref> The emulator allows the user to have access to any kind of ] or ] on a current ], while the ] runs as it did in its original environment.<ref name="Muira, Gregory 2007">Muira, Gregory. " Pushing the Boundaries of Traditional Heritage Policy: maintaining long-term access to multimedia content." IFLA Journal 33 (2007): 323-326.</ref> Jeffery Rothenberg, an early proponent of emulation as a ] strategy states, "the ideal approach would provide a single extensible, long-term solution that can be designed once and for all and applied uniformly, automatically, and in synchrony (for example, at every refresh cycle) to all types of documents and media".<ref>{{Cite web
Most emulators just emulate a hardware architecture—if operating system firmware or software is required for the desired software, it must be provided as well (and may itself be emulated). Both the OS and the software will then be ] by the emulator, rather than being run by native hardware. Apart from this interpreter for the emulated binary ], some other hardware (such as input or output devices) must be provided in virtual form as well; for example, if writing to a specific memory location should influence what is displayed on the screen, then this would need to be emulated. While emulation could, if taken to the extreme, go down to the atomic level, basing its output on a simulation of the actual circuitry from a virtual power source, this would be a highly unusual solution. Emulators typically stop at a simulation of the documented hardware specifications and digital logic. Sufficient emulation of some hardware platforms requires extreme accuracy, down to the level of individual clock cycles, undocumented features, unpredictable analog elements, and implementation bugs. This is particularly the case with classic home computers such as the ], whose software often depends on highly sophisticated low-level programming tricks invented by game programmers and the "]".
|author=Rothenberg, Jeffrey
|title="Criteria for an Ideal Solution." Avoiding Technological Quicksand: Finding a Viable Technical Foundation for Digital Preservation.
|location=Washington, DC
|year=1998
|work=Council on Library and Information Resources
|accessdate=2008-03-08|url=http://www.clir.org/pubs/reports/rothenberg/contents.html}}</ref> He further states that this should not only apply to out of date systems, but also be upwardly mobile to future unknown systems.<ref>Rothenberg, Jeffrey. "The Emulation Solution." Avoiding Technological Quicksand: Finding a Viable Technical Foundation for Digital Preservation. Washington, DC: Council on Library and Information Resources, 1998. Council on Library and Information Resources. 2008. 28 Mar. 2008 http://www.clir.org/pubs/reports/rothenberg/contents.html</ref> Practically speaking, when a certain application is released in a new version, rather than address ] issues and ] for every digital object created in the previous version of that ], one could create an emulator for the ], allowing access to all of said digital objects.


In contrast, some other platforms have had very little use of direct hardware addressing, such as an emulator for the PlayStation 4.<ref>{{Cite web
===Benefits===
|author=GuideStorm
]
|title=PlayStation 4 Emulators
* Emulators allow users to play games for discontinued consoles.
|access-date=2019-08-04|url=https://guidestorm.com/scam-alert/ps4-emulator/}}</ref> In these cases, a simple ] may suffice. This translates system calls for the foreign system into system calls for the host system e.g., the Linux compatibility layer used on *BSD to run closed source Linux native software on ] and ].<ref>Linux emulation removed from OpenBSD at version 6.0 https://www.openbsd.org/60.html</ref> For example, while the ] graphic processor was fully programmable, most games used one of a few pre-made programs, which were mostly self-contained and communicated with the game via ]; therefore, many emulators do not emulate the graphic processor at all, but simply interpret the commands received from the CPU as the original program would. Developers of software for ]s or ]s often design their software on especially accurate emulators called ] before trying it on the real hardware. This is so that software can be produced and tested before the final hardware exists in large quantities, so that it can be tested without taking the time to copy the program to be debugged at a low level and without introducing the side effects of a ]. In many cases, the simulator is actually produced by the company providing the hardware, which theoretically increases its accuracy. Math co-processor emulators allow programs compiled with math instructions to run on machines that do not have the co-processor installed, but the extra work done by the CPU may slow the system down. If a math coprocessor is not installed or present on the CPU, when the CPU executes any co-processor instruction it will make a determined interrupt (coprocessor not available), calling the math emulator routines. When the instruction is successfully emulated, the program continues executing.
* Emulators maintain the original look, feel, and behavior of the digital object, which is just as important as the digital data itself.<ref>Muira, Gregory." Pushing the Boundaries of Traditional Heritage Policy: maintaining long-term access to multimedia content." IFLA Journal 33 (2007): 323-326.</ref>
* Despite the original cost of developing an emulator, it may prove to be the more cost efficient solution over time.<ref>Granger, Stewart. Digital Preservation & Emulation: from theory to practice. Proc. of the ichim01 Meeting, vol. 2, 3 -7 Sept. 2001. Milano, Italy. Toronto: Archives and Museum Informatics, University of Toronto, 2001. 28 Mar. 2008 http://www.leeds.ac.uk/cedars/pubconf/papers/ichim01SG.html</ref>
* Reduces ] hours, because rather than continuing an ongoing task of continual ] for every digital object, once the library of past and present ] and ] is established in an emulator, these same technologies are used for every document using those ].<ref name="Muira, Gregory 2007"/>
* Many emulators have already been developed and released under ] through the ] environment, allowing for wide scale collaboration.<ref>van der Hoeven, Jeffrey, Bram Lohman, and Remco Verdegem. "Emulation for Digital Preservation in Practice: The Results." The International Journal of Digital Curation 2.2 (2007): 123-132.</ref>
* Emulators allow software exclusive to one system to be used on another. For example, a ] exclusive ] could (in theory) be played on a ] or ] using an emulator. This is especially useful when the original system is difficult to obtain, or incompatible with modern equipment (e.g. old video game consoles may be unable to connect to modern TVs).


===Obstacles=== ===Logic simulators===
{{Main article|Logic simulation}}
* ] - Many technology vendors implemented non-standard features during program development in order to establish their niche in the market, while simultaneously applying ongoing upgrades to remain competitive. While this may have advanced the technology industry and increased vendor's ], it has left users lost in a preservation nightmare with little supporting documentation due to the proprietary nature of the hardware and software.<ref>Granger, Stewart. "Emulation as a Digital Preservation Strategy." D-Lib Magazine 6.19 (2000). 29 Mar 2008 http://www.dlib.org/dlib/october00/granger/10granger.html</ref>
* ] laws are not yet in effect to address saving the documentation and specifications of proprietary software and hardware in an emulator module.<ref>Rothenberg, Jeffrey. "The Emulation Solution." Avoiding Technological Quicksand: Finding a Viable Technical Foundation for Digital Preservation. Washington, DC: Council on Library and Information Resources, 1998. Council on Library and Information Resources. 2008. 28 Mar. 2008</ref>
* Emulators are often used as a ] tool, since they allow users to play video games without having to buy the console, and rarely make any attempt to prevent the use of illegal copies. This leads to a number of legal uncertainties regarding emulation, and leads to software being programmed to refuse to work if it can tell the host is an emulator; some video games in particular will continue to run, but not allow the player to progress beyond some late stage in the game, often appearing to be faulty or just extremely difficult.<ref>http://tcrf.net/Pok%C3%A9mon_Black_and_White#Anti-Piracy</ref><ref>http://tcrf.net/Mega_Man_Star_Force#Anti-Piracy</ref> These protections make it more difficult to design emulators, since they must be accurate enough to avoid triggering the protections, whose effects may not be obvious.


Logic simulation is the use of a computer program to simulate the operation of a digital circuit such as a processor.<ref>{{Cite book|url=https://www.worldcat.org/oclc/433173319|title=Electronic design automation : synthesis, verification, and test|date=2009|publisher=Morgan Kaufmann/Elsevier|others=Laung-Terng Wang, Yao-Wen Chang, Kwang-Ting Cheng|isbn=978-0-08-092200-3|location=Amsterdam|oclc=433173319}}</ref> This is done after a digital circuit has been designed in logic equations, but before the circuit is fabricated in hardware.
==Emulators in new media art==
Because of its primary use of digital formats, ] relies heavily on emulation as a preservation strategy. Artists such as ] specialize in resurrecting obsolete technologies in their artwork and recognize the importance of a decentralized and deinstitutionalized process for the preservation of digital culture.


===Functional emulators===
In many cases, the goal of emulation in new media art is to preserve a digital medium so that it can be saved indefinitely and reproduced without error, so that there is no reliance on hardware that ages and becomes obsolete. The paradox is that the emulation and the emulator have to be made to work on future computers.<ref>{{Cite web|url=http://www.variablemedia.net/e/echoes/index.html |title=Echoes of Art: Emulation as preservation strategy |accessdate=2007-12-11 }}</ref>
{{Main article|High level emulation}}


Functional simulation is the use of a computer program to simulate the execution of a second computer program written in symbolic ] or ] language, rather than in binary ]. By using a functional simulator, programmers can execute and trace selected sections of source code to search for programming errors (bugs), without generating binary code. This is distinct from simulating execution of binary code, which is software emulation. The first functional simulator was written by ] about 1960{{Citation needed|date=April 2024}} for testing assembly language programs for later execution in military computer ]. This made it possible for flight programs to be written, executed, and tested before D-17B computer hardware had been built. Autonetics also programmed a functional simulator for testing flight programs for later execution in the military computer ].
==Emulation in future systems design==
{{Main|Full system simulation}}
Emulation technics are commonly used during the design and development of new systems. It eases the development process by providing the ability to detect, recreate and repair flaws in the design even before the system is actually built.<ref>{{cite web|author=Peter Magnusson|year=2004|url=http://www.computerworld.com/s/article/96584/Full_System|title=Full System Simulation: Software Development's Missing Link}}</ref> It is particularly useful in the design of multi-cores systems, where concurrency errors can be very difficult to detect and correct without the controlled environment provided by virtual hardware.<ref>{{cite web|url=http://www.ddj.com/184406408|title=Debugging and Full System Simulation}}</ref> This also allows the software development to take place before the hardware is ready,<ref>{{cite web|year=2009|author=Vania Joloboff|url=http://www.irisa.fr/archi09/joloboff.pdf|title=Full System Simulation of Embedded Systems}}</ref> thus helping to validate design decisions.


==Types of emulators== ===Video game console emulators===
{{Main article|Video game console emulator}}
] emulator, which is in turn running a ] emulator.]]
] running on the ] GameBoy emulator on ], itself running on ] on a modern ] system.]]
Most emulators just emulate a hardware architecture—if operating system firmware or software is required for the desired software, it must be provided as well (and may itself be emulated). Both the OS and the software will then be ] by the emulator, rather than being run by native hardware. Apart from this interpreter for the emulated binary ], some other hardware (such as input or output devices) must be provided in virtual form as well; for example, if writing to a specific memory location should influence what is displayed on the screen, then this would need to be emulated.


Video game console emulators are programs that allow a personal computer or video game console to emulate another video game console. They are most often used to play older 1980s to 2000s-era video games on modern personal computers and more contemporary video game consoles. They are also used to translate games into other languages, to modify existing games, and in the development process of "home brew" ] demos and in the creation of new games for older systems. The ] has helped in the spread of console emulators, as most - if not all - would be unavailable for sale in retail outlets. Examples of console emulators that have been released in the last few decades are: ], ], ], ], ], ], ], ], ], ], ], and ].
While emulation could, if taken to the extreme, go down to the atomic level, basing its output on a simulation of the actual circuitry from a virtual power source, this would be a highly unusual solution. Emulators typically stop at a simulation of the documented hardware specifications and digital logic. Sufficient emulation of some hardware platforms requires extreme accuracy, down to the level of individual clock cycles, undocumented features, unpredictable analog elements, and implementation bugs. This is particularly the case with classic home computers such as the ], whose software often depends on highly sophisticated low-level programming tricks invented by game programmers and the ].


Due to their popularity, emulators have been impersonated by malware. Most of these emulators are for video game consoles like the Xbox 360, Xbox One, Nintendo 3DS, etc. Generally such emulators make currently impossible <!-- As of June 2018 --> claims such as being able to run ] and ] games in a single program.<ref>{{Cite web|title=The Emulation Imitation|url=https://blog.malwarebytes.org/cybercrime/2014/10/the-emulation-imitation/|access-date=2016-05-30|website=Malwarebytes Labs|date=17 October 2014|language=en-us}}</ref>
In contrast, some other platforms have had very little use of direct hardware addressing. In these cases, a simple ] may suffice. This translates system calls for the emulated system into system calls for the host system e.g., the Linux compatibility layer used on *BSD to run closed source Linux native software on FreeBSD, NetBSD and OpenBSD. For example, while the ] graphic processor was fully programmable, most games used one of a few pre-made programs, which were mostly self-contained and communicated with the game via ]; therefore, many emulators do not emulate the graphic processor at all, but simply interpret the commands received from the CPU as the original program would.


====Legal issues====
Developers of software for ]s or ]s often design their software on especially accurate emulators called ] before trying it on the real hardware. This is so that software can be produced and tested before the final hardware exists in large quantities, so that it can be tested without taking the time to copy the program to be debugged at a low level and without introducing the side effects of a ]. In many cases, the simulator is actually produced by the company providing the hardware, which theoretically increases its accuracy.
:{{Further|Console emulator#Legal issues}}
As computers and ] continued to advance and emulator developers grew more skilled in their work, the length of time between the commercial release of a console and its successful emulation began to shrink. ] consoles such as ], ] and ] handhelds, such as the ], saw significant progress toward emulation during their production. This led to an effort by console manufacturers to stop unofficial emulation, but consistent failures such as '']'' 977 F.2d 1510 (9th Cir. 1992), '']'' 203 F.3d 596 (2000), and '']'' 214 F.3d 1022 (2000),<ref name="Sony v Bleem Legal Opinion">{{cite web|date=14 February 2000|title=Sony Computer Entertainment America v. Bleem, 214 F. 3d 1022|url=https://scholar.google.com/scholar_case?q=SONY+COMPUTER+ENTERTAINMENT+AMERICA+v.+BLEEM&hl=en&as_sdt=2,1&as_vis=1&case=11837224078052556056&scilh=0|access-date=15 June 2016|work=Google Scholar|publisher=Court of Appeals|publication-date=4 May 2000|department=9th Circuit 2000}}</ref> have had the opposite effect. According to all legal precedents, emulation is legal within the United States. However, unauthorized distribution of copyrighted code remains illegal, according to both country-specific ] and international copyright law under the ].<ref>''see ]'', 574 F.Supp. 999, aff'd, 704 F.2d 1009 (9th Cir 1982) (holding the computer ROM of Pac Man to be a sufficient fixation for purposes of copyright law even though the game changes each time played.) and Article 2 of the Berne Convention</ref>{{Better source needed|date=June 2016}} Under United States law, obtaining a ] copy of the original machine's ] is legal under the ruling '']'', 964 F.2d 965 (9th Cir. 1992) as ] as long as the user obtained a legally purchased copy of the machine. To mitigate this however, several emulators for platforms such as ] are capable of running without a BIOS file, using high-level emulation to simulate BIOS subroutines at a slight cost in emulation accuracy.{{citation needed|reason=Don't mean to be too harsh here but without a citation it leans on original research.|date=June 2016}}


===Terminal ===
Math coprocessor emulators allow programs compiled with math instructions to run on machines that don't have the coprocessor installed, but the extra work done by the CPU may slow the system down. If a math coprocessor isn't installed or present on the CPU, when the CPU executes any coprocessor instruction it will make a determined interrupt (coprocessor not available), calling the math emulator routines. When the instruction is successfully emulated, the program continues executing.
{{Main article|Terminal emulator}}


Terminal emulators are software programs that provide modern computers and devices interactive access to applications running on ] operating systems or other host systems such as ] or ]. Terminals such as the ] or ] and many others are no longer produced as physical devices. Instead, software running on modern operating systems simulates a "dumb" terminal and is able to render the graphical and text elements of the host application, send keystrokes and process commands using the appropriate terminal protocol. Some terminal emulation applications include ], ], and ] Rumba.
==Structure of an emulator==

{{Refimprove|article's section named "Structure of an emulator"|date=June 2008}}
=== Other types ===
Other types of emulators include:

* ]: the process of imitating the behavior of one or more pieces of hardware (typically a system under design) with another piece of hardware, typically a special purpose emulation system
* ]: the use of a hardware device to ] the ] of an ]
* ]: Some floating-point hardware only supports the simplest operations: addition, subtraction, and multiplication. In systems without any floating-point hardware, the CPU emulates it using a series of simpler fixed-point arithmetic operations that run on the integer arithmetic logic unit.
* ] in a ]: Mimics the behavior of a mainframe or ] by "reading" instructions and maintaining internal variables which represent the processor's ].
* ]: a technique for testing the performance of real applications over a virtual network. This is different from ] where virtual models of traffic, network models, channels, and protocols are applied.
* ]: Multiplayer video games often rely on an online game server, which may or may not be available for on-premises installation. A server emulator is an unofficial on-premises server that imitates the behavior of the official online server, even though its internal working might be different.
*]: the process of controlling an emulation through a simulator

==Structure and organization==
{{More citations needed|article's section named "Structure and organization"|date=June 2008}}
Typically, an emulator is divided into ] that correspond roughly to the emulated computer's subsystems. Typically, an emulator is divided into ] that correspond roughly to the emulated computer's subsystems.
Most often, an emulator will be composed of the following modules: Most often, an emulator will be composed of the following modules:
* a CPU emulator or CPU simulator (the two terms are mostly interchangeable in this case) * a CPU emulator or CPU simulator (the two terms are mostly interchangeable in this case), unless the target being emulated has the same CPU architecture as the host, in which case a ] layer may be used instead
* a memory subsystem module * a memory subsystem module
* various I/O devices emulators * various input/output (I/O) device emulators


Buses are often not emulated, either for reasons of performance or simplicity, and virtual peripherals communicate directly with the CPU or the memory subsystem. Buses are often not emulated, either for reasons of performance or simplicity, and virtual peripherals communicate directly with the CPU or the memory subsystem.


===Memory subsystem=== ===Memory subsystem===
It is possible for the memory subsystem emulation to be reduced to simply an array of elements each sized like an emulated word; however, this model falls very quickly as soon as any location in the computer's logical memory does not match ]. It is possible for the memory subsystem emulation to be reduced to simply an array of elements each sized like an emulated word; however, this model fails very quickly as soon as any location in the computer's logical memory does not match ]. This clearly is the case whenever the emulated hardware allows for advanced memory management (in which case, the ] logic can be embedded in the memory emulator, made a module of its own, or sometimes integrated into the CPU simulator). Even if the emulated computer does not feature an MMU, though, there are usually other factors that break the equivalence between logical and physical memory: many (if not most) architectures offer ]; even those that do not often have a block of logical memory mapped to ], which means that the memory-array module must be discarded if the read-only nature of ROM is to be emulated. Features such as ] or ] may also complicate memory emulation. As a result, most emulators implement at least two procedures for writing to and reading from logical memory, and it is these procedures' duty to map every access to the correct location of the correct object.

This clearly is the case whenever the emulated hardware allows for advanced memory management (in which case, the ] logic can be embedded in the memory emulator, made a module of its own, or sometimes integrated into the CPU simulator).

Even if the emulated computer does not feature an MMU, though, there are usually other factors that break the equivalence between logical and physical memory: many (if not most) architectures offer ]; even those that do not often have a block of logical memory mapped to ], which means that the memory-array module must be discarded if the read-only nature of ROM is to be emulated. Features such as ] or ] may also complicate memory emulation.

As a result, most emulators implement at least two procedures for writing to and reading from logical memory, and it is these procedures' duty to map every access to the correct location of the correct object.


On a ] system where memory from address ''0'' to address ''ROMSIZE-1'' is read-only memory, while the rest is RAM, something along the line of the following procedures would be typical: On a ] system where memory from address ''0'' to address ''ROMSIZE-1'' is read-only memory, while the rest is RAM, something along the line of the following procedures would be typical:
<source lang="c"> <syntaxhighlight lang="c">
void WriteMemory(word Address, word Value) { void WriteMemory(word Address, word Value) {
word RealAddress; word RealAddress;
Line 96: Line 89:
} }
} }
</syntaxhighlight>
</source>


<source lang="c"> <syntaxhighlight lang="c">
word ReadMemory(word Address) { word ReadMemory(word Address) {
word RealAddress; word RealAddress;
Line 109: Line 102:
} }
} }
</syntaxhighlight>
</source>


===CPU simulator=== ===CPU simulator===
The CPU simulator is often the most complicated part of an emulator. Many emulators are written using "pre-packaged" CPU simulators<!--- (see ]) --->, in order to concentrate on good and efficient emulation of a specific machine. The CPU simulator is often the most complicated part of an emulator. Many emulators are written using "pre-packaged" CPU simulators, in order to concentrate on good and efficient emulation of a specific machine. The simplest form of a CPU simulator is an ], which is a computer program that follows the execution flow of the emulated program code and, for every machine code instruction encountered, executes operations on the host processor that are semantically equivalent to the original instructions. This is made possible by assigning a ] to each ] and ] of the simulated CPU. The logic of the simulated CPU can then more or less be directly translated into software algorithms, creating a software re-implementation that basically mirrors the original hardware implementation.

The simplest form of a CPU simulator is an ], which is a computer program that follows the execution flow of the emulated program code and, for every machine code instruction encountered, executes operations on the host processor that are semantically equivalent to the original instructions.

This is made possible by assigning a ] to each ] and ] of the simulated CPU. The logic of the simulated CPU can then more or less be directly translated into software algorithms, creating a software re-implementation that basically mirrors the original hardware implementation.


The following example illustrates how CPU simulation can be accomplished by an interpreter. In this case, interrupts are checked-for before every instruction executed, though this behavior is rare in real emulators for performance reasons (it is generally faster to use a subroutine to do the work of an interrupt). The following example illustrates how CPU simulation can be accomplished by an interpreter. In this case, interrupts are checked-for before every instruction executed, though this behavior is rare in real emulators for performance reasons (it is generally faster to use a subroutine to do the work of an interrupt).
<source lang="c"> <syntaxhighlight lang="c">
void Execute(void) { void Execute(void) {
if (Interrupt != INT_NONE) { if (Interrupt != INT_NONE) {
Line 135: Line 124:
} }
} }
</syntaxhighlight>
</source>
Interpreters are very popular as computer simulators, as they are much simpler to implement than more time-efficient alternative solutions, and their speed is more than adequate for emulating computers of more than roughly a decade ago on modern machines. Interpreters are very popular as computer simulators, as they are much simpler to implement than more time-efficient alternative solutions, and their speed is more than adequate for emulating computers of more than roughly a decade ago on modern machines. However, the speed penalty inherent in interpretation can be a problem when emulating computers whose processor speed is on the same ] as the host machine{{Dubious|date=May 2012}}. Until not many years ago, emulation in such situations was considered completely impractical by many{{Dubious|date=May 2012}}.

However, the speed penalty inherent in interpretation can be a problem when emulating computers whose processor speed is on the same ] as the host machine{{Dubious|date=May 2012}}. Until not many years ago, emulation in such situations was considered completely impractical by many{{Dubious|date=May 2012}}.


What allowed breaking through this restriction were the advances in ] techniques{{Dubious|date=May 2012}}. Simple ''a priori'' translation of emulated program code into code runnable on the host architecture is usually impossible because of several reasons: What allowed breaking through this restriction were the advances in ] techniques{{Dubious|date=May 2012}}. Simple ''a priori'' translation of emulated program code into code runnable on the host architecture is usually impossible because of several reasons:
Line 145: Line 132:


Various forms of dynamic recompilation, including the popular ] technique, try to circumvent these problems by waiting until the processor control flow jumps into a location containing untranslated code, and only then ("just in time") translates a block of the code into host code that can be executed. Various forms of dynamic recompilation, including the popular ] technique, try to circumvent these problems by waiting until the processor control flow jumps into a location containing untranslated code, and only then ("just in time") translates a block of the code into host code that can be executed.
The translated code is kept in a ''code ]''{{Dubious|date=May 2012}}, and the original code is not lost or affected; this way, even data segments can be (meaninglessly) translated by the recompiler, resulting in no more than a waste of translation time. The translated code is kept in a ''code ]''{{Dubious|date=May 2012}}, and the original code is not lost or affected; this way, even data segments can be (meaninglessly) translated by the recompiler, resulting in no more than a waste of translation time. Speed may not be desirable as some older games were not designed with the speed of faster computers in mind. A game designed for a 30&nbsp;MHz PC with a level timer of 300 game seconds might only give the player 30 seconds on a 300&nbsp;MHz PC. Other programs, such as some DOS programs, may not even run on faster computers. Particularly when emulating computers which were "closed-box", in which changes to the core of the system were not typical, software may use techniques that depend on specific characteristics of the computer it ran on (e.g. its CPU's speed) and thus precise control of the speed of emulation is important for such applications to be properly emulated.


===Input/output (I/O)===
Speed may not be desirable as some older games were not designed with the speed of faster computers in mind. A game designed for a 30&nbsp;MHz PC with a level timer of 300 game seconds might only give the player 30 seconds on a 300&nbsp;MHz PC. Other programs, such as some DOS programs, may not even run on faster computers. Particularly when emulating computers which were "closed-box", in which changes to the core of the system were not typical, software may use techniques that depend on specific characteristics of the computer it ran on (i.e. its CPU's speed) and thus precise control of the speed of emulation is important for such applications to be properly emulated.
Most emulators do not, as mentioned earlier, emulate the main ]; each I/O device is thus often treated as a special case, and no consistent interface for virtual peripherals is provided. This can result in a performance advantage, since each I/O module can be tailored to the characteristics of the emulated device; designs based on a standard, unified I/O ] can, however, rival such simpler models, if well thought-out, and they have the additional advantage of "automatically" providing a plug-in service through which third-party virtual devices can be used within the emulator. A unified I/O API may not necessarily mirror the structure of the real hardware bus: bus design is limited by several electric constraints and a need for hardware ] <!--- although this page talks specifically about *programming*, while here I really refer to the concurrency that is inherent in hardware ---> management that can mostly be ignored in a software implementation.

===I/O===
Most emulators do not, as mentioned earlier, emulate the main ]; each I/O device is thus often treated as a special case, and no consistent interface for virtual peripherals is provided.

This can result in a performance advantage, since each I/O module can be tailored to the characteristics of the emulated device; designs based on a standard, unified I/O ] can, however, rival such simpler models, if well thought-out, and they have the additional advantage of "automatically" providing a plug-in service through which third-party virtual devices can be used within the emulator.

A unified I/O API may not necessarily mirror the structure of the real hardware bus: bus design is limited by several electric constraints and a need for hardware ] <!--- although this page talks specifically about *programming*, while here I really refer to the concurrency that is inherent in hardware ---> management that can mostly be ignored in a software implementation.


Even in emulators that treat each device as a special case, there is usually a common basic infrastructure for: Even in emulators that treat each device as a special case, there is usually a common basic infrastructure for:
Line 160: Line 141:
* writing to and reading from physical memory, by means of two procedures similar to the ones dealing with logical memory (although, contrary to the latter, the former ''can'' often be left out, and direct references to the memory array be employed instead) * writing to and reading from physical memory, by means of two procedures similar to the ones dealing with logical memory (although, contrary to the latter, the former ''can'' often be left out, and direct references to the memory array be employed instead)


== Applications ==
== Emulation versus simulation ==

The word "emulator" was coined in 1963 at IBM<ref>{{cite book |last =Pugh|first = Emerson W.|title = Building IBM: Shaping an Industry and Its Technology |publisher = MIT|year = 1995 |isbn = 0-262-16147-8|page = 274}}</ref> during development of the NPL (]) product line, using a "new combination of software, microcode, and hardware".<ref>{{Cite book|last =Pugh|first = Emerson W.|coauthors = et al.|title = IBM's 360 and Early 370 Systems |publisher = MIT|year = 1991|isbn = 0-262-16123-0}} pages 160-161</ref>
===In preservation===
They discovered that using ] hardware instead of software simulation, to execute programs written for earlier IBM computers, dramatically increased simulation speed. Earlier, IBM provided ] for, e.g., the ] on the ].<ref></ref>

Emulation is one strategy in pursuit of ] and combating ]. Emulation focuses on recreating an original computer environment, which can be time-consuming and difficult to achieve, but valuable because of its ability to maintain a closer connection to the authenticity of the digital object, operating system, or even gaming platform.<ref>{{Cite web|title=What is emulation?|url=http://www.kb.nl/en/organisation/research-expertise/research-on-digitisation-and-digital-preservation/emulation|access-date=2007-12-11|work=Koninklijke Bibliotheek|archive-date=2015-09-13|archive-url=https://web.archive.org/web/20150913012600/https://www.kb.nl/en/organisation/research-expertise/research-on-digitisation-and-digital-preservation/emulation|url-status=dead}}</ref> Emulation addresses the original ] and ] environment of the digital object, and recreates it on a current machine.<ref>van der Hoeven, Jeffrey, Bram Lohman, and Remco Verdegem. "Emulation for Digital Preservation in Practice: The Results." The International Journal of Digital Curation 2.2 (2007): 123-132.</ref> The emulator allows the user to have access to any kind of ] or ] on a current ], while the ] runs as it did in its original environment.<ref name="Muira, Gregory 2007">Muira, Gregory. " Pushing the Boundaries of Traditional Heritage Policy: maintaining long-term access to multimedia content." IFLA Journal 33 (2007): 323-326.</ref> Jeffery Rothenberg, an early proponent of emulation as a ] strategy states, "the ideal approach would provide a single ], long-term solution that can be designed once and for all and applied uniformly, automatically, and in organized synchrony (for example, at every refresh cycle) to all types of documents and media".<ref>{{Cite web|author=Rothenberg, Jeffrey|year=1998|title="Criteria for an Ideal Solution." Avoiding Technological Quicksand: Finding a Viable Technical Foundation for Digital Preservation.|url=http://www.clir.org/pubs/reports/rothenberg/contents.html|access-date=2008-03-08|work=Council on Library and Information Resources|location=Washington, DC}}</ref> He further states that this should not only apply to out of date systems, but also be upwardly mobile to future unknown systems.<ref>Rothenberg, Jeffrey. "The Emulation Solution." Avoiding Technological Quicksand: Finding a Viable Technical Foundation for Digital Preservation. Washington, DC: Council on Library and Information Resources, 1998. Council on Library and Information Resources. 2008. 28 Mar. 2008 http://www.clir.org/pubs/reports/rothenberg/contents.html</ref> Practically speaking, when a certain application is released in a new version, rather than address ] issues and ] for every digital object created in the previous version of that ], one could create an emulator for the ], allowing access to all of said digital objects.

===In new media art===
Because of its primary use of digital formats, ] relies heavily on emulation as a preservation strategy. Artists such as ] specialize in resurrecting obsolete technologies in their artwork and recognize the importance of a ] and deinstitutionalized process for the preservation of digital culture. In many cases, the goal of emulation in new media art is to preserve a digital medium so that it can be saved indefinitely and reproduced without error, so that there is no reliance on hardware that ages and becomes obsolete. The paradox is that the emulation and the emulator have to be made to work on future computers.<ref>{{Cite web|title=Echoes of Art: Emulation as preservation strategy|url=http://www.variablemedia.net/e/echoes/index.html|url-status=dead|archive-url=https://web.archive.org/web/20071027162102/http://www.variablemedia.net/e/echoes/index.html|archive-date=2007-10-27|access-date=2007-12-11}}</ref>

===In future systems design===
{{Main article|Full system simulation}}

Emulation techniques are commonly used during the design and development of new systems. It eases the development process by providing the ability to detect, recreate and repair flaws in the design even before the system is actually built.<ref>{{cite web|author=Peter Magnusson|year=2004|title=Full System Simulation: Software Development's Missing Link|url=http://www.computerworld.com/s/article/96584/Full_System}}</ref> It is particularly useful in the design of ] systems, where concurrency errors can be very difficult to detect and correct without the controlled environment provided by virtual hardware.<ref>{{cite web|title=Debugging and Full System Simulation|url=http://www.ddj.com/184406408}}</ref> This also allows the software development to take place before the hardware is ready,<ref>{{cite web|author=Vania Joloboff|year=2009|title=Full System Simulation of Embedded Systems|url=http://www.irisa.fr/archi09/joloboff.pdf|url-status=dead|archive-url=https://web.archive.org/web/20140209190242/http://www.irisa.fr/archi09/joloboff.pdf|archive-date=2014-02-09|access-date=2012-04-22}}</ref> thus helping to validate design decisions and give a little more control.


== Comparison with simulation ==
In addition to simulators, IBM had compatibility features on the ] and ],<ref></ref> for which it
{{Main|Computer simulation}}
provided the IBM 709 computer with a program to run legacy programs written for the ] on the ] and later on the IBM 7090. This program used the instructions added by the compatibility feature<ref>{{cite manual
The word "emulator" was coined in 1963 at IBM<ref>{{cite book |last =Pugh|first = Emerson W.|title = Building IBM: Shaping an Industry and Its Technology |publisher = MIT|year = 1995 |isbn = 0-262-16147-8|page = 274}}</ref> during development of the NPL (]) product line, using a "new ] of ], ], and ]".<ref>{{Cite book|last =Pugh|first = Emerson W.|title = IBM's 360 and Early 370 Systems |publisher = MIT|year = 1991|isbn = 0-262-16123-0|display-authors=etal}} pages 160-161</ref> They discovered that simulation using additional instructions implemented in ] and hardware, instead of software simulation using only standard instructions, to execute programs written for earlier IBM computers dramatically increased simulation speed. Earlier, IBM provided ] for, e.g., the ] on the ].<ref></ref> In addition to simulators, IBM had compatibility features on the ] and ],<ref>{{cite web|url=http://www-03.ibm.com/ibm/history/exhibits/mainframe/mainframe_PP7090B.html|archive-url=https://web.archive.org/web/20050313050927/http://www-03.ibm.com/ibm/history/exhibits/mainframe/mainframe_PP7090B.html|url-status=dead|archive-date=March 13, 2005|title=IBM Archives: 7090 Data Processing System (continued)|date=23 January 2003|website=www-03.ibm.com}}</ref> for which it provided the IBM 709 computer with a program to run legacy programs written for the ] on the ] and later on the IBM 7090. This program used the instructions added by the compatibility feature<ref>{{cite book
| author =
| title = Reference Manual IBM 7090 Data Processing System | title = Reference Manual IBM 7090 Data Processing System
| section = System Compatibility Operations | section = System Compatibility Operations
| sectionurl =
| version =
| publisher =
| date = March 1962 | date = March 1962
| url = http://bitsavers.org/pdf/ibm/7090/22-6528-4_7090Manual.pdf | url = http://bitsavers.org/pdf/ibm/7090/22-6528-4_7090Manual.pdf
| format =
| id = A22-6528-4 | id = A22-6528-4
| accessdate =
| quote =
| page =
| pages = 65–66 | pages = 65–66
}}</ref> to trap instructions requiring special handling; all other 704 instructions ran the same on a 7090. The compatibility feature on the ]<ref>{{cite book
| ref =
}}</ref> to trap instructions requiring special handling; all other 704 instructions ran the same on a 7090. The compatibility feature on the ]<ref>{{cite manual
| author =
| title = IBM 1410 Principles of Operation | title = IBM 1410 Principles of Operation
| section = System Compatibility Operations | section = System Compatibility Operations
| sectionurl =
| version =
| publisher =
| date = March 1962 | date = March 1962
| url = http://bitsavers.org/pdf/ibm/1410/A22-0526-3_1410_princOps.pdf | url = http://bitsavers.org/pdf/ibm/1410/A22-0526-3_1410_princOps.pdf
| format =
| id = A22-0526-3 | id = A22-0526-3
| accessdate =
| quote =
| page =
| pages = 56–57, 98–100 | pages = 56–57, 98–100
| ref =
}}</ref> only required setting a console toggle switch, not a support program. }}</ref> only required setting a console toggle switch, not a support program.


In 1963, when microcode was first used to speed up this simulation process, IBM engineers coined the term "emulator" to describe the concept. In the 2000s, it has become common to use the word "emulate" in the context of software. However, before 1980, "emulation" referred only to emulation with a hardware or microcode assist, while "simulation" referred to pure software emulation.<ref>{{cite journal |doi=10.1145/365691.365931 |title=Emulation of large systems |journal=Communications of the ACM |volume=8 |issue=12 |pages=753–61 |year=1965 |last1=Tucker |first1=S. G |s2cid=15375675 |doi-access=free }}</ref> For example, a computer specially built for running programs designed for another architecture is an emulator. In contrast, a simulator could be a program which runs on a PC, so that old Atari games can be simulated on it. Purists continue to insist on this distinction, but currently the term "emulation" often means the complete imitation of a machine executing binary code while "simulation" often refers to ], where a computer program is used to simulate an abstract model. Computer simulation is used in virtually every scientific and engineering domain and Computer Science is no exception, with several projects simulating abstract models of computer systems, such as ], which both practically and semantically differs from network emulation.<ref>{{cite web|title=Network simulation or emulation?|url=https://www.networkworld.com/article/964353/network-simulation-or-emulation.html|website=Network World|date=22 September 2017|access-date=22 September 2017}}</ref>
In 1963, when microcode was first used to speed up this simulation process, IBM engineers coined the term "emulator" to describe the concept.


== Comparison with hardware virtualization ==
It has recently become common to use the word "emulate" in the context of software. However, before 1980, "emulation" referred only to emulation with a hardware or microcode assist, while "simulation" referred to pure software emulation.<ref>S. G. Tucker, "Emulation of Large Systems", Communications of the ACM (CACM) Vol. 8, No. 12, Dec. 1965, pp. 753-761</ref> For example, a computer specially built for running programs designed for another architecture is an emulator. In contrast, a simulator could be a program which runs on a PC, so that old Atari games can be simulated on it. Purists continue to insist on this distinction, but currently the term "emulation" often means the complete imitation of a machine executing binary code while "simulation" often refers to ], where a computer program is used to simulate an abstract model. Computer simulation is used in virtually every scientific and engineering domain and Computer Science is no exception, with several projects simulating abstract models of computer systems, such as ].
{{Main|Hardware virtualization}}

Hardware virtualization is the ] of ]s as complete hardware platforms, certain logical abstractions of their components, or only the functionality required to run various ]s. Virtualization hides the physical characteristics of a computing platform from the users, presenting instead an abstract computing platform.<ref>{{cite book|last1=Turban|first1=E|url=http://wps.prenhall.com/wps/media/objects/5073/5195381/pdf/Online_Chapter_19.pdf|title=Electronic Commerce A Managerial Perspective|last2=King|first2=D.|last3=Lee|first3=J.|last4=Viehland|first4=D.|publisher=Prentice-Hall|year=2008|edition=5th|pages=27|chapter=19|access-date=2021-12-13|archive-date=2009-05-21|archive-url=https://web.archive.org/web/20090521003109/http://wps.prenhall.com/wps/media/objects/5073/5195381/pdf/Online_Chapter_19.pdf|url-status=dead}}</ref><ref>{{cite web|date=October 2007|title=Virtualization in education|url=http://www-07.ibm.com/solutions/in/education/download/Virtualization%20in%20Education.pdf|access-date=6 July 2010|publisher=]}}</ref> At its origins, the software that controlled virtualization was called a "control program", but the terms "]" or "virtual machine monitor" became preferred over time.<ref name=":0">{{cite web|last=Creasy|first=R.J.|year=1981|title=The Origin of the VM/370 Time-sharing System|url=http://pages.cs.wisc.edu/~stjones/proj/vm_reading/ibmrd2505M.pdf|access-date=26 February 2013|publisher=]}}</ref> Each hypervisor can manage or run multiple ]s.
==Logic simulators==
{{Main|Logic simulation}}
Logic simulation is the use of a computer program to simulate the operation of a digital circuit such as a processor. This is done after a digital circuit has been designed in logic equations, but before the circuit is fabricated in hardware.

==Functional simulators==
{{Main|High level emulation}}
Functional simulation is the use of a computer program to simulate the execution of a second computer program written in symbolic ] or ] language, rather than in binary ]. By using a functional simulator, programmers can execute and trace selected sections of source code to search for programming errors (bugs), without generating binary code. This is distinct from simulating execution of binary code, which is software emulation.

The first functional simulator was written by ] about 1960 for testing assembly language programs for later execution in military computer ]. This made it possible for flight programs to be written, executed, and tested before D-17B computer hardware had been built. Autonetics also programmed a functional simulator for testing flight programs for later execution in the military computer ].

==Video game console emulators==
{{Main|Video game console emulator}}

Video game console emulators are programs that allow a personal computer or video game console to emulate another video game console. They are most often used to play older video games on personal computers and more contemporary video game consoles, but they are also used to translate games into other languages, to modify existing games, and in the development process of home brew demos and new games for older systems. The ] has helped in the spread of console emulators, as most - if not all - would be unavailable for sale in retail outlets. Examples of console emulators that have been released in the last 2 decades are: ], ], ], ], ], ], ], ] and ].
<!--
To avoid clogging up the article try to keep this to one emulator per platform - and that isn't carte blanche to add every emulated platform either!
-->

==Terminal emulators==
{{Main|Terminal emulator}}
Terminal emulators are software programs that provide modern computers and devices interactive access to applications running on ] operating systems or other host systems such as ] or ]. Terminals such as the ] or ] and many others, are no longer produced as physical devices. Instead, software running on modern operating systems simulates a "dumb" terminal and is able to render the graphical and text elements of the host application, send keystrokes and process commands using the appropriate terminal protocol. Some terminal emulation applications include ], ], ] and ] Rumba.

==Legal controversy==
:''See article ]''


==See also== ==See also==
* The ] * ]
* The ] ** ]
**]
* The ]
** ]
* ] is the larger field of modeling real-world phenomenon (e.g. physics and economy) using computers.
* Other uses of the term "emulator" in the field of computer science:
** ]
** ]
** ]
** ]
** ]
* ]
* ]
* Translation:
** ]

* ] (ICE)
** ]
** ]

* ]
* ]
* ]
* ]
* ]

==Notes==
{{Reflist|group=NB}}


==References== ==References==
Line 262: Line 190:
==External links== ==External links==
{{Wiktionary|emulate}} {{Wiktionary|emulate}}
{{Wiktionary|Emulator}} {{Wiktionary|emulator}}

* is a repertory of emulators and their respective histories (site closed in 2010 due to copyright issues).
* {{dmoz|Computers/Emulators}}
<!--===========================({{NoMoreLinks}})=============================== <!--===========================({{NoMoreLinks}})===============================
| DO NOT ADD MORE LINKS TO THIS ARTICLE. WIKIPEDIA IS NOT A COLLECTION OF | | DO NOT ADD MORE LINKS TO THIS ARTICLE. WIKIPEDIA IS NOT A COLLECTION OF |
Line 275: Line 202:
| See ] and ] for details | | See ] and ] for details |
===========================({{NoMoreLinks}})===============================--> ===========================({{NoMoreLinks}})===============================-->

{{Authority control}}


] ]
]
]

Latest revision as of 13:24, 21 December 2024

System allowing a device to imitate another This article is about emulators in computing. For a line of digital musical instruments, see E-mu Emulator. For other uses, see Emulation (disambiguation). Not to be confused with Simulator.
DOSBox emulates the command-line interface of DOS.

In computing, an emulator is hardware or software that enables one computer system (called the host) to behave like another computer system (called the guest). An emulator typically enables the host system to run software or use peripheral devices designed for the guest system. Emulation refers to the ability of a computer program in an electronic device to emulate (or imitate) another program or device.

Many printers, for example, are designed to emulate HP LaserJet printers because so much software is written for HP printers. If a non-HP printer emulates an HP printer, any software written for a real HP printer will also run in the non-HP printer emulation and produce equivalent printing. Since at least the 1990s, many video game enthusiasts and hobbyists have used emulators to play classic arcade games from the 1980s using the games' original 1980s machine code and data, which is interpreted by a current-era system, and to emulate old video game consoles (see video game console emulator).

A hardware emulator is an emulator which takes the form of a hardware device. Examples include the DOS-compatible card installed in some 1990s-era Macintosh computers, such as the Centris 610 or Performa 630, that allowed them to run personal computer (PC) software programs and field-programmable gate array-based hardware emulators. The Church–Turing thesis implies that theoretically, any operating environment can be emulated within any other environment, assuming memory limitations are ignored. However, in practice, it can be quite difficult, particularly when the exact behavior of the system to be emulated is not documented and has to be deduced through reverse engineering. It also says nothing about timing constraints; if the emulator does not perform as quickly as it did using the original hardware, the software inside the emulation may run much more slowly (possibly triggering timer interrupts that alter behavior).

"Can a Commodore 64 emulate MS-DOS?" Yes, it's possible for a 64 to emulate an IBM PC , in the same sense that it's possible to bail out Lake Michigan with a teaspoon.

— Letter to Compute! and editorial answer, April 1988

Types

Windows XP running an Archimedes emulator, which is in turn running a ZX Spectrum emulator
Tetris running on the Wzonka-Lad Game Boy emulator on AmigaOS, itself running on E-UAE on a modern Fedora Linux system

Most emulators just emulate a hardware architecture—if operating system firmware or software is required for the desired software, it must be provided as well (and may itself be emulated). Both the OS and the software will then be interpreted by the emulator, rather than being run by native hardware. Apart from this interpreter for the emulated binary machine's language, some other hardware (such as input or output devices) must be provided in virtual form as well; for example, if writing to a specific memory location should influence what is displayed on the screen, then this would need to be emulated. While emulation could, if taken to the extreme, go down to the atomic level, basing its output on a simulation of the actual circuitry from a virtual power source, this would be a highly unusual solution. Emulators typically stop at a simulation of the documented hardware specifications and digital logic. Sufficient emulation of some hardware platforms requires extreme accuracy, down to the level of individual clock cycles, undocumented features, unpredictable analog elements, and implementation bugs. This is particularly the case with classic home computers such as the Commodore 64, whose software often depends on highly sophisticated low-level programming tricks invented by game programmers and the "demoscene".

In contrast, some other platforms have had very little use of direct hardware addressing, such as an emulator for the PlayStation 4. In these cases, a simple compatibility layer may suffice. This translates system calls for the foreign system into system calls for the host system e.g., the Linux compatibility layer used on *BSD to run closed source Linux native software on FreeBSD and NetBSD. For example, while the Nintendo 64 graphic processor was fully programmable, most games used one of a few pre-made programs, which were mostly self-contained and communicated with the game via FIFO; therefore, many emulators do not emulate the graphic processor at all, but simply interpret the commands received from the CPU as the original program would. Developers of software for embedded systems or video game consoles often design their software on especially accurate emulators called simulators before trying it on the real hardware. This is so that software can be produced and tested before the final hardware exists in large quantities, so that it can be tested without taking the time to copy the program to be debugged at a low level and without introducing the side effects of a debugger. In many cases, the simulator is actually produced by the company providing the hardware, which theoretically increases its accuracy. Math co-processor emulators allow programs compiled with math instructions to run on machines that do not have the co-processor installed, but the extra work done by the CPU may slow the system down. If a math coprocessor is not installed or present on the CPU, when the CPU executes any co-processor instruction it will make a determined interrupt (coprocessor not available), calling the math emulator routines. When the instruction is successfully emulated, the program continues executing.

Logic simulators

Main article: Logic simulation

Logic simulation is the use of a computer program to simulate the operation of a digital circuit such as a processor. This is done after a digital circuit has been designed in logic equations, but before the circuit is fabricated in hardware.

Functional emulators

Main article: High level emulation

Functional simulation is the use of a computer program to simulate the execution of a second computer program written in symbolic assembly language or compiler language, rather than in binary machine code. By using a functional simulator, programmers can execute and trace selected sections of source code to search for programming errors (bugs), without generating binary code. This is distinct from simulating execution of binary code, which is software emulation. The first functional simulator was written by Autonetics about 1960 for testing assembly language programs for later execution in military computer D-17B. This made it possible for flight programs to be written, executed, and tested before D-17B computer hardware had been built. Autonetics also programmed a functional simulator for testing flight programs for later execution in the military computer D-37C.

Video game console emulators

Main article: Video game console emulator

Video game console emulators are programs that allow a personal computer or video game console to emulate another video game console. They are most often used to play older 1980s to 2000s-era video games on modern personal computers and more contemporary video game consoles. They are also used to translate games into other languages, to modify existing games, and in the development process of "home brew" DIY demos and in the creation of new games for older systems. The Internet has helped in the spread of console emulators, as most - if not all - would be unavailable for sale in retail outlets. Examples of console emulators that have been released in the last few decades are: RPCS3, Dolphin, Cemu, PCSX2, PPSSPP, ZSNES, Citra, ePSXe, Project64, Visual Boy Advance, Nestopia, and Yuzu.

Due to their popularity, emulators have been impersonated by malware. Most of these emulators are for video game consoles like the Xbox 360, Xbox One, Nintendo 3DS, etc. Generally such emulators make currently impossible claims such as being able to run Xbox One and Xbox 360 games in a single program.

Legal issues

Further information: Console emulator § Legal issues

As computers and global computer networks continued to advance and emulator developers grew more skilled in their work, the length of time between the commercial release of a console and its successful emulation began to shrink. Fifth generation consoles such as Nintendo 64, PlayStation and sixth generation handhelds, such as the Game Boy Advance, saw significant progress toward emulation during their production. This led to an effort by console manufacturers to stop unofficial emulation, but consistent failures such as Sega v. Accolade 977 F.2d 1510 (9th Cir. 1992), Sony Computer Entertainment, Inc. v. Connectix Corporation 203 F.3d 596 (2000), and Sony Computer Entertainment America v. Bleem 214 F.3d 1022 (2000), have had the opposite effect. According to all legal precedents, emulation is legal within the United States. However, unauthorized distribution of copyrighted code remains illegal, according to both country-specific copyright and international copyright law under the Berne Convention. Under United States law, obtaining a dumped copy of the original machine's BIOS is legal under the ruling Lewis Galoob Toys, Inc. v. Nintendo of America, Inc., 964 F.2d 965 (9th Cir. 1992) as fair use as long as the user obtained a legally purchased copy of the machine. To mitigate this however, several emulators for platforms such as Game Boy Advance are capable of running without a BIOS file, using high-level emulation to simulate BIOS subroutines at a slight cost in emulation accuracy.

Terminal

Main article: Terminal emulator

Terminal emulators are software programs that provide modern computers and devices interactive access to applications running on mainframe computer operating systems or other host systems such as HP-UX or OpenVMS. Terminals such as the IBM 3270 or VT100 and many others are no longer produced as physical devices. Instead, software running on modern operating systems simulates a "dumb" terminal and is able to render the graphical and text elements of the host application, send keystrokes and process commands using the appropriate terminal protocol. Some terminal emulation applications include Attachmate Reflection, IBM Personal Communications, and Micro Focus Rumba.

Other types

Other types of emulators include:

  • Hardware emulator: the process of imitating the behavior of one or more pieces of hardware (typically a system under design) with another piece of hardware, typically a special purpose emulation system
  • In-circuit emulator: the use of a hardware device to debug the software of an embedded system
  • Floating-point emulator: Some floating-point hardware only supports the simplest operations: addition, subtraction, and multiplication. In systems without any floating-point hardware, the CPU emulates it using a series of simpler fixed-point arithmetic operations that run on the integer arithmetic logic unit.
  • Instruction set simulator in a high-level programming language: Mimics the behavior of a mainframe or microprocessor by "reading" instructions and maintaining internal variables which represent the processor's registers.
  • Network emulation: a technique for testing the performance of real applications over a virtual network. This is different from network simulation where virtual models of traffic, network models, channels, and protocols are applied.
  • Server emulator: Multiplayer video games often rely on an online game server, which may or may not be available for on-premises installation. A server emulator is an unofficial on-premises server that imitates the behavior of the official online server, even though its internal working might be different.
  • Semulation: the process of controlling an emulation through a simulator

Structure and organization

This article's section named "Structure and organization" needs additional citations for verification. Please help improve this article by adding citations to reliable sources in this article's section named "Structure and organization". Unsourced material may be challenged and removed.
Find sources: "Emulator" – news · newspapers · books · scholar · JSTOR (June 2008) (Learn how and when to remove this message)

Typically, an emulator is divided into modules that correspond roughly to the emulated computer's subsystems. Most often, an emulator will be composed of the following modules:

  • a CPU emulator or CPU simulator (the two terms are mostly interchangeable in this case), unless the target being emulated has the same CPU architecture as the host, in which case a virtual machine layer may be used instead
  • a memory subsystem module
  • various input/output (I/O) device emulators

Buses are often not emulated, either for reasons of performance or simplicity, and virtual peripherals communicate directly with the CPU or the memory subsystem.

Memory subsystem

It is possible for the memory subsystem emulation to be reduced to simply an array of elements each sized like an emulated word; however, this model fails very quickly as soon as any location in the computer's logical memory does not match physical memory. This clearly is the case whenever the emulated hardware allows for advanced memory management (in which case, the MMU logic can be embedded in the memory emulator, made a module of its own, or sometimes integrated into the CPU simulator). Even if the emulated computer does not feature an MMU, though, there are usually other factors that break the equivalence between logical and physical memory: many (if not most) architectures offer memory-mapped I/O; even those that do not often have a block of logical memory mapped to ROM, which means that the memory-array module must be discarded if the read-only nature of ROM is to be emulated. Features such as bank switching or segmentation may also complicate memory emulation. As a result, most emulators implement at least two procedures for writing to and reading from logical memory, and it is these procedures' duty to map every access to the correct location of the correct object.

On a base-limit addressing system where memory from address 0 to address ROMSIZE-1 is read-only memory, while the rest is RAM, something along the line of the following procedures would be typical:

void WriteMemory(word Address, word Value) {
    word RealAddress;
    RealAddress = Address + BaseRegister;
    if ((RealAddress < LimitRegister) &&
        (RealAddress > ROMSIZE)) {
        Memory = Value;
    } else {
        RaiseInterrupt(INT_SEGFAULT);
    }
}
word ReadMemory(word Address) {
    word RealAddress;
    RealAddress=Address+BaseRegister;
    if (RealAddress < LimitRegister) {
        return Memory;
    } else {
        RaiseInterrupt(INT_SEGFAULT);
        return NULL;
    }
}

CPU simulator

The CPU simulator is often the most complicated part of an emulator. Many emulators are written using "pre-packaged" CPU simulators, in order to concentrate on good and efficient emulation of a specific machine. The simplest form of a CPU simulator is an interpreter, which is a computer program that follows the execution flow of the emulated program code and, for every machine code instruction encountered, executes operations on the host processor that are semantically equivalent to the original instructions. This is made possible by assigning a variable to each register and flag of the simulated CPU. The logic of the simulated CPU can then more or less be directly translated into software algorithms, creating a software re-implementation that basically mirrors the original hardware implementation.

The following example illustrates how CPU simulation can be accomplished by an interpreter. In this case, interrupts are checked-for before every instruction executed, though this behavior is rare in real emulators for performance reasons (it is generally faster to use a subroutine to do the work of an interrupt).

void Execute(void) {
    if (Interrupt != INT_NONE) {
        SuperUser = TRUE;
        WriteMemory(++StackPointer, ProgramCounter);
        ProgramCounter = InterruptPointer;
    }
    switch (ReadMemory(ProgramCounter++)) {
        /*
         * Handling of every valid instruction
         * goes here...
         */
        default:
        Interrupt = INT_ILLEGAL;
    }
}

Interpreters are very popular as computer simulators, as they are much simpler to implement than more time-efficient alternative solutions, and their speed is more than adequate for emulating computers of more than roughly a decade ago on modern machines. However, the speed penalty inherent in interpretation can be a problem when emulating computers whose processor speed is on the same order of magnitude as the host machine. Until not many years ago, emulation in such situations was considered completely impractical by many.

What allowed breaking through this restriction were the advances in dynamic recompilation techniques. Simple a priori translation of emulated program code into code runnable on the host architecture is usually impossible because of several reasons:

  • code may be modified while in RAM, even if it is modified only by the emulated operating system when loading the code (for example from disk)
  • there may not be a way to reliably distinguish data (which should not be translated) from executable code.

Various forms of dynamic recompilation, including the popular Just In Time compiler (JIT) technique, try to circumvent these problems by waiting until the processor control flow jumps into a location containing untranslated code, and only then ("just in time") translates a block of the code into host code that can be executed. The translated code is kept in a code cache, and the original code is not lost or affected; this way, even data segments can be (meaninglessly) translated by the recompiler, resulting in no more than a waste of translation time. Speed may not be desirable as some older games were not designed with the speed of faster computers in mind. A game designed for a 30 MHz PC with a level timer of 300 game seconds might only give the player 30 seconds on a 300 MHz PC. Other programs, such as some DOS programs, may not even run on faster computers. Particularly when emulating computers which were "closed-box", in which changes to the core of the system were not typical, software may use techniques that depend on specific characteristics of the computer it ran on (e.g. its CPU's speed) and thus precise control of the speed of emulation is important for such applications to be properly emulated.

Input/output (I/O)

Most emulators do not, as mentioned earlier, emulate the main system bus; each I/O device is thus often treated as a special case, and no consistent interface for virtual peripherals is provided. This can result in a performance advantage, since each I/O module can be tailored to the characteristics of the emulated device; designs based on a standard, unified I/O API can, however, rival such simpler models, if well thought-out, and they have the additional advantage of "automatically" providing a plug-in service through which third-party virtual devices can be used within the emulator. A unified I/O API may not necessarily mirror the structure of the real hardware bus: bus design is limited by several electric constraints and a need for hardware concurrency management that can mostly be ignored in a software implementation.

Even in emulators that treat each device as a special case, there is usually a common basic infrastructure for:

  • managing interrupts, by means of a procedure that sets flags readable by the CPU simulator whenever an interrupt is raised, allowing the virtual CPU to "poll for (virtual) interrupts"
  • writing to and reading from physical memory, by means of two procedures similar to the ones dealing with logical memory (although, contrary to the latter, the former can often be left out, and direct references to the memory array be employed instead)

Applications

In preservation

Emulation is one strategy in pursuit of digital preservation and combating obsolescence. Emulation focuses on recreating an original computer environment, which can be time-consuming and difficult to achieve, but valuable because of its ability to maintain a closer connection to the authenticity of the digital object, operating system, or even gaming platform. Emulation addresses the original hardware and software environment of the digital object, and recreates it on a current machine. The emulator allows the user to have access to any kind of application or operating system on a current platform, while the software runs as it did in its original environment. Jeffery Rothenberg, an early proponent of emulation as a digital preservation strategy states, "the ideal approach would provide a single extensible, long-term solution that can be designed once and for all and applied uniformly, automatically, and in organized synchrony (for example, at every refresh cycle) to all types of documents and media". He further states that this should not only apply to out of date systems, but also be upwardly mobile to future unknown systems. Practically speaking, when a certain application is released in a new version, rather than address compatibility issues and migration for every digital object created in the previous version of that application, one could create an emulator for the application, allowing access to all of said digital objects.

In new media art

Because of its primary use of digital formats, new media art relies heavily on emulation as a preservation strategy. Artists such as Cory Arcangel specialize in resurrecting obsolete technologies in their artwork and recognize the importance of a decentralized and deinstitutionalized process for the preservation of digital culture. In many cases, the goal of emulation in new media art is to preserve a digital medium so that it can be saved indefinitely and reproduced without error, so that there is no reliance on hardware that ages and becomes obsolete. The paradox is that the emulation and the emulator have to be made to work on future computers.

In future systems design

Main article: Full system simulation

Emulation techniques are commonly used during the design and development of new systems. It eases the development process by providing the ability to detect, recreate and repair flaws in the design even before the system is actually built. It is particularly useful in the design of multi-core systems, where concurrency errors can be very difficult to detect and correct without the controlled environment provided by virtual hardware. This also allows the software development to take place before the hardware is ready, thus helping to validate design decisions and give a little more control.

Comparison with simulation

Main article: Computer simulation

The word "emulator" was coined in 1963 at IBM during development of the NPL (IBM System/360) product line, using a "new combination of software, microcode, and hardware". They discovered that simulation using additional instructions implemented in microcode and hardware, instead of software simulation using only standard instructions, to execute programs written for earlier IBM computers dramatically increased simulation speed. Earlier, IBM provided simulators for, e.g., the 650 on the 705. In addition to simulators, IBM had compatibility features on the 709 and 7090, for which it provided the IBM 709 computer with a program to run legacy programs written for the IBM 704 on the 709 and later on the IBM 7090. This program used the instructions added by the compatibility feature to trap instructions requiring special handling; all other 704 instructions ran the same on a 7090. The compatibility feature on the 1410 only required setting a console toggle switch, not a support program.

In 1963, when microcode was first used to speed up this simulation process, IBM engineers coined the term "emulator" to describe the concept. In the 2000s, it has become common to use the word "emulate" in the context of software. However, before 1980, "emulation" referred only to emulation with a hardware or microcode assist, while "simulation" referred to pure software emulation. For example, a computer specially built for running programs designed for another architecture is an emulator. In contrast, a simulator could be a program which runs on a PC, so that old Atari games can be simulated on it. Purists continue to insist on this distinction, but currently the term "emulation" often means the complete imitation of a machine executing binary code while "simulation" often refers to computer simulation, where a computer program is used to simulate an abstract model. Computer simulation is used in virtually every scientific and engineering domain and Computer Science is no exception, with several projects simulating abstract models of computer systems, such as network simulation, which both practically and semantically differs from network emulation.

Comparison with hardware virtualization

Main article: Hardware virtualization

Hardware virtualization is the virtualization of computers as complete hardware platforms, certain logical abstractions of their components, or only the functionality required to run various operating systems. Virtualization hides the physical characteristics of a computing platform from the users, presenting instead an abstract computing platform. At its origins, the software that controlled virtualization was called a "control program", but the terms "hypervisor" or "virtual machine monitor" became preferred over time. Each hypervisor can manage or run multiple virtual machines.

See also

References

  1. Warick, Mike (April 1988). "MS-DOS Emulation For The 64". Compute!. p. 43. Retrieved 10 November 2013.
  2. GuideStorm. "PlayStation 4 Emulators". Retrieved 2019-08-04.
  3. Linux emulation removed from OpenBSD at version 6.0 https://www.openbsd.org/60.html
  4. Electronic design automation : synthesis, verification, and test. Laung-Terng Wang, Yao-Wen Chang, Kwang-Ting Cheng. Amsterdam: Morgan Kaufmann/Elsevier. 2009. ISBN 978-0-08-092200-3. OCLC 433173319.{{cite book}}: CS1 maint: others (link)
  5. "The Emulation Imitation". Malwarebytes Labs. 17 October 2014. Retrieved 2016-05-30.
  6. "Sony Computer Entertainment America v. Bleem, 214 F. 3d 1022". 9th Circuit 2000. Google Scholar. Court of Appeals (published 4 May 2000). 14 February 2000. Retrieved 15 June 2016.
  7. see Midway Manufacturing Co. v. Artic International, Inc., 574 F.Supp. 999, aff'd, 704 F.2d 1009 (9th Cir 1982) (holding the computer ROM of Pac Man to be a sufficient fixation for purposes of copyright law even though the game changes each time played.) and Article 2 of the Berne Convention
  8. "What is emulation?". Koninklijke Bibliotheek. Archived from the original on 2015-09-13. Retrieved 2007-12-11.
  9. van der Hoeven, Jeffrey, Bram Lohman, and Remco Verdegem. "Emulation for Digital Preservation in Practice: The Results." The International Journal of Digital Curation 2.2 (2007): 123-132.
  10. Muira, Gregory. " Pushing the Boundaries of Traditional Heritage Policy: maintaining long-term access to multimedia content." IFLA Journal 33 (2007): 323-326.
  11. Rothenberg, Jeffrey (1998). ""Criteria for an Ideal Solution." Avoiding Technological Quicksand: Finding a Viable Technical Foundation for Digital Preservation". Council on Library and Information Resources. Washington, DC. Retrieved 2008-03-08.
  12. Rothenberg, Jeffrey. "The Emulation Solution." Avoiding Technological Quicksand: Finding a Viable Technical Foundation for Digital Preservation. Washington, DC: Council on Library and Information Resources, 1998. Council on Library and Information Resources. 2008. 28 Mar. 2008 http://www.clir.org/pubs/reports/rothenberg/contents.html
  13. "Echoes of Art: Emulation as preservation strategy". Archived from the original on 2007-10-27. Retrieved 2007-12-11.
  14. Peter Magnusson (2004). "Full System Simulation: Software Development's Missing Link".
  15. "Debugging and Full System Simulation".
  16. Vania Joloboff (2009). "Full System Simulation of Embedded Systems" (PDF). Archived from the original (PDF) on 2014-02-09. Retrieved 2012-04-22.
  17. Pugh, Emerson W. (1995). Building IBM: Shaping an Industry and Its Technology. MIT. p. 274. ISBN 0-262-16147-8.
  18. Pugh, Emerson W.; et al. (1991). IBM's 360 and Early 370 Systems. MIT. ISBN 0-262-16123-0. pages 160-161
  19. Simulation of the IBM 650 on the IBM 705
  20. "IBM Archives: 7090 Data Processing System (continued)". www-03.ibm.com. 23 January 2003. Archived from the original on March 13, 2005.
  21. "System Compatibility Operations". Reference Manual IBM 7090 Data Processing System (PDF). March 1962. pp. 65–66. A22-6528-4.
  22. "System Compatibility Operations". IBM 1410 Principles of Operation (PDF). March 1962. pp. 56–57, 98–100. A22-0526-3.
  23. Tucker, S. G (1965). "Emulation of large systems". Communications of the ACM. 8 (12): 753–61. doi:10.1145/365691.365931. S2CID 15375675.
  24. "Network simulation or emulation?". Network World. 22 September 2017. Retrieved 22 September 2017.
  25. Turban, E; King, D.; Lee, J.; Viehland, D. (2008). "19". Electronic Commerce A Managerial Perspective (PDF) (5th ed.). Prentice-Hall. p. 27. Archived from the original (PDF) on 2009-05-21. Retrieved 2021-12-13.
  26. "Virtualization in education" (PDF). IBM. October 2007. Retrieved 6 July 2010.
  27. Creasy, R.J. (1981). "The Origin of the VM/370 Time-sharing System" (PDF). IBM. Retrieved 26 February 2013.

External links


Categories: