US20180065045A1 - Hand-held video game platform emulation - Google Patents
Hand-held video game platform emulation Download PDFInfo
- Publication number
- US20180065045A1 US20180065045A1 US15/807,395 US201715807395A US2018065045A1 US 20180065045 A1 US20180065045 A1 US 20180065045A1 US 201715807395 A US201715807395 A US 201715807395A US 2018065045 A1 US2018065045 A1 US 2018065045A1
- Authority
- US
- United States
- Prior art keywords
- game
- platform
- emulator
- memory
- video game
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- A63F13/10—
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/70—Game security or game management aspects
- A63F13/77—Game security or game management aspects involving data related to game devices or game servers, e.g. configuration data, software version or amount of memory
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/45—Controlling the progress of the video game
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/45—Controlling the progress of the video game
- A63F13/48—Starting a game, e.g. activating a game device or waiting for other players to join a multiplayer session
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/50—Controlling the output signals based on the game progress
- A63F13/52—Controlling the output signals based on the game progress involving aspects of the displayed game scene
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/50—Controlling the output signals based on the game progress
- A63F13/54—Controlling the output signals based on the game progress involving acoustic signals, e.g. for simulating revolutions per minute [RPM] dependent engine sounds in a driving game or reverberation against a virtual wall
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F13/00—Video games, i.e. games using an electronically generated display having two or more dimensions
- A63F13/90—Constructional details or arrangements of video game devices not provided for in groups A63F13/20 or A63F13/25, e.g. housing, wiring, connections or cabinets
- A63F13/92—Video game devices specially adapted to be hand-held while playing
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F2300/00—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
- A63F2300/20—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of the game platform
- A63F2300/203—Image generating hardware
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F2300/00—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
- A63F2300/20—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of the game platform
- A63F2300/204—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game characterised by details of the game platform the platform being a handheld device
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F2300/00—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
- A63F2300/60—Methods for processing data by generating or executing the game program
-
- A—HUMAN NECESSITIES
- A63—SPORTS; GAMES; AMUSEMENTS
- A63F—CARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
- A63F2300/00—Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
- A63F2300/60—Methods for processing data by generating or executing the game program
- A63F2300/6009—Methods for processing data by generating or executing the game program for importing or creating game content, e.g. authoring tools during game development, adapting content to different platforms, use of a scripting language to create content
- A63F2300/6018—Methods for processing data by generating or executing the game program for importing or creating game content, e.g. authoring tools during game development, adapting content to different platforms, use of a scripting language to create content where the game content is authored by the player, e.g. level editor or by game device at runtime, e.g. level is created from music data on CD
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N21/00—Selective content distribution, e.g. interactive television or video on demand [VOD]
- H04N21/40—Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
- H04N21/47—End-user applications
- H04N21/478—Supplemental services, e.g. displaying phone caller identification, shopping application
- H04N21/4781—Games
Definitions
- This invention relates to systems, methods, techniques, data structures, and other features for running software applications including but not limited to video games on platforms different from the ones the software is intended or designed to run on.
- Nintendo's GAME BOY®, GAME BOY COLOR® and GAME BOY ADVANCE® are examples of platforms having specialized hardware that is optimized for low cost, excellent performance and good graphics. These devices are not really general purpose computers; rather, they are special-purpose devices with specialized capabilities particularly adapted to video game play. These special capabilities provide low cost and exciting video game play action with good graphics and sound.
- GAME BOY® platforms are inexpensive and have long battery life, there may be situations in which it would be desirable to play or use applications developed for GAME BOY® on other platforms.
- an airline, train or other vehicle passenger might want to play video games during a long journey.
- FIG. 1B airlines are installing seat-back computer displays into the backs of airline seats.
- Such seat-back displays may provide a low cost personal computer including a processor, random access memory, liquid crystal display and input device(s).
- Similar displays could be installed in other vehicles (e.g., trains, ships, vans, cars, etc.) or in other contexts (e.g., at walk-up kiosks, within hotel rooms, etc.). It would be desirable under certain circumstances to allow users to execute all sorts of different applications including GAME BOY® video games and other applications using the general-purpose computer capabilities of such seat-back or similar display devices.
- PDA personal digital assistants
- Such devices now comprise an entire miniature computer within a package small enough to fit into your pocket.
- Mobile cellular telephones are also becoming increasingly computationally-intensive and have better displays so they can access the World Wide Web and perform a variety of downloaded applications.
- the special-purpose sound and graphics circuitry provided by the GAME BOY® platforms is not generally found in the various other platforms shown in FIGS. 1B, 1C and 1D . Providing these missing capabilities is one of the challenges to running a GAME BOY® video game (or other GAME BOY® application) on these other target platforms.
- Nintendo's GAME BOY® is based on an older, relatively inexpensive microprocessor (the Zilog Z80) that is no longer being used in most modern general purpose computer systems such as personal computers, seat-back displays and personal digital assistants.
- the Z80 instruction set (the language in which all GAME BOY® games and other GAME BOY® applications are written in) is not directly understood by the more modern Intel microprocessors (e.g., the 8086, 80286, 80386, Pentium and other processors in the Intel family) that are now widely used and found in most personal computers, seat-back displays, personal digital assistants, and the like.
- a software emulator is a computer program that executes on a desired target platform (e.g., a seat-back display device, a personal computer or a personal digital assistant shown in FIGS. 1B-1D ) and uses software to supply native platform capabilities that are missing from the target platform.
- a software emulator may perform some or all of GAME BOY®'s specialized graphics functions in software, and may interface with whatever graphics resources are available on the target platform to display resulting images.
- a software emulator may translate or interpret Z80 instructions so the microprocessor of the target platform can perform the functions that GAME BOY® would perform if presented with the same instructions.
- the software emulator may include software code that emulates hardware capabilities within the GAME BOY® circuitry (e.g., audio and/or graphics processing) and/or translate associated GAME BOY® application requests into requests that can be handled by the hardware resources available on the target platform.
- the target platform may include a graphics adapter and associated display that is incompatible with GAME BOY®'s graphics hardware but which can perform some of the basic graphics functions required to display GAME BOY® graphics on a display.
- GAME BOY® emulators have been written for a variety of different platforms ranging from personal digital assistants to personal computers. However, further improvements are possible and desirable.
- a low-capability platform e.g., a seat-back display or a personal digital assistant
- a low-capability platform may not have enough processing power to readily provide acceptable speed performance.
- the software emulator is carefully designed and carefully optimized, it will not be able to maintain real time speed performance when running on a slower or less highly capable processor. Slow-downs in game performance are generally unacceptable if the average user can notice them since they immediately affect and degrade the fun and excitement of the game playing experience.
- Performance problems are exacerbated by the penchant of some video game developers to squeeze the last bit of performance out of the GAME BOY® platform. Performance tricks and optimizations within a GAME BOY® application may place additional demands on any emulator running the application. Some prior art emulators provide acceptable results when running certain games but unacceptable results (or do not work at all) for other games. An ideal emulator provides acceptable results across a wide range of different games and other applications such that the emulator can run virtually any game or other application developed for the original platform.
- Another challenge to designing a good software emulator relates to maintaining excellent image and sound quality.
- the software emulator running on the target platform should be able to produce graphic displays that are at least the same quality as those that would be seen on the native platform. Additionally, the color rendition and other aspects of the image should be nearly if not exactly the same. Sounds (e.g., music and speech) from the emulator should have at least the same quality as would be heard on the original platform. All of these capabilities should be relatively closely matched even on platforms with radically different sound and graphics hardware capabilities.
- the present invention solves these and other problems by providing a unique software emulator capable of providing acceptable speed performance and good image and sound quality on even a low-capability target platform such as a seat back display for example.
- the preferred embodiment software emulator provided by this invention maintains high-quality graphics and sound in real time across a wide variety of video games and other applications—and nearly duplicates the graphics and sound that would be experienced by a user of the GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® platform running the same game or other application.
- the preferred embodiment emulator achieves this through a unique combination of features and optimizations including, for example:
- FIG. 1A shows someone playing a Nintendo GAME BOY® portable video game platform
- FIGS. 1B-1D show various different target platforms that could be used to emulate the FIG. 1 GAME BOY®;
- FIG. 2 is a block diagram of an example software emulator architecture
- FIG. 2A is a flow chart of example overall software emulator steps
- FIG. 3 is a block diagram of example functional models of the FIG. 2 emulator
- FIG. 4 is a block diagram of example emulator memory objects/data structures
- FIG. 5 shows an example emulated cartridge read only memory data structure
- FIG. 6 shows example compatibility modes
- FIG. 7 shows example registration data locations
- FIG. 8 shows an example virtual liquid crystal display controller state machine state diagram
- FIGS. 9A-9B show example virtual LCD controller emulation/control registers
- FIG. 9C shows example state machine cycle parameters
- FIG. 10 shows an example flow diagram of an emulated liquid crystal display controller
- FIG. 11 shows an example op code jump table
- FIG. 12 shows example emulation of a particular (NOP) instruction
- FIG. 13 shows an example page table
- FIG. 14 shows an example memory access operation
- FIG. 15 shows example read and write pointer tables
- FIG. 16 shows example virtual microprocessor registers
- FIG. 17 shows an example HL register write optimization
- FIG. 18 shows an example input controller emulation register set
- FIGS. 19A and 19B show example additional emulator control registers
- FIG. 20 shows an example graphics emulation optimization
- FIG. 21 shows an example native character data
- FIG. 22 shows example pre-rendered un-colorized “bit-map-ized” character tiles
- FIG. 23 shows example graphics object pointers
- FIG. 24 shows example emulated object attribute memory
- FIG. 25 shows an example video memory transfer process
- FIG. 26 shows example graphics mode selectors
- FIG. 27 shows example screen layouts
- FIG. 28 shows example VGA mode control parameters
- FIG. 29 shows example graphics engine register indices.
- FIG. 2 shows an example software emulator 100 provided by a preferred embodiment of the invention.
- Emulator 100 is designed to operate on a target platform of the type shown in FIG. 1B above, but could run on any desired platform including, for example, the target platforms shown in FIGS. 1C and 1D .
- the target platform includes:
- Emulator 100 (which executes on the target platform microprocessor and uses the resources of the target platform) receives the binary image of a game (or other application) file 66 stored on disk or other file system 52 ( FIG. 2A block 70 ). Emulator 100 parses and interprets this binary image ( FIG. 2A block 72 ). Emulator 100 also receives user inputs from handheld controller 56 via target platform keypad interface 54 ( FIG. 2A block 74 ). In response to these inputs, emulator 100 generates sound commands for the audio adapter 58 ( FIG. 2A block 76 ) and generates graphics commands for application to the video graphics adapter 62 ( FIG. 2A block 78 )—creating sounds on audio transducer 60 and images on display 64 . These sounds and images nearly duplicate what one would hear and see if running file 66 on a native GAME BOY® platform.
- the game file binary image 66 can be a video game or any other application that can run on a GAME BOY®, COLOR GAME BOY® or GAME BOY ADVANCE®.
- Binary image 66 includes binary audio commands and binary graphics commands, compatible with a GAME BOY® native platform but which are not compatible with the application programming interface features of audio interface 58 and VGA adapter 62 .
- Emulator 100 interprets those graphics commands and sound commands, and generates a corresponding sequence of graphics and sound commands that are understandable by and compatible with the audio and sound capabilities of the target platform.
- emulator 100 includes a virtual microprocessor core 102 .
- Virtual microprocessor core 102 interprets instructions within the binary game file 66 that would be executed by the actual GAME BOY® native platform (Z80) microprocessor ( FIG. 2A block 72 ), and provides a corresponding sequence of microprocessor instructions for execution by the target platform microprocessor (which in the general case, is different from the microprocessor found in GAME BOY® and does not understand and is incompatible with the native platform microprocessor instruction set).
- Virtual microprocessor core 102 receives inputs from a keypad emulation block 104 ( FIG. 2A block 74 ).
- Block 104 receives interactive inputs from the user via target platform keypad interface 54 .
- Keypad emulator block 104 emulates the GAME BOY® control input circuitry and associated functionality and translates inputs received from the target platform keypad interface—which may have a different set of control inputs and configurations from that found in a GAME BOY® native platform.
- Virtual microprocessor core 102 also communicates with sound emulation block 106 and graphics emulation block 108 .
- Sound emulation block 106 emulates or simulates the sound generation circuitry within a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® to provide a set of sound commands for application to the target platform sound adapter 58 ( FIG. 2A block 76 ).
- Graphics emulation block 108 emulates or simulates the hardware acceleration and other graphics circuitry found within a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® platform to provide a set of graphics commands for application to a target platform graphics adapter 62 ( FIG. 2A block 78 ).
- virtual microprocessor core 102 also includes a virtual liquid crystal display controller 103 used for the purpose of maintaining timing.
- Events within the GAME BOY®, GAME BOY COLOR®, and GAME BOY ADVANCE® native platforms are generally driven by activities relating to updating the liquid crystal display every one-sixtieth of a second.
- the example embodiment of emulator 100 emulates the native platform liquid crystal display controller ( FIG. 2A block 80 ) in order to synchronize events occurring within the emulator with emulated events that would occur within a GAME BOY®, GAME BOY COLOR®, and/or GAME BOY ADVANCE® native platform.
- the virtual liquid crystal display controller 103 of the example embodiment does not actually perform any display functions, but rather is used to tell emulator 100 what would be going on in terms of display timing on a real GAME BOY®, GAME BOY COLOR®, or GAME BOY ADVANCE R.
- a virtual liquid crystal display controller 103 allows emulator 100 to synchronize its pace with what the pace of a real GAME BOY®, GAME BOY COLOR®, and/or GAME BOY ADVANCE® native platform would be running the same application file 66 .
- Virtual liquid crystal display controller 103 may be viewed as a software-implemented model of the event timing sequence of a GAME BOY®, GAME BOY COLOR®, and/or GAME BOY ADVANCE® native platform.
- Emulator 100 also includes an emulated random access memory 110 , an emulated read only memory 112 , and an emulated memory bank controller (MBC) 114 .
- Emulated random access memory 110 and emulated read only memory 112 provide memory storage locations within the (read/write) random access memory 68 of the target platform.
- the emulated random access memory 110 emulates or simulates the random access memory of a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE®
- the emulated read only memory 112 emulates or simulates the read only memory within the game cartridge of a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® ( FIG. 2A block 82 ).
- the emulated memory bank controller 114 emulates or simulates the hardware memory bank controller (bank switching) circuitry found within certain a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® game cartridges.
- FIG. 2A shows example steps performed by emulator 100 .
- the emulator receives a binary game image (block 70 ) and activates any game-title-specific emulator options (block 71 ).
- the example emulator 100 parses and interprets the game binary image (block 72 ) and receives user inputs (block 74 ).
- the example emulator 100 generates sound commands (block 76 ) and graphics commands (block 78 ).
- the example emulator 100 emulates a native liquid crystal display controller (block 80 ) and native memory (block 82 ).
- FIG. 3 shows a breakdown of example illustrative functional modules used to implement the FIG. 2 emulator in software. These functional modules include:
- the example functional modules shown in FIG. 3 provide various functions that can be called by name from other parts of the emulator code.
- Each of these functional modules may be implemented with a C or C++ and/or assembler function or other routine in one example implementation.
- the entire executable file (the aggregate of all modules) is designed as a DOS protected mode application that runs with a minimum number of drivers to maximize efficiency.
- the run game functional module 120 loads the game file 66 into emulated ROM 112 and then calls the emulate functional module 122 ( FIG. 2A block 70 ).
- the run game module 120 may also by itself (or in conjunction with an additional function if desired) initialize each of the hardware-handler modules within the emulator 100 .
- Emulate functional module 122 is the main emulation loop and is executed until the user quits the game or other application.
- the draw functional modules 124 , 126 , 128 perform the task of drawing graphics objects generated by emulator 100 by sending graphics commands to the graphics adapter 62 ( FIG. 2A block 78 ).
- the draw_CGB functional module 124 may draw each of 144 color background lines of the COLOR GAME BOY® on the screen and may also by itself (or in conjunction with another module) draw the moving objects after the background has been drawn.
- the draw_DMG functional module 126 performs a similar drawing task for original GAME BOY® games and other applications
- the draw_AGB functional module 128 performs similar drawing tasks for GAME BOY ADVANCE® games and other applications.
- Example emulator 100 is capable of emulating any/all of a number of different platforms across the Nintendo GAME BOY® product line.
- the ROM check (“ROM REG”) functional module 130 is used to check (and/or display) registration data within the game file 66 .
- This functional module 130 is used to ensure, for example, proper authorization on the part of the user before game play is allowed.
- the ROM registration module does not do anything regarding user authorization, but just reads the ROM registration data in the game file, sets emulator variables and optionally displays the registration data on the screen.
- a game file validation function may be included in the ROM registration module to validate the game file, not the user.
- the video functional module 132 is used in the example to transfer character graphics data.
- the functions in the video module 132 perform character bitmap translation for any type of write to the character RAM area, whether it is a direct write from the CPU or a DMA transfer. Functions in the video module also handle the RAM bank switching register for character data areas, control and status registers for the LCD controller and palette registers for both CGB and DMG modes.
- video functional module 132 performs a character bit map translation into a portion of emulated RAM 110 to prepare graphics characters for display.
- the video functional module 132 may, by itself or in conjunction with another functional module, place appropriate function pointers into appropriate input/output read/write tables for all of the register handling functions that should be performed.
- the VGA functional module 134 is used to set the appropriate video mode of the target platform graphics adapter 62 .
- this VGA functional module 134 may be responsible for transferring full screens of graphics data to VGA graphics adapter 62 under certain circumstances (e.g., if a hardware-assisted bit BLIT operation is not available on the target platform).
- the buttons functional module 136 is responsible for getting the keypad data from keypad interface 54 and writing this data into a set of input interface registers that emulate actual hardware interface registers within GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE®.
- the sound functional module 138 in the example embodiment generates and writes appropriate sound information to the target platform sound adapter 58 by translating writes to the virtual sound registers to appropriate sound information for the target platform sound adapter ( FIG. 2A block 76 ).
- the sound functional module 138 by itself or in conjunction with another functional module, may also be used to put function pointers into appropriate input/output, read/write tables for all of the register handling functions performed by the sound functional module.
- the no write functional module 140 protects the emulated ROM 112 from being written to (thus making sure this memory segment is emulated as a read only memory as opposed to a read-write memory during game play).
- the no write functional module 140 by itself or in conjunction with an additional functional module, may place appropriate function pointers into the appropriate input/output read/write tables for all of the register handling functions in the no write functional module.
- the port mode functional module 142 emulates a CPU timer and provides a keypad handler. It has functions that handle the keypad, the timers, and the CPU speed control (e.g., to provide a CPU speed change operation since COLOR GAME BOY® operates twice as fast as GAME BOY® and GAME BOY ADVANCE operates still faster).
- the port mode functional module 142 may also set appropriate function pointers or call an additional function module(s) to perform this task.
- the main function of the CPU timer is to generate CPU interrupts at specified intervals. Registers to specify this interval are handled in the port/mode module. There are a couple of registers that provide real-time views of a free-running counter. These registers can be emulated by returning a random number.
- the CGB RAM functional module 144 emulates the COLOR GAME BOY® RAM to provide (additional) emulated RAM 110 .
- DMA functional module 146 performs direct memory access transfers between the various emulated storage resources within emulator 100 —thereby emulating the GAME BOY® native platform DMA controller.
- the MBC functional module 148 emulates the native platform memory bank controller to provide emulated MBC 114 .
- the SIO functional module 150 emulates a serial input/output port available on a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® platform (e.g., to provide a “game link” operation whereby plural platforms can exchange data over a cable or other communications interface).
- the ADDPTRS functional module 152 performs the task of registering various handlers for operation (in particular, it may contain a single function that all hardware support modules call to register their memory/function pointers in an I/O handler table, and accomplishes this by registering pointers for reading and writing to I/O addresses).
- the timer functional module 154 implements the virtual liquid crystal display controller 103 by maintaining an emulated state machine that keeps track of the state and associated timing information of a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® platform. Timer module 154 thus allows the target platform (which may operate at a completely different speed from the original platform) to maintain a sense of the event timing as those events would occur on the native platform—ensuring that emulator 100 provides event timings that are consistent with the native platform. Without such timing information, the speed of the application's graphics and/or sound might be different on the emulator 100 as compared to on the original platform—resulting in an unsatisfying game play experience.
- FIG. 4 is a block diagram of exemplary memory objects/data structures that emulator 100 maintains in the random access memory 68 of the target platform.
- these data structures emulate hardware resources of the native platform.
- these data structures do not correspond directly to any part of the native platform but instead provide support for optimized execution of emulator 100 .
- FIG. 4 shows the following exemplary data structures:
- the FIG. 4 data structures may be globally-defined memory arrays.
- the main RAM array 110 is, in one example, a generic 64K memory array used for any non-paged address space.
- a CGB buffer 175 is used to emulate the internal RAM banks for COLOR GAME BOY®.
- MBC RAM 172 is used to emulate the random access memory that may be provided within certain game cartridges.
- the object index array 174 may be used for sorting moving objects.
- the object enable array 176 may include a flag for each display line indicating that drawing of moving objects was enabled for that line (flags may be sent/queried as the background is drawn).
- Page table 178 may comprise a 64K table of pointers to the base pointers that handle each address, and may be used to reestablish the program counter on jumps, calls, returns, etc.
- Page table 178 may be used for making pointer adjustments to both the program counter and the stack pointer.
- a separate stack table comprising for example a 64K table can be used in a similar manner to page table 178 , but with a coverage of each base pointer extending one address higher and used to reestablish the base of the stack pointer when it is manually changed.
- the ROM pages 112 may be used to emulate the cartridge read only memory arrays (in the example embodiment, this ROM array is twice as big as the actual ROM pages since the bottom half is always duplicated).
- the raw character data array 162 is used to store raw character data
- the further character data array 164 is used to store corresponding “bit map-ized” character data.
- a translator 163 is used to provide precomputed translation data for translating the raw character data 162 into the bit mapped character data 164 .
- Different sets of pointers are used for each page and addressing mode in this example.
- the background data buffer 166 is used to store background data in pages 0 and 1.
- the off screen buffer 162 (which may comprise an entry of 192 ⁇ 160 ⁇ 2) may be used to compose images off screen. This buffer may not be needed when a bit BLIT capability is available within the hardware of the target platform.
- Color background palettes 184 a , 184 b comprise two sets of eight palettes, one for high priority background pixels and the other for low priority background pixels.
- Color object palette 184 c provides object palette data to emulate the COLOR GAME BOY® object color palette (one set of eight palettes may be provided).
- GAME BOY® color palettes 186 a , 186 b , 186 c emulate the monochrome GAME BOY® palettes, with background palette 186 a providing four background palette data entries and object palettes 186 b , 186 c comprising object palette data for object 0 and object 1 (four entries per palette).
- the native COLOR GAME BOY® platform has selectable palettes for “colorizing” monochrome GAME BOY® games—and this capability may also be emulated by, for example, changing the color entries within palettes 186 a , 186 b , 186 c . In another embodiment, these palettes 186 may be preassigned to provide certain default colors (e.g., red objects on a green background).
- Jump table 182 is used to facilitate the parsing and execution of target instructions by emulator 100 , as is explained below.
- FIG. 5 shows an example emulated cartridge ROM 112 .
- the cartridge ROM may have a number of banks up to a maximum.
- Preferred embodiment emulator 100 emulates each of these banks with a different RAM page 112 ( 1 ), 112 ( 2 ), 112 ( n ).
- the number of ROM pages to allocate can be determined dynamically based on the particular game or other application.
- the lower 16 K in each allocated ROM page 112 ( 1 ), . . . 112 ( n ) is duplicated to facilitate page selection and reduce page swapping.
- a ROM page selection pointer 202 is used to select the current ROM page, and a ROM page count register 204 specifies the number of ROM pages loaded for the current game or other application.
- the “no write” functional module 140 is used to protect the ROM space so that inadvertent write instructions within the application and/or emulator 100 do not succeed in overwriting emulated read only memory 112 .
- the run game routine 120 is responsible for loading the game (application) file 166 into emulated ROM 112 . Part of this loading operation loads particular compatibility information (see FIG. 6 ) and registration data (see FIG. 7 ) into the emulated ROM 112 .
- the FIG. 6 compatibility information is used to specify whether an application is compatible or incompatible with certain native platforms (e.g., compatibility with the COLOR GAME BOY® mode of emulator 100 , or whether it can run exclusively on the COLOR GAME BOY® mode).
- This compatibility information is present in a normal binary game file 166 to provide instructions to the COLOR GAME BOY® platform; emulator 100 reads and takes advantage of this information in determining its own emulation mode.
- emulator 100 performs checks similar to those performed by the GAME BOY®, COLOR GAME BOY® and GAME BOY ADVANCE® native platforms (as well as possibly other security checks such as digital signatures, decryption, digital certificates, etc.) to ensure the user has proper authorization.
- emulator 100 uses an internal state machine to keep track of and emulate the states of an actual GAME BOY®, COLOR GAME BOY® or GAME BOY ADVANCE® platform during emulation operation.
- the emulator 100 could execute the instructions within game file 66 without keeping track of corresponding events within the native platform, but this would lead to loss of real time synchronization.
- the pacing of the audio and video presentation is very important to the game play experience. Playing a game too fast or too slow will tend to destroy the fun of the game It is therefore desirable to emulate a game playing experience that is close to or nearly the same as the game playing experience one would have when running the application on the original native platform.
- Emulator 100 accomplishes this result by maintaining liquid crystal display controller 103 providing a sequential state machine that is synchronized with event states that would occur on the original native platform. Emulator 100 synchronizes its operation to the state transitions within this internal state machine to maintain real time synchronization of game play.
- FIG. 8 shows an example four-state virtual state machine state transition diagram that can be maintained by virtual LCD controller 103 . These states include:
- the sequential progression through all four states 250 - 256 comprises a frame that results in the display of a new image on display 64 .
- one frame comprises a vertical blanking state 256 and various repetitions of the hblank, OAM search and OAM transfer states 254 , 250 , 252 dependent on the number of lines (e.g., 144) within a frame.
- emulator 100 driven by an emulated state machine that models the same line scanning and other time intervals to ensure proper game timing as the developers of the game intended it and as a user would see and experience a game on the native platform.
- each line there is an hblank interval and associated state 254 , as well as an OAM search state 250 (during which a native platform would search its object attribute memory for objects to be displayed on the next line) and an OAM transfer state 252 (during which a native platform transfers object character information into a line buffer for display).
- OAM search state 250 (during which a native platform would search its object attribute memory for objects to be displayed on the next line)
- OAM transfer state 252 (during which a native platform transfers object character information into a line buffer for display).
- FIG. 9C shows example cycle parameters for the FIG. 8 virtual state machine.
- the preferred embodiment emulator 100 emulates a virtual state machine by maintaining the various registers shown in FIGS. 9A and 9B .
- the registers shown in FIG. 9A generally comprise various registers used to keep track of the virtual state and operation of a liquid crystal display controller that is being emulated.
- emulator 100 emulates a liquid crystal display controller using the following registers:
- FIG. 9B timing registers are used to maintain the various parameters pertaining to the timing parameters associated with the FIG. 8 virtual state machine. These registers include:
- FIG. 10 is a flow diagram of an example emulated liquid crystal display controller 103 .
- This flow diagram uses the various registers shown in FIGS. 9A and 9B to implement the FIG. 8 state machine.
- the FIG. 10 flow diagram has been simplified for purposes of illustration; additional operations may occur in an actual implementation.
- the virtual state machine is initialized with an initial state by updating an express or implied state counter (state may be explicitly stored in register 262 or it may be implied through inline code for efficiency purposes if desired) (block 302 ).
- the cycle counter register 286 is loaded with an appropriate number of cycles from the one of registers 274 , 276 , 278 , 280 corresponding to the current state of the state machine (block 304 , see FIGS.
- the effect of double-speed CPU operation is accomplished by loading the cycle counter with twice the number for each LCD controller phase than would be loaded for single-speed operation. So the cycle counter gets decremented at the same rate (which is determined by the speed of the host CPU), but the CPU can run through twice as many cycles per LCD phase in double-speed mode. Since the game speed is governed by throwing in an appropriate wait time once per frame in the example embodiment, the game speed is correct for both fast and slow modes, but in fast mode the CPU can do twice as much work.
- emulator 100 determines whether it is running behind (e.g., by determining the amount of time until the next timer interrupt is going to occur). Preferred embodiment emulator 100 tries to maintain the sixty frames-per-second screen update rate of the native platform. However, in one particular embodiment, it is not always possible (e.g., depending upon the particular game of other application being executed) to maintain a sixty frame-per-second rate on a slow target platform. In that example embodiment, emulator 100 dynamically scales back to a slower, thirty frame-per-second rate by setting the do-frame flag 292 (“yes” exit to decision block 314 , block 316 ) which will have the result of entirely skipping the drawing of the next frame.
- this frame-skipping operation does not skip execution of any instruction from game file 66 . All such instructions are executed by virtual microprocessor core 102 in order to continually maintain and update appropriate state information. Furthermore, this frame-skipping operation does not have the result, in the embodiment, of partially rendering the frame being skipped. For example, there is no selective execution of certain graphics commands in a command buffer depending on whether or not the emulator is falling behind. In that example embodiment of emulator 100 , the only operations that are skipped are internal emulator 100 operations of transferring graphic information to the VGA graphics adapter 62 and updating the display 64 —resulting in the frame either being rendered or not being rendered.
- the “dynamic-scaling” feature is omitted from the emulator 100 to allow better emulation of transparency-based images. It turns out there are some games that achieve transparency effects by enabling and disabling the visibility of entities on the screen at a 30 fps rate (on for one frame, off the next). Allowing the emulator to skip “as needed” between 30 fps and 60 fps causes undesirable flickering in such games.
- the emulator 100 may draw frames at either a fixed 30 fps (skip drawing of every other frame) or a fixed 45 fps (skip drawing of every third frame). Running at 30 fps causes the object to either always be visible or never be visible, depending on which phase you hit on.
- the 45 fps rate is currently used in certain games to make characters blink when they are hit by an enemy.
- Running at 45 fps (which provides acceptable game speed in certain games but not many other CGB games) allows you to alternate between visible and invisible and provides a good flickering character. If the emulator could draw at 60 fps, none of these problems would exist, but slow target hardware does not permit this.
- 30 fps provides good game play for most games. It is possible to modify a few bytes (the “game code”, which the emulator does not use) in the ROM registration area of the game file to tell the emulator what frame rate to use. There may be other game-specific emulation parameters put into the game file in the future.
- the virtual microprocessor core 102 interprets the binary instruction formats of game file 66 ( FIG. 2A block 72 ).
- the game file 66 binary instruction formats in the example embodiment are compiled for execution by a Z80 microprocessor of the native platform—whereas the target platform on which emulator 100 runs may be any microprocessor (e.g., an Intel 8086 family microprocessor).
- the virtual microprocessor core 102 may include a binary instruction format parser implemented as a jump table (e.g., C or C++ “case” statement) that parses the binary op code portion of the incoming instruction and jumps to appropriate code that performs one or a series of steps that will cause emulator 100 to emulate the operation of that instruction.
- FIG. 11 shows an example jump table flow based on the jump table 182 (which may be implemented as inline code if desired).
- FIG. 12 shows an example flow diagram for emulation of an example “no operation” (NOP) instruction.
- NOP no operation
- an op code of “00” parsed by the FIG. 11 process results in transferring control to the FIG. 12 process for emulating the “no operation” instruction.
- a “no operation” instruction results in nothing happening (wait) for a CPU cycle.
- certain tasks are performed in response to such a “no operation” instruction.
- an emulated program counter (which is different from the target platform program counter and is used to emulate the program counter of the native platform) is incremented (block 322 ), and the cycle counter is decremented (see block 306 , FIG. 10 ).
- the cycle counter is not greater than zero, a “timer” function is called to perform the steps of blocks 310 - 316 shown in FIG. 10 . If the cycle counter is still greater than zero, then control returns to the FIG. 11 operation to parse the next op code (block 324 ).
- emulator 100 may intelligently use events other than a wait loop (e.g., setting a timer and waiting for it to expire, or relying on the virtual liquid crystal display controller 103 ) as alternate means for providing the requisite “wait loop” timing.
- a wait loop e.g., setting a timer and waiting for it to expire, or relying on the virtual liquid crystal display controller 103
- FIG. 13 shows an example page table 178 within the context of a memory map that also includes emulated RAM 110 , 172 , 175 and emulated ROM 112 .
- This page table 178 is used in the example embodiment to process memory access commands within game file 66 .
- some memory access (read or write) commands can be executed by performing the requested read or write operation on a specified location within memory.
- page table 178 includes a memory pointer specifying a corresponding memory location—remapping various read/write locations into other locations as defined within the emulator 100 (see FIG. 14 , blocks 332 , 334 , 336 ).
- a read or write to a particular memory location will trigger the performance of a sequence of steps by emulator 100 .
- a read by the game file 66 of a game controller input register of the native platform may cause emulator 100 to execute a “key” function in order to poll the keypad interface 54 and get a user controller input value.
- the preferred embodiment page table 178 handles this situation by providing a zero-valued memory pointer within page table 178 ( FIG. 14 , block 334 ) that causes the emulator to reference an associated “key” function pointer—resulting in the calling of a “key” function ( FIG. 14 , block 338 ).
- page table 178 efficiently maps native instruction memory accesses to the same or different memory locations within emulated memory and/or to calling a function that emulates a result which would occur on the native platform in response to such a memory access command.
- the emulated random access memory 172 , 175 , 110 and the emulated read only memory 112 may include multiple copies of the same information within the target platform random access memory 68 in order to provide more efficient paging and corresponding reduction in processing time.
- FIG. 15 shows implementation detail for one detailed implementation of page table 178 .
- the page table may comprise two different tables 178 a , 178 b —one for read memory accesses and one for write memory accesses. Each of these tables may be 64 kilobytes (or other convenient size). All memory accesses by virtual microprocessor core 102 are performed via these tables 178 a , 178 b .
- the code that is reading or writing first looks to see if there is a non-null value in the “PTR” element for the desired address.
- the “PTR” element is a pointer to the pointer that defines the base of the target platform memory array that applies for the desired address.
- FIG. 16 shows example emulated registers within the virtual microprocessor core 102 .
- the native (e.g., Z80) microprocessor registers are emulated with random access memory values within the target platform RAM 68 and/or actual registers internal to the target platform CPU.
- it may be desirable to map certain emulated native microprocessor registers to target microprocessor registers for efficiency purposes e.g., to map a program counter 350 to a general purpose register within the target platform CPU).
- the program counter or program pointer 350 may include a current base pointer for the program counter as well as an offset portion.
- a stack pointer 352 may include a base pointer for an emulated stack pointer to which may be added an offset (e.g., in a target platform register).
- Virtual microprocessor core 102 may further include a set of emulated native platform flags 354 including:
- emulated flags 354 are not in the same bit positions as the native platform flags, but rather they are in positions used by the target platform processor. This allows emulator 100 to pass “virtual” flags to the target platform processor before performing operations that effect the flags. The target platform flags are retrieved into the virtual flag data structure 354 after the operation is performed.
- the various native platform general purpose registers are defined in three separate data structures as bytes (block 356 ), words (block 358 ) and long words (block 360 ).
- the three structures 356 , 358 , 360 are bundled into a union so that emulator 100 can access a particular register as a byte, a word or a long word as needed.
- the program pointer 350 is not included because it is maintained as a C character pointer for maximum efficiency.
- the program counter or pointer can be declared as a local variable in the main emulation function 122 , and the compiler preferably implements the program pointer 350 as a register in the target platform CPU as described above.
- the HL register within the native platform CPU is often used as an index register.
- FIG. 17 shows, it is possible for virtual microprocessor core 102 to “look ahead” by determining whether the indexed address is for a special hardware location in response to a write to the I-IL register (decision block 370 )—and to access page table 178 immediately in response to such an indexed address so that the corresponding memory pointer and/or function are available when a further instruction comes along that uses the HL register contents for an indexed operation (block 372 ). This optimization can save processing time.
- Indirect accesses via HL or any other 16-bit register are all handled by referring to the I/O read/write handler tables in the example embodiment.
- One “look-ahead” technique the preferred embodiment emulator uses is the “prefetch queue” implemented by always fetching four bytes into a 32-bit target platform register each time. The low-order byte is the opcode the emulator is after, but many opcodes require one or two subsequent bytes as data or extended opcode. By having four bytes in a register, any opcode handlers that need subsequent bytes already have them in a CPU register.
- the virtual microprocessor core 102 further includes a set of interrupt vectors and an interrupt master enable flag that are used to emulate the interrupt structure within a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® native platform.
- This interrupt vector (when enabled by the interrupt master enable flag) can be read to determine what portion of emulator 100 caused a particular interrupt (e.g., vblank, the liquid crystal display controller, a timer, button depression, or serial input/output).
- Emulator 100 provides an emulated interrupt controller that emulates the actual native platform interrupt structure in controller to maintain compatibility and event-driven functionality of game file 66 .
- preferred embodiment emulator 100 provides keypad emulation 104 in the example embodiment through the use of certain data registers/flags including:
- buttons direction register 380 and the buttons register 382 encode various button parameters in certain bit positions as shown in FIG. 18 .
- the buttons functional module 136 shown in FIG. 3 may be used to retrieve inputs from keypad interface 54 and load them into the FIG. 18 data structures for reading by virtual microprocessor core 102 . These data structures and associated functionality emulate the hardware control input controller of the native platform by duplicating the register interface of the native platform in software.
- Target platform controller device 56 may be any of a variety of different configurations including, for example, an SNES handheld controller, a keypad, or any other input device capable of interacting with a user.
- a “parallel port” register or indicator 388 may be used to define the type of keypad interface 54 (e.g., SNES controller adapter or keyboard) that will be used for the controller input on the target platform.
- FIGS. 19A and 19B show example additional virtual microprocessor data structures. These data structures are used to provide a variety of different additional functionality in the example embodiment of emulator 100 .
- preferred embodiment emulator 100 may include one or more game-specific emulation options that go into effect for particular games or other applications ( FIG. 2A block 71 ).
- an “options” data structure 402 may specify particular functions and/or features that could be activated selectively depending upon the particular application or game being supplied by game file 66 .
- Such game-specific emulation options can improve efficiency by tailoring the operation of emulator 100 for particular applications or games on a dynamic, as-needed basis. While in some embodiments it would be best to avoid using game-specific options, in other examples it might be desirable to use such game-specific options to increase efficiency and/or functionality.
- one game-specific option might be using a single CGB_RAM memory pointer.
- Another game-specific option is the 30/45 fps frame rate option described previously.
- Other game-specific options are possible.
- FIG. 19A also shows a “DMG only” flag 404 that is used in the example embodiment to indicate that the loaded game file 66 is COLOR GAME BOY® incompatible.
- This DMG only flag 404 (which is set or unset depending on the compatibility modes shown in FIG. 6 ) is used to determine whether COLOR GAME BOY® functionality of emulator 100 is enabled or disabled. It is also possible to provide a flag indicating that the stack pointer is allocated to a particular region of memory (e.g., fixed emulated COLOR GAME BOY® RAM). The flag that indicates that the stack pointer is pointing to a particular region of memory (fixed CGB RAM) is not a game-specific option in one example embodiment, and is set dynamically by the emulator 100 .
- a rumble pack flag 406 is used in the example embodiment to indicate whether the loaded game file 66 supports the rumble pack feature of certain native platform games.
- the TSR interrupt register 408 in the example embodiment specifies the number of the DOS interrupt used for host-to-emulator communication.
- a DMA source register 410 specifies a source address for emulated direct memory access operations
- a DMA destination register 412 specifies a destination address for emulated direct memory access operations
- a memory base pointer 414 specifies a base pointer for non-paged memory 110 .
- register file including for example, various native platform registers emulated in software (RAM locations) is shown.
- registers include, for example, sound control registers (“NR 10 -NR 52 ), a liquid crystal display controller register having the bit assignments shown, and a status register STAT having the bit assignments shown.
- certain information written to the sound control registers may be straight-forwardly translated and passed on to the target platform sound adapter 58 using the particular API used by that sound adapter.
- Other sound generation commands are peculiar to the GAME BOY®, GAME BOY COLOR® and GAME BOY ADVANCE® native platforms, and need to be emulated using sound-producing functions.
- These sound-producing functions take advantage, as much as possible, of the target platform sound generation capabilities, but typically need to provide additional state information (e.g., implementation of a sound-generation state machine) in order to ensure sound timing synchronization. Maintaining real time sound timing sound synchronization is especially important with voices—which will sound unnatural if played back too fast or too slow.
- the sound module translates writes to the virtual sound registers to appropriate sound information for the target platform sound adapter. If the sound library used does not provide for automatic termination of sounds after specified durations, then the emulator 100 may also be provided with the capability to terminate sounds at appropriate times.
- a graphics emulation 108 portion of emulator 100 in the example embodiment receives commands from the virtual microprocessor core 102 and performs responsive graphics tasks.
- This graphics emulation functionality performed by block 108 supplies capabilities normally supplied by the graphics acceleration hardware of the native platform.
- FIG. 20 shows an example of how the efficiency of preferred embodiment emulator 100 is enhanced by handling character data differently than the way it is handled in the native platform.
- a pre-computed translation table 163 is used to translate “raw” character data within an array 162 into a “bit mapped-ized” character data format for storage into buffer 164 .
- FIGS. 21 and 22 further illustrate this feature.
- the FIG. 21 representation shows a portion of the “raw” character data buffer 162 storing the character data bit planes as they are typically maintained by the native platform.
- Pre-computed translator 163 translates this raw character data representation into a differently-ordered and organized, bit mapped character data representation more like the format found in a conventional bit map (.bmp) file. This character data reorganization is useful in minimizing processing time required to output character graphics data to the video adapter 62 .
- the FIG. 21 representation shows a portion of the “raw” character data buffer 162 storing the character data bit planes as they are typically maintained by the native platform.
- Pre-computed translator 163 translates this raw character data representation into a differently-ordered and organized, bit mapped character data representation more like
- FIG. 23 shows a number of example graphics object pointers used by graphics emulation block 108 , including:
- FIG. 24 shows an example illustration of a preferred embodiment emulated object attribute memory 173 .
- the native platform includes an object attribute memory that maintains pointer and other information relating to characters to be displayed on the next frame.
- Preferred example embodiment emulator 100 includes an emulated object attribute memory 173 including an array of up to 40 objects each including y (vertical position), x (horizontal position), character (identifier) and attribute field. The bit-encoding of the attribute field information is also shown in FIG. 24 .
- An OAM base pointer 476 is used to function as a pre-allocated pointer to the emulated object attribute memory object 173 .
- FIG. 25 shows an example video memory arrangement including an off screen memory buffer 168 and an on screen memory buffer 170 .
- the off screen memory buffer 168 is defined to be larger than the display size of the native platform.
- the display size of a GAME BOY® or COLOR GAME BOY® is 160 pixels by 144 pixels high.
- off screen memory buffer 168 is defined to be 192 pixels wide by 160 pixels high—leaving additional memory locations on all sides of the screen size buffer.
- a buffer zone of sixteen bytes or eight bytes is useful in improving efficiency.
- the use of screen memory buffers larger than screen size is an attempt to increase graphic drawing efficiency by eliminating clipping calculations and using the hardware BitBlt to transfer a subset of the memory buffer to displayed video memory.
- Emulator 100 may draw to one buffer until it is complete, then switch to the other buffer. On the target hardware's vertical retrace interrupt, the emulator 100 copies the last-completed buffer to the on-screen area via BitBlt. This works well when a way is provided to implement the vertical retrace interrupt. As mentioned above, the “buffer zone” in the memory buffer is used to eliminate clipping calculations.
- the example embodiment emulator 100 uses a hardware-assisted bit BLIT operation to copy the contents of the screen size buffer into on screen buffer 170 .
- a bit-BLIT hardware-assisted operator can increase transfer times without corresponding increases in overhead. If a bit BLIT operation is not available, then a conventional direct memory access or other memory transfer can be used instead.
- a STPC_TARGET register 478 is used to specify whether a bit BLIT engine of the target platform is available and can be used (if one is not available, then a conventional memory copy function can be used instead).
- FIG. 26 shows some example additional graphics mode selectors used by emulator 100 in the preferred embodiment, including:
- FIG. 27 shows an example screen layout of display 64 showing that the emulated display provided by on-screen buffer 170 may be smaller than the actual display area of display 64 .
- the graphics adapter 62 and associated display 64 may provide a resolution of 320 pixels by 200 pixels, whereas emulator 100 produces an emulated image of 160 pixels by 144 pixels.
- Emulator 100 uses only a subset of display 64 to display emulated images in order to preserve aspect ratio.
- FIG. 28 shows an example set of graphics adapter 62 control constants that may be set to the VGA graphics adapter in order to set the graphics adapter's mode for use with emulator 100 .
- Emulator 100 may be hard-coded to a particular graphics mode (320 ⁇ 200 ⁇ 16), an 8-bit color mode, or other mode available on the target hardware. If the 320 ⁇ 200 ⁇ 16 color mode (VESA mode 0x10E) works on a particular target platform, emulator 100 may use this mode exclusively—and there will be no need for different control constants for the VGA.
- FIG. 29 shows example graphics engine register indices and associated example values.
- a screen pitch of 384 may also be defined as a constant in the example embodiment.
- the handling of color palettes can lead to efficiency problems.
- graphics characters are represented in a color lookup table (CLUT) format (i.e., the graphics characters themselves include a reduced number of bits that are used to look up a color value in a color palette for display). See FIG. 21 .
- CLUT color lookup table
- the example COLOR GAME BOY® native platform can display 56 colors on the screen nominally (eight palettes of four colors each for background, and eight palettes of four colors each for object characters minus transparency). It would seem therefore that with only 56 simultaneous colors on the screen at any one time, it would be possible to use a 320 ⁇ 200 ⁇ 8-bit VGA mode (13H) which would provide 256 different colors on the screen at once (much more than 56 colors).
- emulator 100 in the preferred embodiment to map color information (4 bits) into 32,000 colors.
- the 16-bit color resolution makes it desirable for emulator 100 to write 16-bit color palette information into the video adapter 62 . This, in turn, necessitates a memory array of 16-bit numbers associated with the various color palettes.
- the color palettes (see FIG. 4 ) can be accessed on a character-by-character basis, using pointers to apply color information to the “bit map-ized” character data 164 before the data is written to the display buffer 168 .
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Physics & Mathematics (AREA)
- Acoustics & Sound (AREA)
- Business, Economics & Management (AREA)
- Computer Security & Cryptography (AREA)
- General Business, Economics & Management (AREA)
- Controls And Circuits For Display Device (AREA)
Abstract
A software emulator for emulating a handheld video game platform such as GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® on a low-capability target platform (e.g., a seat-back display for airline or train use, a personal digital assistant, a cell phone) uses a number of features and optimizations to provide high quality graphics and sound that nearly duplicates the game playing experience on the native platform. Some exemplary features include use of bit BLITing, graphics character reformatting, modeling of a native platform liquid crystal display controller using a sequential state machine, and selective skipping of frame display updates if the game play falls behind what would occur on the native platform.
Description
- This application is a division of U.S. patent application Ser. No. 14/312,190 filed Jun. 23, 2014; which is a continuation of U.S. patent application Ser. No. 13/439,770 filed Apr. 4, 2012, now U.S. Pat. No. 8,795,090; which is a continuation of U.S. patent application Ser. No. 10/690,818 filed Oct. 23, 2003, now U.S. Pat. No. 8,157,654; which is a division of U.S. patent application Ser. No. 09/723,322 filed Nov. 28, 2000, now U.S. Pat. No. 6,672,963; which claims benefit of U.S. Provisional Patent Application No. 60/233,622 filed Sep. 18, 2000. Each of these applications is incorporated herein by reference.
- This invention relates to systems, methods, techniques, data structures, and other features for running software applications including but not limited to video games on platforms different from the ones the software is intended or designed to run on.
- Nintendo's GAME BOY® hand-held video game platforms have been extraordinarily successful. Nintendo released the first GAME BOY® in the late 1980s. Since then, this product and its successors (GAME BOY COLOR® and GAME BOY ADVANCE®) have captured the imaginations of millions of video game players throughout the world.
- A wide number of different software applications (including but not limited to video games) have been designed to run on these platforms. People throughout the world enjoy these applications every day. One can see them being used on subways, at sports arenas, after school, and in a number of other contexts. See
FIG. 1A . - Nintendo's GAME BOY®, GAME BOY COLOR® and GAME BOY ADVANCE® are examples of platforms having specialized hardware that is optimized for low cost, excellent performance and good graphics. These devices are not really general purpose computers; rather, they are special-purpose devices with specialized capabilities particularly adapted to video game play. These special capabilities provide low cost and exciting video game play action with good graphics and sound.
- While GAME BOY® platforms are inexpensive and have long battery life, there may be situations in which it would be desirable to play or use applications developed for GAME BOY® on other platforms. For example, an airline, train or other vehicle passenger might want to play video games during a long journey. As shown in
FIG. 1B , airlines are installing seat-back computer displays into the backs of airline seats. Such seat-back displays may provide a low cost personal computer including a processor, random access memory, liquid crystal display and input device(s). Similar displays could be installed in other vehicles (e.g., trains, ships, vans, cars, etc.) or in other contexts (e.g., at walk-up kiosks, within hotel rooms, etc.). It would be desirable under certain circumstances to allow users to execute all sorts of different applications including GAME BOY® video games and other applications using the general-purpose computer capabilities of such seat-back or similar display devices. - Personal computers have also proliferated throughout the world and are now available at relatively low cost. A trend has shifted some entertainment from the home television set to the home personal computer, where children and adults can view interesting web pages and play downloaded video games and other applications. In some circumstances, it may be desirable to allow users to play GAME BOY® video games on their home personal computers (see
FIG. 1C ). - A wide variety of so-called personal digital assistants (PDA's) have become available in recent years. Such devices now comprise an entire miniature computer within a package small enough to fit into your pocket. Mobile cellular telephones are also becoming increasingly computationally-intensive and have better displays so they can access the World Wide Web and perform a variety of downloaded applications. In some circumstances, it may be desirable to enable people to play GAME BOY® video games and other GAME BOY® applications on a personal digital assistant, cellular telephone or other such device (see
FIG. 1D ). - The special-purpose sound and graphics circuitry provided by the GAME BOY® platforms is not generally found in the various other platforms shown in
FIGS. 1B, 1C and 1D . Providing these missing capabilities is one of the challenges to running a GAME BOY® video game (or other GAME BOY® application) on these other target platforms. - Another challenge relates to instruction set compatibility. Nintendo's GAME BOY® is based on an older, relatively inexpensive microprocessor (the Zilog Z80) that is no longer being used in most modern general purpose computer systems such as personal computers, seat-back displays and personal digital assistants. The Z80 instruction set (the language in which all GAME BOY® games and other GAME BOY® applications are written in) is not directly understood by the more modern Intel microprocessors (e.g., the 8086, 80286, 80386, Pentium and other processors in the Intel family) that are now widely used and found in most personal computers, seat-back displays, personal digital assistants, and the like. While it is possible to “port” certain GAME BOY® games or other applications to different microprocessor families (e.g., by cross-compiling the source code to a different target microprocessor), there may be an advantage in certain contexts to being able to play or execute the same binary images stored in GAME BOY® cartridges on target platforms other than GAME BOY®.
- One way to provide a cross-platform capability is to provide a GAME BOY® software emulator on the target platform. Generally, a software emulator is a computer program that executes on a desired target platform (e.g., a seat-back display device, a personal computer or a personal digital assistant shown in
FIGS. 1B-1D ) and uses software to supply native platform capabilities that are missing from the target platform. For example, a software emulator may perform some or all of GAME BOY®'s specialized graphics functions in software, and may interface with whatever graphics resources are available on the target platform to display resulting images. A software emulator may translate or interpret Z80 instructions so the microprocessor of the target platform can perform the functions that GAME BOY® would perform if presented with the same instructions. The software emulator may include software code that emulates hardware capabilities within the GAME BOY® circuitry (e.g., audio and/or graphics processing) and/or translate associated GAME BOY® application requests into requests that can be handled by the hardware resources available on the target platform. For example, the target platform may include a graphics adapter and associated display that is incompatible with GAME BOY®'s graphics hardware but which can perform some of the basic graphics functions required to display GAME BOY® graphics on a display. - A number of GAME BOY® emulators have been written for a variety of different platforms ranging from personal digital assistants to personal computers. However, further improvements are possible and desirable.
- One area of needed improvement relates to obtaining acceptable speed performance and high quality sound and graphics on a low-capability platform. A low-capability platform (e.g., a seat-back display or a personal digital assistant) may not have enough processing power to readily provide acceptable speed performance. Unless the software emulator is carefully designed and carefully optimized, it will not be able to maintain real time speed performance when running on a slower or less highly capable processor. Slow-downs in game performance are generally unacceptable if the average user can notice them since they immediately affect and degrade the fun and excitement of the game playing experience.
- Performance problems are exacerbated by the penchant of some video game developers to squeeze the last bit of performance out of the GAME BOY® platform. Performance tricks and optimizations within a GAME BOY® application may place additional demands on any emulator running the application. Some prior art emulators provide acceptable results when running certain games but unacceptable results (or do not work at all) for other games. An ideal emulator provides acceptable results across a wide range of different games and other applications such that the emulator can run virtually any game or other application developed for the original platform.
- Another challenge to designing a good software emulator relates to maintaining excellent image and sound quality. Ideally, the software emulator running on the target platform should be able to produce graphic displays that are at least the same quality as those that would be seen on the native platform. Additionally, the color rendition and other aspects of the image should be nearly if not exactly the same. Sounds (e.g., music and speech) from the emulator should have at least the same quality as would be heard on the original platform. All of these capabilities should be relatively closely matched even on platforms with radically different sound and graphics hardware capabilities.
- One prior attempt to develop a video game platform emulator is disclosed in U.S. Pat. No. 6,115,054 to Giles. That patent describes a general purpose computer based video game platform software emulator including an execution skipping feature that evaluates the ability of the general purpose computer to generate video frames fully synchronized with the target platform computer system. If the evaluation determines that the emulator is falling behind the target system, the emulator executes only a first subset of the graphics commands while skipping execution of a second subset of graphics commands so as to partially render the frame. For example, the patent discloses fully executing certain graphics commands while partially executing others (e.g., clipped drawing commands) to provide a partial rendering of the frame. One disadvantage to the approach described in the Giles patent is that partial rendering of a frame can lead to uncertain imaging results that will degrade the quality of the image being produced by the emulator.
- The present invention solves these and other problems by providing a unique software emulator capable of providing acceptable speed performance and good image and sound quality on even a low-capability target platform such as a seat back display for example.
- The preferred embodiment software emulator provided by this invention maintains high-quality graphics and sound in real time across a wide variety of video games and other applications—and nearly duplicates the graphics and sound that would be experienced by a user of the GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® platform running the same game or other application. The preferred embodiment emulator achieves this through a unique combination of features and optimizations including, for example:
-
- use of a virtual liquid crystal display controller (state machine) to maintain real time synchronization with events as they would occur on the native platform,
- use of a hardware-assisted bit BLIT memory transfer operation to efficiently transfer graphics information into video memory,
- pre-computed translation table for translating native platform graphics character formats into formats more compatible with standard graphics adapters,
- emulation of native platform color palette information to provide compatibility with games and other applications that change color palettes within a frame,
- emulation of major registers and other hardware-based memory structures within the native platform in RAM under software control,
- use of a jump table able to efficiently parse incoming binary instruction formats,
- use of a unique page table to control memory access by remapping memory access instructions into different memory locations and/or function calls,
- availability of a ROM protection function to eliminate ROM overwriting during emulated operations,
- responsive to video game compatibility modes and registration data,
- models native platform using state machine defining search, transfer, horizontal blank and vertical blank states,
- cycle counter to determine when a modeled state has expired and transition to a new state is desired,
- selective frame display update skipping while maintaining execution of all instructions to maintain state information while minimizing game play slowdowns,
- optional NOP loop look ahead feature to avoid wasting processing time in NOP loops,
- redundant emulated RAM and ROM storage to optimize execution efficiency,
- separate page tables for read and write operations,
- modeling of native microprocessor registers as a union of byte, word and long register formats,
- modeling native instruction CPU flags to allow efficient updating after operations are performed by target platform microprocessor,
- mapping emulated program counter into target platform microprocessor general purpose register,
- reads and writes via index register go through pointer tables to increase execution efficiency,
- adaptable input controller emulator to provide user inputs from a variety of different user input devices,
- emulated object attribute memory, and
- use of screen memory buffers larger than screen size to increase paging efficiency by eliminating clipping calculations and using the hardware BitBlt to transfer a subset of the memory buffer to displayed video memory.
- These and other features and advantages provided by the invention will be better and more completely understood by referring to the following detailed description of presently preferred embodiments in conjunction with the drawings, of which:
-
FIG. 1A shows someone playing a Nintendo GAME BOY® portable video game platform; -
FIGS. 1B-1D show various different target platforms that could be used to emulate theFIG. 1 GAME BOY®; -
FIG. 2 is a block diagram of an example software emulator architecture; -
FIG. 2A is a flow chart of example overall software emulator steps; -
FIG. 3 is a block diagram of example functional models of theFIG. 2 emulator; -
FIG. 4 is a block diagram of example emulator memory objects/data structures; -
FIG. 5 shows an example emulated cartridge read only memory data structure; -
FIG. 6 shows example compatibility modes; -
FIG. 7 shows example registration data locations; -
FIG. 8 shows an example virtual liquid crystal display controller state machine state diagram; -
FIGS. 9A-9B show example virtual LCD controller emulation/control registers; -
FIG. 9C shows example state machine cycle parameters; -
FIG. 10 shows an example flow diagram of an emulated liquid crystal display controller; -
FIG. 11 shows an example op code jump table; -
FIG. 12 shows example emulation of a particular (NOP) instruction; -
FIG. 13 shows an example page table; -
FIG. 14 shows an example memory access operation; -
FIG. 15 shows example read and write pointer tables; -
FIG. 16 shows example virtual microprocessor registers; -
FIG. 17 shows an example HL register write optimization; -
FIG. 18 shows an example input controller emulation register set; -
FIGS. 19A and 19B show example additional emulator control registers; -
FIG. 20 shows an example graphics emulation optimization; -
FIG. 21 shows an example native character data; -
FIG. 22 shows example pre-rendered un-colorized “bit-map-ized” character tiles; -
FIG. 23 shows example graphics object pointers; -
FIG. 24 shows example emulated object attribute memory; -
FIG. 25 shows an example video memory transfer process; -
FIG. 26 shows example graphics mode selectors; -
FIG. 27 shows example screen layouts; -
FIG. 28 shows example VGA mode control parameters; and -
FIG. 29 shows example graphics engine register indices. -
FIG. 2 shows anexample software emulator 100 provided by a preferred embodiment of the invention.Emulator 100 is designed to operate on a target platform of the type shown inFIG. 1B above, but could run on any desired platform including, for example, the target platforms shown inFIGS. 1C and 1D . - In the example embodiment, the target platform includes:
-
- a microprocessor (e.g., an Intel 386);
- a disk or
other file system 52; - a
keypad interface 54 coupled to ahandheld controller 56; - a sound blaster or other
audio interface card 58 coupled to a loud speaker or other sound transducer; and - a VGA or
other graphics adapter 62 that outputs video information to adisplay 64 such as a liquid crystal display screen or video monitor.
- Emulator 100 (which executes on the target platform microprocessor and uses the resources of the target platform) receives the binary image of a game (or other application)
file 66 stored on disk or other file system 52 (FIG. 2A block 70).Emulator 100 parses and interprets this binary image (FIG. 2A block 72).Emulator 100 also receives user inputs fromhandheld controller 56 via target platform keypad interface 54 (FIG. 2A block 74). In response to these inputs,emulator 100 generates sound commands for the audio adapter 58 (FIG. 2A block 76) and generates graphics commands for application to the video graphics adapter 62 (FIG. 2A block 78)—creating sounds onaudio transducer 60 and images ondisplay 64. These sounds and images nearly duplicate what one would hear and see if runningfile 66 on a native GAME BOY® platform. - In the example embodiment, the game file
binary image 66 can be a video game or any other application that can run on a GAME BOY®, COLOR GAME BOY® or GAME BOY ADVANCE®.Binary image 66 includes binary audio commands and binary graphics commands, compatible with a GAME BOY® native platform but which are not compatible with the application programming interface features ofaudio interface 58 andVGA adapter 62.Emulator 100 interprets those graphics commands and sound commands, and generates a corresponding sequence of graphics and sound commands that are understandable by and compatible with the audio and sound capabilities of the target platform. - In the example embodiment,
emulator 100 includes avirtual microprocessor core 102.Virtual microprocessor core 102 interprets instructions within thebinary game file 66 that would be executed by the actual GAME BOY® native platform (Z80) microprocessor (FIG. 2A block 72), and provides a corresponding sequence of microprocessor instructions for execution by the target platform microprocessor (which in the general case, is different from the microprocessor found in GAME BOY® and does not understand and is incompatible with the native platform microprocessor instruction set). -
Virtual microprocessor core 102 receives inputs from a keypad emulation block 104 (FIG. 2A block 74).Block 104 in turn, receives interactive inputs from the user via targetplatform keypad interface 54.Keypad emulator block 104 emulates the GAME BOY® control input circuitry and associated functionality and translates inputs received from the target platform keypad interface—which may have a different set of control inputs and configurations from that found in a GAME BOY® native platform. -
Virtual microprocessor core 102 also communicates withsound emulation block 106 andgraphics emulation block 108.Sound emulation block 106 emulates or simulates the sound generation circuitry within a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® to provide a set of sound commands for application to the target platform sound adapter 58 (FIG. 2A block 76).Graphics emulation block 108 emulates or simulates the hardware acceleration and other graphics circuitry found within a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® platform to provide a set of graphics commands for application to a target platform graphics adapter 62 (FIG. 2A block 78). - In the example embodiment,
virtual microprocessor core 102 also includes a virtual liquidcrystal display controller 103 used for the purpose of maintaining timing. Events within the GAME BOY®, GAME BOY COLOR®, and GAME BOY ADVANCE® native platforms are generally driven by activities relating to updating the liquid crystal display every one-sixtieth of a second. The example embodiment ofemulator 100 emulates the native platform liquid crystal display controller (FIG. 2A block 80) in order to synchronize events occurring within the emulator with emulated events that would occur within a GAME BOY®, GAME BOY COLOR®, and/or GAME BOY ADVANCE® native platform. As will be described below in detail, the virtual liquidcrystal display controller 103 of the example embodiment does not actually perform any display functions, but rather is used to tellemulator 100 what would be going on in terms of display timing on a real GAME BOY®, GAME BOY COLOR®, or GAME BOY ADVANCE R. A virtual liquidcrystal display controller 103 allowsemulator 100 to synchronize its pace with what the pace of a real GAME BOY®, GAME BOY COLOR®, and/or GAME BOY ADVANCE® native platform would be running thesame application file 66. Virtual liquidcrystal display controller 103 may be viewed as a software-implemented model of the event timing sequence of a GAME BOY®, GAME BOY COLOR®, and/or GAME BOY ADVANCE® native platform. -
Emulator 100 also includes an emulatedrandom access memory 110, an emulated read onlymemory 112, and an emulated memory bank controller (MBC) 114. Emulatedrandom access memory 110 and emulated read onlymemory 112 provide memory storage locations within the (read/write)random access memory 68 of the target platform. The emulatedrandom access memory 110 emulates or simulates the random access memory of a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE®, and the emulated read onlymemory 112 emulates or simulates the read only memory within the game cartridge of a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® (FIG. 2A block 82). The emulatedmemory bank controller 114 emulates or simulates the hardware memory bank controller (bank switching) circuitry found within certain a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® game cartridges. -
FIG. 2A shows example steps performed byemulator 100. The emulator receives a binary game image (block 70) and activates any game-title-specific emulator options (block 71). Theexample emulator 100 parses and interprets the game binary image (block 72) and receives user inputs (block 74). Theexample emulator 100 generates sound commands (block 76) and graphics commands (block 78). Theexample emulator 100 emulates a native liquid crystal display controller (block 80) and native memory (block 82). -
FIG. 3 shows a breakdown of example illustrative functional modules used to implement theFIG. 2 emulator in software. These functional modules include: -
-
run game module 120, - emulate
module 122, -
draw_CGB module 124, -
draw_DMG module 126, -
draw_AGB module 128, - ROM authentication check (“ROM REG”)
module 130, -
video module 132, -
VGA module 134, -
buttons module 136, -
sound module 138, - no
write module 140, -
port mode module 142, -
CGB RAM module 144, -
DMA module 146, -
MBC module 148, -
SIO module 150, -
ADDPTRS module 152, and -
timer module 154.
-
- The example functional modules shown in
FIG. 3 provide various functions that can be called by name from other parts of the emulator code. Each of these functional modules may be implemented with a C or C++ and/or assembler function or other routine in one example implementation. In this particular implementation, the entire executable file (the aggregate of all modules) is designed as a DOS protected mode application that runs with a minimum number of drivers to maximize efficiency. - The run game
functional module 120 loads thegame file 66 into emulatedROM 112 and then calls the emulate functional module 122 (FIG. 2A block 70). Therun game module 120 may also by itself (or in conjunction with an additional function if desired) initialize each of the hardware-handler modules within theemulator 100. Emulatefunctional module 122 is the main emulation loop and is executed until the user quits the game or other application. - In the example embodiment, the draw
functional modules emulator 100 by sending graphics commands to the graphics adapter 62 (FIG. 2A block 78). For example, the draw_CGBfunctional module 124 may draw each of 144 color background lines of the COLOR GAME BOY® on the screen and may also by itself (or in conjunction with another module) draw the moving objects after the background has been drawn. The draw_DMGfunctional module 126 performs a similar drawing task for original GAME BOY® games and other applications, and the draw_AGBfunctional module 128 performs similar drawing tasks for GAME BOY ADVANCE® games and other applications.Example emulator 100 is capable of emulating any/all of a number of different platforms across the Nintendo GAME BOY® product line. - In this example, the ROM check (“ROM REG”)
functional module 130 is used to check (and/or display) registration data within thegame file 66. Thisfunctional module 130 is used to ensure, for example, proper authorization on the part of the user before game play is allowed. In another embodiment, the ROM registration module does not do anything regarding user authorization, but just reads the ROM registration data in the game file, sets emulator variables and optionally displays the registration data on the screen. A game file validation function may be included in the ROM registration module to validate the game file, not the user. - The video
functional module 132 is used in the example to transfer character graphics data. The functions in thevideo module 132 perform character bitmap translation for any type of write to the character RAM area, whether it is a direct write from the CPU or a DMA transfer. Functions in the video module also handle the RAM bank switching register for character data areas, control and status registers for the LCD controller and palette registers for both CGB and DMG modes. When agame file 66 instruction calls for a direct memory access data transfer of character information into the GAME BOY® character RAM space, videofunctional module 132 performs a character bit map translation into a portion of emulatedRAM 110 to prepare graphics characters for display. The videofunctional module 132 may, by itself or in conjunction with another functional module, place appropriate function pointers into appropriate input/output read/write tables for all of the register handling functions that should be performed. - In the example embodiment, the VGA
functional module 134 is used to set the appropriate video mode of the targetplatform graphics adapter 62. In addition, this VGAfunctional module 134 may be responsible for transferring full screens of graphics data toVGA graphics adapter 62 under certain circumstances (e.g., if a hardware-assisted bit BLIT operation is not available on the target platform). - The buttons
functional module 136 is responsible for getting the keypad data fromkeypad interface 54 and writing this data into a set of input interface registers that emulate actual hardware interface registers within GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE®. - The sound
functional module 138 in the example embodiment generates and writes appropriate sound information to the targetplatform sound adapter 58 by translating writes to the virtual sound registers to appropriate sound information for the target platform sound adapter (FIG. 2A block 76). The soundfunctional module 138, by itself or in conjunction with another functional module, may also be used to put function pointers into appropriate input/output, read/write tables for all of the register handling functions performed by the sound functional module. - In this example module, the no write
functional module 140 protects the emulatedROM 112 from being written to (thus making sure this memory segment is emulated as a read only memory as opposed to a read-write memory during game play). The no writefunctional module 140, by itself or in conjunction with an additional functional module, may place appropriate function pointers into the appropriate input/output read/write tables for all of the register handling functions in the no write functional module. - The port mode
functional module 142 emulates a CPU timer and provides a keypad handler. It has functions that handle the keypad, the timers, and the CPU speed control (e.g., to provide a CPU speed change operation since COLOR GAME BOY® operates twice as fast as GAME BOY® and GAME BOY ADVANCE operates still faster). The port modefunctional module 142 may also set appropriate function pointers or call an additional function module(s) to perform this task. The main function of the CPU timer is to generate CPU interrupts at specified intervals. Registers to specify this interval are handled in the port/mode module. There are a couple of registers that provide real-time views of a free-running counter. These registers can be emulated by returning a random number. This is only a partial emulation (a random number is not a real time value). However, the most common use of these registers by games is to generate a random number by looking at a fast clock at an arbitrary point in time. It is therefore possible to completely satisfy such games by providing a random number as opposed to a real time clock indication. A more accurate emulation can be provided if a game requires the real-time view of the counter actually provided in the native hardware. - The CGB RAM
functional module 144 emulates the COLOR GAME BOY® RAM to provide (additional) emulatedRAM 110. DMAfunctional module 146 performs direct memory access transfers between the various emulated storage resources withinemulator 100—thereby emulating the GAME BOY® native platform DMA controller. The MBCfunctional module 148 emulates the native platform memory bank controller to provide emulatedMBC 114. - The SIO
functional module 150 emulates a serial input/output port available on a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® platform (e.g., to provide a “game link” operation whereby plural platforms can exchange data over a cable or other communications interface). The ADDPTRSfunctional module 152 performs the task of registering various handlers for operation (in particular, it may contain a single function that all hardware support modules call to register their memory/function pointers in an I/O handler table, and accomplishes this by registering pointers for reading and writing to I/O addresses). The timerfunctional module 154 implements the virtual liquidcrystal display controller 103 by maintaining an emulated state machine that keeps track of the state and associated timing information of a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® platform.Timer module 154 thus allows the target platform (which may operate at a completely different speed from the original platform) to maintain a sense of the event timing as those events would occur on the native platform—ensuring thatemulator 100 provides event timings that are consistent with the native platform. Without such timing information, the speed of the application's graphics and/or sound might be different on theemulator 100 as compared to on the original platform—resulting in an unsatisfying game play experience. -
FIG. 4 is a block diagram of exemplary memory objects/data structures that emulator 100 maintains in therandom access memory 68 of the target platform. In some cases, these data structures emulate hardware resources of the native platform. In other cases, these data structures do not correspond directly to any part of the native platform but instead provide support for optimized execution ofemulator 100. -
FIG. 4 shows the following exemplary data structures: -
- emulated “read only memory” 112,
- emulated
random access memory 110, - register table 160,
- raw
character data buffer 162, -
translator 163 - “bit-map-ized”
character data buffer 164, -
background data buffer 166, - off
screen display buffer 168, - on
screen display buffer 170, - memory bank switched (cartridge) RAM buffer 172,
- object
attribute memory buffer 173, - object
index data structure 174, -
CGB RAM buffer 175 - object enable
data structure 176, - page table 178,
- jump table 182,
- various color palettes including a high
priority background palette 184 a, a lowpriority background palette 184 b, and anobject color palette 184 c for emulating COLOR GAME BOY®, and - various monochrome color (gray scale) palettes for GAME BOY® monochrome game emulation, including a
background palette 186 a, anobject 0palette 186 b and anobject 1palette 186 c.
- The
FIG. 4 data structures may be globally-defined memory arrays. - The
main RAM array 110 is, in one example, a generic 64K memory array used for any non-paged address space. ACGB buffer 175 is used to emulate the internal RAM banks for COLOR GAME BOY®. MBC RAM 172 is used to emulate the random access memory that may be provided within certain game cartridges. - The
object index array 174 may be used for sorting moving objects. - The object enable
array 176 may include a flag for each display line indicating that drawing of moving objects was enabled for that line (flags may be sent/queried as the background is drawn). - Page table 178 may comprise a 64K table of pointers to the base pointers that handle each address, and may be used to reestablish the program counter on jumps, calls, returns, etc.
- Page table 178 may be used for making pointer adjustments to both the program counter and the stack pointer. In another embodiment, a separate stack table comprising for example a 64K table can be used in a similar manner to page table 178, but with a coverage of each base pointer extending one address higher and used to reestablish the base of the stack pointer when it is manually changed.
- The ROM pages 112 may be used to emulate the cartridge read only memory arrays (in the example embodiment, this ROM array is twice as big as the actual ROM pages since the bottom half is always duplicated).
- The raw
character data array 162 is used to store raw character data, and the furthercharacter data array 164 is used to store corresponding “bit map-ized” character data. Atranslator 163 is used to provide precomputed translation data for translating theraw character data 162 into the bit mappedcharacter data 164. Different sets of pointers are used for each page and addressing mode in this example. Thebackground data buffer 166 is used to store background data inpages - The off screen buffer 162 (which may comprise an entry of 192×160×2) may be used to compose images off screen. This buffer may not be needed when a bit BLIT capability is available within the hardware of the target platform.
-
Color background palettes Color object palette 184 c provides object palette data to emulate the COLOR GAME BOY® object color palette (one set of eight palettes may be provided). GAME BOY® color palettes background palette 186 a providing four background palette data entries and objectpalettes object 0 and object 1 (four entries per palette). The native COLOR GAME BOY® platform has selectable palettes for “colorizing” monochrome GAME BOY® games—and this capability may also be emulated by, for example, changing the color entries withinpalettes - Jump table 182 is used to facilitate the parsing and execution of target instructions by
emulator 100, as is explained below. -
FIG. 5 shows an example emulatedcartridge ROM 112. In the native platform, the cartridge ROM may have a number of banks up to a maximum.Preferred embodiment emulator 100 emulates each of these banks with a different RAM page 112(1), 112(2), 112(n). In one example embodiment, the number of pages that may be allocated can be fixed (e.g., to a maximum of n=256) to provide static allocation for a four-megabyte game. In another embodiment, the number of ROM pages to allocate can be determined dynamically based on the particular game or other application. - In the example embodiment, the lower 16K in each allocated ROM page 112(1), . . . 112(n) is duplicated to facilitate page selection and reduce page swapping. A ROM
page selection pointer 202 is used to select the current ROM page, and a ROMpage count register 204 specifies the number of ROM pages loaded for the current game or other application. As mentioned above, the “no write”functional module 140 is used to protect the ROM space so that inadvertent write instructions within the application and/oremulator 100 do not succeed in overwriting emulated read onlymemory 112. - As mentioned above, the
run game routine 120 is responsible for loading the game (application) file 166 into emulatedROM 112. Part of this loading operation loads particular compatibility information (seeFIG. 6 ) and registration data (seeFIG. 7 ) into the emulatedROM 112. TheFIG. 6 compatibility information is used to specify whether an application is compatible or incompatible with certain native platforms (e.g., compatibility with the COLOR GAME BOY® mode ofemulator 100, or whether it can run exclusively on the COLOR GAME BOY® mode). This compatibility information is present in a normalbinary game file 166 to provide instructions to the COLOR GAME BOY® platform;emulator 100 reads and takes advantage of this information in determining its own emulation mode. The registration data shown inFIG. 7 is used in the example embodiment to ensure thatgame file 66 is authorized and authentic, andemulator 100 performs checks similar to those performed by the GAME BOY®, COLOR GAME BOY® and GAME BOY ADVANCE® native platforms (as well as possibly other security checks such as digital signatures, decryption, digital certificates, etc.) to ensure the user has proper authorization. - In the example embodiment,
emulator 100 uses an internal state machine to keep track of and emulate the states of an actual GAME BOY®, COLOR GAME BOY® or GAME BOY ADVANCE® platform during emulation operation. Theemulator 100 could execute the instructions withingame file 66 without keeping track of corresponding events within the native platform, but this would lead to loss of real time synchronization. In video game play, the pacing of the audio and video presentation is very important to the game play experience. Playing a game too fast or too slow will tend to destroy the fun of the game It is therefore desirable to emulate a game playing experience that is close to or nearly the same as the game playing experience one would have when running the application on the original native platform. -
Emulator 100 accomplishes this result by maintaining liquidcrystal display controller 103 providing a sequential state machine that is synchronized with event states that would occur on the original native platform.Emulator 100 synchronizes its operation to the state transitions within this internal state machine to maintain real time synchronization of game play. -
FIG. 8 shows an example four-state virtual state machine state transition diagram that can be maintained byvirtual LCD controller 103. These states include: -
- an object attribute
memory search state 250, - a
memory transfer state 252, - a
horizontal blanking state 254, and - a vertical blanking
state 256.
Additional states (e.g., enable and disable) can also be provided.
- an object attribute
- In the example embodiment, the sequential progression through all four states 250-256 comprises a frame that results in the display of a new image on
display 64. In the native platform, one frame comprises a vertical blankingstate 256 and various repetitions of the hblank, OAM search and OAM transfer states 254, 250, 252 dependent on the number of lines (e.g., 144) within a frame. Because the native platform hardware is driven by line scanning operation of a liquid crystal display, so too is preferredembodiment emulator 100 driven by an emulated state machine that models the same line scanning and other time intervals to ensure proper game timing as the developers of the game intended it and as a user would see and experience a game on the native platform. - Within each line there is an hblank interval and associated
state 254, as well as an OAM search state 250 (during which a native platform would search its object attribute memory for objects to be displayed on the next line) and an OAM transfer state 252 (during which a native platform transfers object character information into a line buffer for display). The table ofFIG. 9C shows example cycle parameters for theFIG. 8 virtual state machine. - The
preferred embodiment emulator 100 emulates a virtual state machine by maintaining the various registers shown inFIGS. 9A and 9B . The registers shown inFIG. 9A generally comprise various registers used to keep track of the virtual state and operation of a liquid crystal display controller that is being emulated. In this example,emulator 100 emulates a liquid crystal display controller using the following registers: -
- LCD cycle counter 260 (maintains the number of CPU cycles remaining before a transition to the next liquid crystal display controller phase/state should occur),
- liquid crystal display mode register 262 (maintains the current phase/state of the liquid crystal display controller including the various states shown in
FIG. 8 as well as an additional disabled and re-enabled state), - a liquid crystal display background enabled flag 264 (indicates whether the background should be drawn),
- a liquid crystal display window enabled flag 266 (indicates whether the current display window is enabled),
- a liquid crystal display object enabled flag 268 (indicates that the drawing of moving objects is enabled),
- a liquid crystal display big object flag 270 (indicates that objects are sixteen lines high instead of eight),
- a last object draw line register 272 (indicates the last line at which a direct memory access to object attribute memory occurred).
- The
FIG. 9B timing registers are used to maintain the various parameters pertaining to the timing parameters associated with theFIG. 8 virtual state machine. These registers include: -
- a cycleshblank register 274 (specifying the number of virtual CPU cycles needed in the horizontal blanking period),
- a cyclesvblank register 276 (indicating the number of virtual CPU cycles needed in the vertical blanking period),
- a cycles OAM (search) register 278 (indicating the number of virtual CPU cycles needed in the OAM search period),
- a cycles transfer register 280 (indicating the number of virtual CPU cycles need in the liquid crystal display data transfer period),
- a cycles frame register 282 (indicating the number of virtual CPU cycles needed for an entire frame),
- a timer ticks register 284 (this comprises a master game timer and is incremented by interrupt every 1/60th of a second),
- a cycle counter 286 (this may be implemented by a local variable within the main emulation
functional module 122 and is used to keep track of the current number of cycles within the frame), - a timer target liquid crystal display counter flag 288 (this is a flag indicating when the
cycle counter 286reaches 0 in order to control the virtual liquid crystal display controller to transition to the next phase shown inFIG. 8 ), - a fast CPU flag 290 (a flag indicating that the emulated COLOR GAME BOY® CPU is running in double-speed mode),
- a do frame flag 292 (a flag indicating whether
emulator 100 should draw the current and/or next video frame or skip drawing it), - a timer cycle counter 294 (indicates the number of CPU cycles remaining before a timer interrupt should be asserted),
- a timer threshold register 296 (indicates the number of CPU cycles corresponding to the current timer interrupt period),
- a timer enable register 298 (a flag indicating that timer interrupts are enabled).
-
FIG. 10 is a flow diagram of an example emulated liquidcrystal display controller 103. This flow diagram uses the various registers shown inFIGS. 9A and 9B to implement theFIG. 8 state machine. TheFIG. 10 flow diagram has been simplified for purposes of illustration; additional operations may occur in an actual implementation. As shown inFIG. 10 , the virtual state machine is initialized with an initial state by updating an express or implied state counter (state may be explicitly stored inregister 262 or it may be implied through inline code for efficiency purposes if desired) (block 302). Then, thecycle counter register 286 is loaded with an appropriate number of cycles from the one ofregisters FIGS. 8 and 9C ). Thecycle counter 286 is continually decremented at the emulated CPU rate (block 306) (as determined, for example, by the fast CPU flag 290) in response to timer ticks 284. Thiscycle counter 286 is continually compared with zero (decision block 308) to determine whether the current state is over. When the cycle counter has been decremented to zero (the “=” exit to decision block 308), the emulatedLCD controller 103 transitions to the next state of the virtual state machine (seeFIG. 8 ) (block 310). In the example embodiment, the cycle counter register is decremented by a fixed amount for each CPU instruction emulated. The effect of double-speed CPU operation is accomplished by loading the cycle counter with twice the number for each LCD controller phase than would be loaded for single-speed operation. So the cycle counter gets decremented at the same rate (which is determined by the speed of the host CPU), but the CPU can run through twice as many cycles per LCD phase in double-speed mode. Since the game speed is governed by throwing in an appropriate wait time once per frame in the example embodiment, the game speed is correct for both fast and slow modes, but in fast mode the CPU can do twice as much work. - If the next state is vertical blanking (“yes” exit to decision block 312), then emulator 100 determines whether it is running behind (e.g., by determining the amount of time until the next timer interrupt is going to occur).
Preferred embodiment emulator 100 tries to maintain the sixty frames-per-second screen update rate of the native platform. However, in one particular embodiment, it is not always possible (e.g., depending upon the particular game of other application being executed) to maintain a sixty frame-per-second rate on a slow target platform. In that example embodiment,emulator 100 dynamically scales back to a slower, thirty frame-per-second rate by setting the do-frame flag 292 (“yes” exit to decision block 314, block 316) which will have the result of entirely skipping the drawing of the next frame. In that example embodiment, this frame-skipping operation does not skip execution of any instruction fromgame file 66. All such instructions are executed byvirtual microprocessor core 102 in order to continually maintain and update appropriate state information. Furthermore, this frame-skipping operation does not have the result, in the embodiment, of partially rendering the frame being skipped. For example, there is no selective execution of certain graphics commands in a command buffer depending on whether or not the emulator is falling behind. In that example embodiment ofemulator 100, the only operations that are skipped areinternal emulator 100 operations of transferring graphic information to theVGA graphics adapter 62 and updating thedisplay 64—resulting in the frame either being rendered or not being rendered. Since the GAME BOY platforms operate to render an entire new frame each 1/60th of a second “from scratch”, there is no need to partially render a frame for use in generating a next frame, and such a partial rendering would tend only to degrade speed performance and generate uncertain image results. A maximum of every other frame may be skipped in the example embodiment since using a frame update rate of less than 1/30th of a second would noticeably degrade image quality. - In a further embodiment, the “dynamic-scaling” feature is omitted from the
emulator 100 to allow better emulation of transparency-based images. It turns out there are some games that achieve transparency effects by enabling and disabling the visibility of entities on the screen at a 30 fps rate (on for one frame, off the next). Allowing the emulator to skip “as needed” between 30 fps and 60 fps causes undesirable flickering in such games. In this alternate configuration, theemulator 100 may draw frames at either a fixed 30 fps (skip drawing of every other frame) or a fixed 45 fps (skip drawing of every third frame). Running at 30 fps causes the object to either always be visible or never be visible, depending on which phase you hit on. This is less than perfect emulation, but actually is the best solution for at least some games. For example, the 45 fps rate is currently used in certain games to make characters blink when they are hit by an enemy. Running at 45 fps (which provides acceptable game speed in certain games but not many other CGB games) allows you to alternate between visible and invisible and provides a good flickering character. If the emulator could draw at 60 fps, none of these problems would exist, but slow target hardware does not permit this. Luckily, 30 fps provides good game play for most games. It is possible to modify a few bytes (the “game code”, which the emulator does not use) in the ROM registration area of the game file to tell the emulator what frame rate to use. There may be other game-specific emulation parameters put into the game file in the future. - In the example embodiment, the
virtual microprocessor core 102 interprets the binary instruction formats of game file 66 (FIG. 2A block 72). As mentioned above, thegame file 66 binary instruction formats in the example embodiment are compiled for execution by a Z80 microprocessor of the native platform—whereas the target platform on which emulator 100 runs may be any microprocessor (e.g., an Intel 8086 family microprocessor). In the example embodiment, thevirtual microprocessor core 102 may include a binary instruction format parser implemented as a jump table (e.g., C or C++ “case” statement) that parses the binary op code portion of the incoming instruction and jumps to appropriate code that performs one or a series of steps that will cause emulator 100 to emulate the operation of that instruction.FIG. 11 shows an example jump table flow based on the jump table 182 (which may be implemented as inline code if desired). - Those skilled in the art will understand that different native instructions can be emulated in different ways depending upon the particular instruction.
FIG. 12 shows an example flow diagram for emulation of an example “no operation” (NOP) instruction. In thisFIG. 12 example, an op code of “00” parsed by theFIG. 11 process results in transferring control to theFIG. 12 process for emulating the “no operation” instruction. On the native platform, a “no operation” instruction results in nothing happening (wait) for a CPU cycle. Withinemulator 100, in contrast, certain tasks are performed in response to such a “no operation” instruction. For example, an emulated program counter (which is different from the target platform program counter and is used to emulate the program counter of the native platform) is incremented (block 322), and the cycle counter is decremented (seeblock 306,FIG. 10 ). As shown inFIG. 10 , if the cycle counter is not greater than zero, a “timer” function is called to perform the steps of blocks 310-316 shown inFIG. 10 . If the cycle counter is still greater than zero, then control returns to theFIG. 11 operation to parse the next op code (block 324). - Some games and other applications make extensive use of “no operation” loops to maintain game timing. Somewhat surprisingly, such “no operation” loops can cause
emulator 100 to run very slowly. To avoid this particular issue, it is possible foremulator 100 to include a dynamic code analyzer that “looks ahead” to the next few instructions surrounding a “no op” instruction to determine whether thegame file 66 includes a “no op” loop. Ifemulator 100 determines that such a loop is present, then the emulator may intelligently use events other than a wait loop (e.g., setting a timer and waiting for it to expire, or relying on the virtual liquid crystal display controller 103) as alternate means for providing the requisite “wait loop” timing. This optimization can result in increased efficiency by preventing the emulator 100 from becoming bogged down with “no operation” wait loops. In other embodiments, no NOP-reduction analysis is implemented, and the only such technique implemented is to detect whether a loop was waiting for a transition of the LCD machine and automatically force the transition. The problem is that such a technique may work for some games, but could cause some games to malfunction. -
FIG. 13 shows an example page table 178 within the context of a memory map that also includes emulatedRAM ROM 112. This page table 178 is used in the example embodiment to process memory access commands withingame file 66. In this example embodiment, some memory access (read or write) commands can be executed by performing the requested read or write operation on a specified location within memory. In such cases, page table 178 includes a memory pointer specifying a corresponding memory location—remapping various read/write locations into other locations as defined within the emulator 100 (seeFIG. 14 , blocks 332, 334, 336). In some cases, a read or write to a particular memory location will trigger the performance of a sequence of steps byemulator 100. As an example, a read by thegame file 66 of a game controller input register of the native platform may cause emulator 100 to execute a “key” function in order to poll thekeypad interface 54 and get a user controller input value. The preferred embodiment page table 178 handles this situation by providing a zero-valued memory pointer within page table 178 (FIG. 14 , block 334) that causes the emulator to reference an associated “key” function pointer—resulting in the calling of a “key” function (FIG. 14 , block 338). In this way, page table 178 efficiently maps native instruction memory accesses to the same or different memory locations within emulated memory and/or to calling a function that emulates a result which would occur on the native platform in response to such a memory access command. - Also as shown in
FIG. 13 and alluded to above, the emulatedrandom access memory memory 112 may include multiple copies of the same information within the target platformrandom access memory 68 in order to provide more efficient paging and corresponding reduction in processing time. -
FIG. 15 shows implementation detail for one detailed implementation of page table 178. In this example, the page table may comprise two different tables 178 a, 178 b—one for read memory accesses and one for write memory accesses. Each of these tables may be 64 kilobytes (or other convenient size). All memory accesses byvirtual microprocessor core 102 are performed via these tables 178 a, 178 b. The code that is reading or writing first looks to see if there is a non-null value in the “PTR” element for the desired address. The “PTR” element is a pointer to the pointer that defines the base of the target platform memory array that applies for the desired address. If there is a non-null “PTR” value, de-referencing “PTR” and adding the desired address will get emulator 100 to the target platform address to read/write. If, on the other hand, the “PTR” value is null, that means that there is a handler function defined for reading/writing to the desired address. The handler function can be called via the “FUNCT” element of the appropriate table. - Different functions can be called for reading from and writing to the same address in this example arrangement, and different pointers may be used reading from and writing to the same address. Similarly, a read operation with respect to a particular native address may cause a read from an active “PTR” memory mapped value whereas a write operation to the same address can invoke a handler function—or vice versa. The flexibility provided by this arrangement simplifies the architecture of
emulator 100 while providing an efficient way to execute instructions fromgame file 66. -
FIG. 16 shows example emulated registers within thevirtual microprocessor core 102. In this example, the native (e.g., Z80) microprocessor registers are emulated with random access memory values within thetarget platform RAM 68 and/or actual registers internal to the target platform CPU. For example, it may be desirable to map certain emulated native microprocessor registers to target microprocessor registers for efficiency purposes (e.g., to map aprogram counter 350 to a general purpose register within the target platform CPU). - In the example embodiment, the program counter or
program pointer 350 may include a current base pointer for the program counter as well as an offset portion. Similarly, astack pointer 352 may include a base pointer for an emulated stack pointer to which may be added an offset (e.g., in a target platform register).Virtual microprocessor core 102 may further include a set of emulated native platform flags 354 including: -
- a
carry flag 354 a, - a half-
carry flag 354 b, - an
add sub flag 354 c, - a zero
flag 354 d.
- a
- In the example embodiment, emulated
flags 354 are not in the same bit positions as the native platform flags, but rather they are in positions used by the target platform processor. This allowsemulator 100 to pass “virtual” flags to the target platform processor before performing operations that effect the flags. The target platform flags are retrieved into the virtualflag data structure 354 after the operation is performed. - In the example embodiment, the various native platform general purpose registers are defined in three separate data structures as bytes (block 356), words (block 358) and long words (block 360). The three
structures emulator 100 can access a particular register as a byte, a word or a long word as needed. In the example embodiment, theprogram pointer 350 is not included because it is maintained as a C character pointer for maximum efficiency. The program counter or pointer can be declared as a local variable in themain emulation function 122, and the compiler preferably implements theprogram pointer 350 as a register in the target platform CPU as described above. - Some additional optimizations are possible when accessing the emulated registers shown in
FIG. 16 . For example, the HL register within the native platform CPU is often used as an index register. AsFIG. 17 shows, it is possible forvirtual microprocessor core 102 to “look ahead” by determining whether the indexed address is for a special hardware location in response to a write to the I-IL register (decision block 370)—and to access page table 178 immediately in response to such an indexed address so that the corresponding memory pointer and/or function are available when a further instruction comes along that uses the HL register contents for an indexed operation (block 372). This optimization can save processing time. Indirect accesses via HL or any other 16-bit register (BC or DE) are all handled by referring to the I/O read/write handler tables in the example embodiment. One “look-ahead” technique the preferred embodiment emulator uses is the “prefetch queue” implemented by always fetching four bytes into a 32-bit target platform register each time. The low-order byte is the opcode the emulator is after, but many opcodes require one or two subsequent bytes as data or extended opcode. By having four bytes in a register, any opcode handlers that need subsequent bytes already have them in a CPU register. - Referring once again to
FIG. 16 , thevirtual microprocessor core 102 further includes a set of interrupt vectors and an interrupt master enable flag that are used to emulate the interrupt structure within a GAME BOY®, GAME BOY COLOR® and/or GAME BOY ADVANCE® native platform. This interrupt vector (when enabled by the interrupt master enable flag) can be read to determine what portion ofemulator 100 caused a particular interrupt (e.g., vblank, the liquid crystal display controller, a timer, button depression, or serial input/output).Emulator 100 provides an emulated interrupt controller that emulates the actual native platform interrupt structure in controller to maintain compatibility and event-driven functionality ofgame file 66. - As shown in
FIG. 18 ,preferred embodiment emulator 100 provideskeypad emulation 104 in the example embodiment through the use of certain data registers/flags including: -
- a buttons direction register 380 that maintains the data for emulated direction keys,
- a buttons register 382 that maintains the data for the emulated control buttons, and
- a buttons changed
flag 384 that indicates that the button data has been changed.
- In one example embodiment, the buttons direction register 380 and the buttons register 382 encode various button parameters in certain bit positions as shown in
FIG. 18 . As mentioned above, the buttonsfunctional module 136 shown inFIG. 3 may be used to retrieve inputs fromkeypad interface 54 and load them into theFIG. 18 data structures for reading byvirtual microprocessor core 102. These data structures and associated functionality emulate the hardware control input controller of the native platform by duplicating the register interface of the native platform in software. Targetplatform controller device 56 may be any of a variety of different configurations including, for example, an SNES handheld controller, a keypad, or any other input device capable of interacting with a user. A “parallel port” register or indicator 388 may be used to define the type of keypad interface 54 (e.g., SNES controller adapter or keyboard) that will be used for the controller input on the target platform. -
FIGS. 19A and 19B show example additional virtual microprocessor data structures. These data structures are used to provide a variety of different additional functionality in the example embodiment ofemulator 100. - As shown in
FIG. 19A ,preferred embodiment emulator 100 may include one or more game-specific emulation options that go into effect for particular games or other applications (FIG. 2A block 71). As one example, an “options”data structure 402 may specify particular functions and/or features that could be activated selectively depending upon the particular application or game being supplied bygame file 66. Such game-specific emulation options can improve efficiency by tailoring the operation ofemulator 100 for particular applications or games on a dynamic, as-needed basis. While in some embodiments it would be best to avoid using game-specific options, in other examples it might be desirable to use such game-specific options to increase efficiency and/or functionality. - As shown in
FIG. 19A , one game-specific option might be using a single CGB_RAM memory pointer. Another game-specific option is the 30/45 fps frame rate option described previously. Other game-specific options are possible. -
FIG. 19A also shows a “DMG only”flag 404 that is used in the example embodiment to indicate that the loadedgame file 66 is COLOR GAME BOY® incompatible. This DMG only flag 404 (which is set or unset depending on the compatibility modes shown inFIG. 6 ) is used to determine whether COLOR GAME BOY® functionality ofemulator 100 is enabled or disabled. It is also possible to provide a flag indicating that the stack pointer is allocated to a particular region of memory (e.g., fixed emulated COLOR GAME BOY® RAM). The flag that indicates that the stack pointer is pointing to a particular region of memory (fixed CGB RAM) is not a game-specific option in one example embodiment, and is set dynamically by theemulator 100. - A
rumble pack flag 406 is used in the example embodiment to indicate whether the loadedgame file 66 supports the rumble pack feature of certain native platform games. - The TSR interrupt
register 408 in the example embodiment specifies the number of the DOS interrupt used for host-to-emulator communication. - A DMA source register 410 specifies a source address for emulated direct memory access operations, and a
DMA destination register 412 specifies a destination address for emulated direct memory access operations. Amemory base pointer 414 specifies a base pointer fornon-paged memory 110. - Referring to
FIG. 19B , a register file including for example, various native platform registers emulated in software (RAM locations) is shown. Such registers include, for example, sound control registers (“NR10-NR52), a liquid crystal display controller register having the bit assignments shown, and a status register STAT having the bit assignments shown. - In terms of sound emulation, certain information written to the sound control registers may be straight-forwardly translated and passed on to the target
platform sound adapter 58 using the particular API used by that sound adapter. Other sound generation commands are peculiar to the GAME BOY®, GAME BOY COLOR® and GAME BOY ADVANCE® native platforms, and need to be emulated using sound-producing functions. These sound-producing functions take advantage, as much as possible, of the target platform sound generation capabilities, but typically need to provide additional state information (e.g., implementation of a sound-generation state machine) in order to ensure sound timing synchronization. Maintaining real time sound timing sound synchronization is especially important with voices—which will sound unnatural if played back too fast or too slow. Unfortunately, voice reproduction may be difficult to achieve since the strict CPU timing necessary to play back voice takes up too much time in itself, and may not be possible to perform on a low-resource target platform. Games that rely on voice playback for a satisfactory game play experience may have to be excluded. In the example embodiment, the sound module translates writes to the virtual sound registers to appropriate sound information for the target platform sound adapter. If the sound library used does not provide for automatic termination of sounds after specified durations, then theemulator 100 may also be provided with the capability to terminate sounds at appropriate times. - As described above, a
graphics emulation 108 portion ofemulator 100 in the example embodiment receives commands from thevirtual microprocessor core 102 and performs responsive graphics tasks. This graphics emulation functionality performed byblock 108 supplies capabilities normally supplied by the graphics acceleration hardware of the native platform. - One way to provide
such graphics emulation 108 would be to nearly exactly implement, in software, each of the hardware structures of the native platform's graphics circuitry. This is not necessarily the best approach, however, since it may be more efficient to perform certain graphics-related tasks differently in software.FIG. 20 shows an example of how the efficiency ofpreferred embodiment emulator 100 is enhanced by handling character data differently than the way it is handled in the native platform. - In the
FIG. 20 example, a pre-computed translation table 163 is used to translate “raw” character data within anarray 162 into a “bit mapped-ized” character data format for storage intobuffer 164.FIGS. 21 and 22 further illustrate this feature. TheFIG. 21 representation shows a portion of the “raw”character data buffer 162 storing the character data bit planes as they are typically maintained by the native platform.Pre-computed translator 163 translates this raw character data representation into a differently-ordered and organized, bit mapped character data representation more like the format found in a conventional bit map (.bmp) file. This character data reorganization is useful in minimizing processing time required to output character graphics data to thevideo adapter 62. TheFIG. 22 “bit mapped-ized” representation is more compatible with VGA and other commonly-used video adapter hardware, and the pre-computation oftranslator 163 allows this data reorganization to occur in a straight forward manner in advance of the time when the graphics data is sent to thegraphics adapter 62. -
FIG. 23 shows a number of example graphics object pointers used bygraphics emulation block 108, including: -
- window x, window y registers 450, 452 specifying the coordinates of the display window (these coordinates may be copied from the memory [wx], memory [ly] values at the top of each frame),
- a window source y register 454 specifying the y coordinate for the source data for a window (this may start at zero at the top of the window),
- a
background base pointer 456 that stores the base pointer for the current background RAM area (moves betweenbackground 1 andbackground 2, pages zero and one), - a background pointer bank zero and background pointer bank one
register background 1 andbackground 2 areas), - a window pointer bank zero register and a window pointer bank one
register 462, 464 (these registers specify base pointers for the current window RAM page zero and one respectively (they move between pages zero and one)), - a character
base pointer register 466 specifying the base pointer for the current character RAM area (moves between pages zero and one), - a character
RAM base pointer 467 specifying the base pointer for the current internal COLOR GAME BOY® RAM area 175 (0xC000-0xE000), - a character bit mapped
base pointer 468 specifying the base pointer for the “bit map-ized” character data 164 (this pointer moves between pages zero and one), - a memory bank controller
RAM base pointer 470 specifying the base pointer for the current cartridge RAM page 172, - a character bit map index bank zero pointer and a character bit map index bank one
pointer
-
FIG. 24 shows an example illustration of a preferred embodiment emulatedobject attribute memory 173. In this example, the native platform includes an object attribute memory that maintains pointer and other information relating to characters to be displayed on the next frame. Preferredexample embodiment emulator 100 includes an emulatedobject attribute memory 173 including an array of up to 40 objects each including y (vertical position), x (horizontal position), character (identifier) and attribute field. The bit-encoding of the attribute field information is also shown inFIG. 24 . AnOAM base pointer 476 is used to function as a pre-allocated pointer to the emulated objectattribute memory object 173. -
FIG. 25 shows an example video memory arrangement including an offscreen memory buffer 168 and an onscreen memory buffer 170. In the example embodiment, the offscreen memory buffer 168 is defined to be larger than the display size of the native platform. For example, the display size of a GAME BOY® or COLOR GAME BOY® is 160 pixels by 144 pixels high. In the example embodiment, offscreen memory buffer 168 is defined to be 192 pixels wide by 160 pixels high—leaving additional memory locations on all sides of the screen size buffer. A buffer zone of sixteen bytes or eight bytes is useful in improving efficiency. The use of screen memory buffers larger than screen size is an attempt to increase graphic drawing efficiency by eliminating clipping calculations and using the hardware BitBlt to transfer a subset of the memory buffer to displayed video memory. It may be desirable to use two off-screen buffers and one on-screen buffer in a classic “double-buffering” technique.Emulator 100 may draw to one buffer until it is complete, then switch to the other buffer. On the target hardware's vertical retrace interrupt, the emulator 100 copies the last-completed buffer to the on-screen area via BitBlt. This works well when a way is provided to implement the vertical retrace interrupt. As mentioned above, the “buffer zone” in the memory buffer is used to eliminate clipping calculations. - The
example embodiment emulator 100 uses a hardware-assisted bit BLIT operation to copy the contents of the screen size buffer into onscreen buffer 170. Such a bit-BLIT hardware-assisted operator can increase transfer times without corresponding increases in overhead. If a bit BLIT operation is not available, then a conventional direct memory access or other memory transfer can be used instead. In the example embodiment, aSTPC_TARGET register 478 is used to specify whether a bit BLIT engine of the target platform is available and can be used (if one is not available, then a conventional memory copy function can be used instead). -
FIG. 26 shows some example additional graphics mode selectors used byemulator 100 in the preferred embodiment, including: -
- a selector
graphics engine register 480 that selects protected-mode memory for the graphics engine registers, - a selector off
screen register 482 that selects protected mode memory for the off-screen video memory buffer 168 (two such selector registers can be used to indicate which one of two double buffered buffers is currently being drawn, with an index variable indicating this), and - a selector on
screen register 484 that selects protected mode memory for the on-screenvideo memory buffer 170.
- a selector
-
FIG. 27 shows an example screen layout ofdisplay 64 showing that the emulated display provided by on-screen buffer 170 may be smaller than the actual display area ofdisplay 64. In one example embodiment, thegraphics adapter 62 and associateddisplay 64 may provide a resolution of 320 pixels by 200 pixels, whereasemulator 100 produces an emulated image of 160 pixels by 144 pixels.Emulator 100 uses only a subset ofdisplay 64 to display emulated images in order to preserve aspect ratio. -
FIG. 28 shows an example set ofgraphics adapter 62 control constants that may be set to the VGA graphics adapter in order to set the graphics adapter's mode for use withemulator 100.Emulator 100 may be hard-coded to a particular graphics mode (320×200×16), an 8-bit color mode, or other mode available on the target hardware. If the 320×200×16 color mode (VESA mode 0x10E) works on a particular target platform,emulator 100 may use this mode exclusively—and there will be no need for different control constants for the VGA. -
FIG. 29 shows example graphics engine register indices and associated example values. A screen pitch of 384 may also be defined as a constant in the example embodiment. - In the example embodiment, the handling of color palettes can lead to efficiency problems. In the example native platforms, graphics characters are represented in a color lookup table (CLUT) format (i.e., the graphics characters themselves include a reduced number of bits that are used to look up a color value in a color palette for display). See
FIG. 21 . The example COLOR GAME BOY® native platform can display 56 colors on the screen nominally (eight palettes of four colors each for background, and eight palettes of four colors each for object characters minus transparency). It would seem therefore that with only 56 simultaneous colors on the screen at any one time, it would be possible to use a 320×200×8-bit VGA mode (13H) which would provide 256 different colors on the screen at once (much more than 56 colors). One possibility would be to simply add an offset into a VGA palette when using 8 bits of color. However, certain game developers for the COLOR GAME BOY® native platform change color palettes during horizontal blanking periods to achieve greater color variety on the screen. To emulate for these particular games, it is necessary to provide more than 256 colors on the screen at a time. A mode such as the VESA standard (320×216 bits) provides 65,000 different colors (RGB 565)—about twice as much as the 32,000 colors the GAME BOY COLOR® is capable of displaying. Thus, this video adapter mode is adequate for even applications that change their color palettes in the middle of a frame—but using this mode doubles the amount of information that must be sent to the video memory per frame and costs processing time. Moreover, it also requiresemulator 100 in the preferred embodiment to map color information (4 bits) into 32,000 colors. The 16-bit color resolution makes it desirable foremulator 100 to write 16-bit color palette information into thevideo adapter 62. This, in turn, necessitates a memory array of 16-bit numbers associated with the various color palettes. The color palettes (seeFIG. 4 ) can be accessed on a character-by-character basis, using pointers to apply color information to the “bit map-ized”character data 164 before the data is written to thedisplay buffer 168. - While the invention has been described in connection with what is presently considered to be the most practical and preferred embodiment, it is to be understood that the invention is not to be limited to the disclosed embodiment, but on the contrary, is intended to cover various modifications and equivalent arrangements included within the scope of the appended claims.
Claims (3)
1. A method of emulating a handheld video game platform comprising:
loading and executing an emulator program on a target platform different from said video game platform;
parsing and interpreting, with said emulator program, a binary image capable of being executed on said video game platform; and
generating an audio visual real time interactive presentation on said target platform in response to said interpreted binary image,
wherein said binary image defines graphic characters using a predetermined format applicable to said handheld video game platform, and said emulator program reformats said graphic characters using a precomputed translation table.
2. A method of emulating a handheld video game platform comprising:
loading and executing an emulator program on a target platform different from said video game platform;
parsing and interpreting, with said emulator program, a binary image capable of being executed on said video game platform; and
generating an audio visual real time interactive presentation on said target platform in response to said interpreted binary image,
wherein said emulator program displays images based on color palettes defined by said binary image that are changed during a display frame.
3. A method of emulating a handheld video game platform comprising:
loading and executing an emulator program on a target platform different from said video game platform;
parsing and interpreting, with said emulator program, a binary image capable of being executed on said video game platform; and
generating an audio visual real time interactive presentation on said target platform in response to said interpreted binary image,
wherein said emulator program uses a jump table to parse op codes within the binary image, and uses a page table to selectively map memory access instructions into predetermined memory locations and/or function calls.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/807,395 US20180065045A1 (en) | 2000-09-18 | 2017-11-08 | Hand-held video game platform emulation |
Applications Claiming Priority (6)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US23362200P | 2000-09-18 | 2000-09-18 | |
US09/723,322 US6672963B1 (en) | 2000-09-18 | 2000-11-28 | Software implementation of a handheld video game hardware platform |
US10/690,818 US8157654B2 (en) | 2000-11-28 | 2003-10-23 | Hand-held video game platform emulation |
US13/439,770 US8795090B2 (en) | 2000-09-18 | 2012-04-04 | Hand-held video game platform emulation |
US14/312,190 US9839849B2 (en) | 2000-09-18 | 2014-06-23 | Hand-held video game platform emulation |
US15/807,395 US20180065045A1 (en) | 2000-09-18 | 2017-11-08 | Hand-held video game platform emulation |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/312,190 Division US9839849B2 (en) | 2000-09-18 | 2014-06-23 | Hand-held video game platform emulation |
Publications (1)
Publication Number | Publication Date |
---|---|
US20180065045A1 true US20180065045A1 (en) | 2018-03-08 |
Family
ID=32825731
Family Applications (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/690,818 Expired - Fee Related US8157654B2 (en) | 2000-09-18 | 2003-10-23 | Hand-held video game platform emulation |
US13/439,770 Expired - Fee Related US8795090B2 (en) | 2000-09-18 | 2012-04-04 | Hand-held video game platform emulation |
US14/312,190 Expired - Lifetime US9839849B2 (en) | 2000-09-18 | 2014-06-23 | Hand-held video game platform emulation |
US15/807,395 Abandoned US20180065045A1 (en) | 2000-09-18 | 2017-11-08 | Hand-held video game platform emulation |
Family Applications Before (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/690,818 Expired - Fee Related US8157654B2 (en) | 2000-09-18 | 2003-10-23 | Hand-held video game platform emulation |
US13/439,770 Expired - Fee Related US8795090B2 (en) | 2000-09-18 | 2012-04-04 | Hand-held video game platform emulation |
US14/312,190 Expired - Lifetime US9839849B2 (en) | 2000-09-18 | 2014-06-23 | Hand-held video game platform emulation |
Country Status (1)
Country | Link |
---|---|
US (4) | US8157654B2 (en) |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108939538A (en) * | 2018-07-24 | 2018-12-07 | 合肥爱玩动漫有限公司 | A kind of disconnection reconnecting method for web game |
US10207191B2 (en) | 2005-05-17 | 2019-02-19 | Electronic Arts Inc. | Collaborative online gaming system and method |
US10286327B2 (en) | 2016-10-21 | 2019-05-14 | Electronic Arts Inc. | Multiplayer video game matchmaking system and methods |
US10610786B2 (en) | 2016-03-08 | 2020-04-07 | Electronic Arts Inc. | Multiplayer video game matchmaking optimization |
US10729975B1 (en) | 2016-03-30 | 2020-08-04 | Electronic Arts Inc. | Network connection selection processing system |
US12017140B2 (en) | 2021-06-07 | 2024-06-25 | Sony Interactive Entertainment LLC | Systems and methods for emulation of graphical and audio parameters during a play of a legacy game |
Families Citing this family (72)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8157654B2 (en) * | 2000-11-28 | 2012-04-17 | Nintendo Co., Ltd. | Hand-held video game platform emulation |
US7127271B1 (en) | 2001-10-18 | 2006-10-24 | Iwao Fujisaki | Communication device |
US7107081B1 (en) | 2001-10-18 | 2006-09-12 | Iwao Fujisaki | Communication device |
US7466992B1 (en) | 2001-10-18 | 2008-12-16 | Iwao Fujisaki | Communication device |
US8229512B1 (en) | 2003-02-08 | 2012-07-24 | Iwao Fujisaki | Communication device |
US7417782B2 (en) | 2005-02-23 | 2008-08-26 | Pixtronix, Incorporated | Methods and apparatus for spatial light modulation |
US8241128B1 (en) | 2003-04-03 | 2012-08-14 | Iwao Fujisaki | Communication device |
US7852856B2 (en) * | 2003-08-29 | 2010-12-14 | Broadcom Corp. | System and method for providing pooling or dynamic allocation of connection context data |
US8090402B1 (en) | 2003-09-26 | 2012-01-03 | Iwao Fujisaki | Communication device |
WO2005039717A1 (en) * | 2003-10-29 | 2005-05-06 | Matsushita Electric Industrial Co., Ltd. | Game system, game execution apparatus, and portable storage medium |
US7917167B1 (en) | 2003-11-22 | 2011-03-29 | Iwao Fujisaki | Communication device |
US8041348B1 (en) | 2004-03-23 | 2011-10-18 | Iwao Fujisaki | Communication device |
US11278793B2 (en) | 2004-03-31 | 2022-03-22 | Nintendo Co., Ltd. | Game console |
US8267780B2 (en) | 2004-03-31 | 2012-09-18 | Nintendo Co., Ltd. | Game console and memory card |
US7837558B2 (en) * | 2004-03-31 | 2010-11-23 | Nintendo Co., Ltd. | Game console and emulator for the game console |
US8016681B2 (en) * | 2004-03-31 | 2011-09-13 | Nintendo Co., Ltd. | Memory card for a game console |
US7771280B2 (en) * | 2004-03-31 | 2010-08-10 | Nintendo Co., Ltd. | Game console connector and emulator for the game console |
US20060080702A1 (en) * | 2004-05-20 | 2006-04-13 | Turner Broadcasting System, Inc. | Systems and methods for delivering content over a network |
US7465231B2 (en) * | 2004-05-20 | 2008-12-16 | Gametap Llc | Systems and methods for delivering content over a network |
US7483696B1 (en) * | 2004-11-29 | 2009-01-27 | Rockwell Collins, Inc. | Cellular wireless network for passengers cabins |
US8482496B2 (en) | 2006-01-06 | 2013-07-09 | Pixtronix, Inc. | Circuits for controlling MEMS display apparatus on a transparent substrate |
US9261694B2 (en) | 2005-02-23 | 2016-02-16 | Pixtronix, Inc. | Display apparatus and methods for manufacture thereof |
US9229222B2 (en) | 2005-02-23 | 2016-01-05 | Pixtronix, Inc. | Alignment methods in fluid-filled MEMS displays |
US7755582B2 (en) | 2005-02-23 | 2010-07-13 | Pixtronix, Incorporated | Display methods and apparatus |
US8519945B2 (en) | 2006-01-06 | 2013-08-27 | Pixtronix, Inc. | Circuits for controlling display apparatus |
US9158106B2 (en) | 2005-02-23 | 2015-10-13 | Pixtronix, Inc. | Display methods and apparatus |
US7746529B2 (en) | 2005-02-23 | 2010-06-29 | Pixtronix, Inc. | MEMS display apparatus |
US7675665B2 (en) | 2005-02-23 | 2010-03-09 | Pixtronix, Incorporated | Methods and apparatus for actuating displays |
US20070205969A1 (en) | 2005-02-23 | 2007-09-06 | Pixtronix, Incorporated | Direct-view MEMS display devices and methods for generating images thereon |
US7742016B2 (en) | 2005-02-23 | 2010-06-22 | Pixtronix, Incorporated | Display methods and apparatus |
US9082353B2 (en) | 2010-01-05 | 2015-07-14 | Pixtronix, Inc. | Circuits for controlling display apparatus |
US8310442B2 (en) | 2005-02-23 | 2012-11-13 | Pixtronix, Inc. | Circuits for controlling display apparatus |
US7999994B2 (en) | 2005-02-23 | 2011-08-16 | Pixtronix, Inc. | Display apparatus and methods for manufacture thereof |
US8159428B2 (en) | 2005-02-23 | 2012-04-17 | Pixtronix, Inc. | Display methods and apparatus |
US8208954B1 (en) | 2005-04-08 | 2012-06-26 | Iwao Fujisaki | Communication device |
US8526096B2 (en) | 2006-02-23 | 2013-09-03 | Pixtronix, Inc. | Mechanical light modulators with stressed beams |
US7876489B2 (en) | 2006-06-05 | 2011-01-25 | Pixtronix, Inc. | Display apparatus with optical cavities |
EP2080045A1 (en) | 2006-10-20 | 2009-07-22 | Pixtronix Inc. | Light guides and backlight systems incorporating light redirectors at varying densities |
WO2008063579A2 (en) | 2006-11-17 | 2008-05-29 | Nintendo Co., Ltd. | Systems and methods for downloading video game programs |
US7852546B2 (en) | 2007-10-19 | 2010-12-14 | Pixtronix, Inc. | Spacers for maintaining display apparatus alignment |
US9176318B2 (en) | 2007-05-18 | 2015-11-03 | Pixtronix, Inc. | Methods for manufacturing fluid-filled MEMS displays |
JP4671198B2 (en) * | 2007-01-26 | 2011-04-13 | 株式会社ソニー・コンピュータエンタテインメント | Information processing device |
US7890089B1 (en) | 2007-05-03 | 2011-02-15 | Iwao Fujisaki | Communication device |
US8559983B1 (en) | 2007-05-03 | 2013-10-15 | Iwao Fujisaki | Communication device |
US8676273B1 (en) | 2007-08-24 | 2014-03-18 | Iwao Fujisaki | Communication device |
US8639214B1 (en) | 2007-10-26 | 2014-01-28 | Iwao Fujisaki | Communication device |
US8472935B1 (en) | 2007-10-29 | 2013-06-25 | Iwao Fujisaki | Communication device |
US8613673B2 (en) * | 2008-12-15 | 2013-12-24 | Sony Computer Entertainment America Llc | Intelligent game loading |
US8744720B1 (en) | 2007-12-27 | 2014-06-03 | Iwao Fujisaki | Inter-vehicle middle point maintaining implementer |
JP2009205422A (en) * | 2008-02-27 | 2009-09-10 | Nintendo Co Ltd | Information processing system |
US8248560B2 (en) | 2008-04-18 | 2012-08-21 | Pixtronix, Inc. | Light guides and backlight systems incorporating prismatic structures and light redirectors |
US8543157B1 (en) | 2008-05-09 | 2013-09-24 | Iwao Fujisaki | Communication device which notifies its pin-point location or geographic area in accordance with user selection |
US8340726B1 (en) | 2008-06-30 | 2012-12-25 | Iwao Fujisaki | Communication device |
US8452307B1 (en) | 2008-07-02 | 2013-05-28 | Iwao Fujisaki | Communication device |
US8169679B2 (en) | 2008-10-27 | 2012-05-01 | Pixtronix, Inc. | MEMS anchors |
JP5415779B2 (en) * | 2009-02-19 | 2014-02-12 | 株式会社ソニー・コンピュータエンタテインメント | Compatible adapter device and compatible processing method |
US8887129B1 (en) * | 2010-01-25 | 2014-11-11 | Sprint Communications Company L.P. | Detecting non-touch applications |
CN102834763B (en) | 2010-02-02 | 2015-07-22 | 皮克斯特罗尼克斯公司 | Methods for manufacturing cold seal fluid-filled display apparatus |
CN103000141B (en) | 2010-02-02 | 2016-01-13 | 皮克斯特罗尼克斯公司 | For controlling the circuit of display device |
US9134552B2 (en) | 2013-03-13 | 2015-09-15 | Pixtronix, Inc. | Display apparatus with narrow gap electrostatic actuators |
US9486700B2 (en) * | 2014-04-10 | 2016-11-08 | Dean Schumacher | Video game incorporating safe live-action combat |
WO2016018233A1 (en) * | 2014-07-28 | 2016-02-04 | Hewlett-Packard Development Company, L.P. | Memory access control |
WO2016018234A1 (en) | 2014-07-28 | 2016-02-04 | Hewlett-Packard Development Company, L.P. | Memory access control |
US9614942B2 (en) * | 2014-08-22 | 2017-04-04 | Google Inc. | Systems and methods for tangible configuration of a modular mobile electronic device |
CN105786441B (en) * | 2016-01-29 | 2019-01-25 | 腾讯科技(深圳)有限公司 | A kind of method of audio processing, server, user equipment and system |
US10286304B2 (en) * | 2016-08-30 | 2019-05-14 | Microsoft Technology Licensing, Llc | Controller having accessory connectors for externalizing controls |
CN111787186A (en) * | 2017-06-26 | 2020-10-16 | 张旺 | Video image processing method and picture splicing method based on electronic map |
CN109945411B (en) * | 2019-03-25 | 2020-05-26 | 珠海格力电器股份有限公司 | Control method and device of controller, storage medium and controller |
US11669435B2 (en) * | 2019-06-26 | 2023-06-06 | Microsoft Technology Licensing, Llc | Chat bot diagnostic visualization |
US11216065B2 (en) * | 2019-09-26 | 2022-01-04 | Lenovo (Singapore) Pte. Ltd. | Input control display based on eye gaze |
WO2022054283A1 (en) * | 2020-09-14 | 2022-03-17 | 日本電信電話株式会社 | Information processing system, information processing method, and program |
US11272250B1 (en) * | 2020-11-23 | 2022-03-08 | The Boston Consulting Group, Inc. | Methods and systems for executing and monitoring content in a decentralized runtime environment |
Family Cites Families (87)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR2506623A1 (en) | 1981-06-01 | 1982-12-03 | Radiotechnique | THREE-COLOR VIDEO SIGNAL GENERATOR, SUCH AS A VIDEO GAME, FOR USE WITH A MONOCHROME IMAGE REPRODUCER |
JPS58116377A (en) | 1981-12-28 | 1983-07-11 | 任天堂株式会社 | Handheld type game apparatus |
FR2532856A1 (en) | 1982-09-14 | 1984-03-16 | Radiotechnique | TRICHROME VIDEO SIGNAL GENERATING SYSTEM, SUCH AS A GAME, AND REMOVABLE CARTRIDGE FOR SUCH A SYSTEM |
US4516777A (en) | 1983-11-21 | 1985-05-14 | Nikora Robert J | Mobile self-contained video game system with instantaneously selectable game cartridges |
US4979738A (en) | 1983-12-06 | 1990-12-25 | Midway Manufacturing Corporation | Constant spatial data mass RAM video display system |
US5089811A (en) | 1984-04-16 | 1992-02-18 | Texas Instruments Incorporated | Advanced video processor having a color palette |
JPS61182160A (en) * | 1985-02-06 | 1986-08-14 | Toshiba Corp | Data processing device |
US5153577A (en) * | 1986-04-28 | 1992-10-06 | Xerox Corporation | Mapping character color attributes into grey pixel patterns |
CA1284225C (en) | 1986-07-23 | 1991-05-14 | Katsuya Nakagawa | Game software service system |
US4756528A (en) | 1986-07-24 | 1988-07-12 | Ramon Umashankar | Video system for passenger vehicles |
JPS63242293A (en) | 1987-03-31 | 1988-10-07 | 株式会社 ナムコ | Initial data input system of game |
US4924413A (en) | 1987-05-29 | 1990-05-08 | Hercules Computer Technology | Color conversion apparatus and method |
US4771279A (en) * | 1987-07-10 | 1988-09-13 | Silicon Graphics, Inc. | Dual clock shift register |
JPS6424565A (en) | 1987-07-20 | 1989-01-26 | Sharp Kk | System for storing plural kinds of picture data |
US4903218A (en) | 1987-08-13 | 1990-02-20 | Digital Equipment Corporation | Console emulation for a graphics workstation |
US4858930A (en) | 1988-06-07 | 1989-08-22 | Namco, Ltd. | Game system |
US5300944A (en) | 1988-07-21 | 1994-04-05 | Proxima Corporation | Video display system and method of using same |
FI111789B (en) | 1989-01-10 | 2003-09-15 | Nintendo Co Ltd | Electronic gaming apparatus with the possibility of pseudostereophonic development of sound |
US5184830A (en) * | 1989-01-10 | 1993-02-09 | Nintendo Company Limited | Compact hand-held video game system |
FI99250C (en) | 1989-01-10 | 1997-12-29 | Nintendo Co Ltd | System for preventing unauthorized use of external memory |
US5412800A (en) | 1989-05-25 | 1995-05-02 | Cirrus Logic, Inc. | System for running incompatible graphics programs |
GB8912866D0 (en) | 1989-06-05 | 1989-07-26 | Code Masters Softwara | Interfacing device for a computer games system |
JP2627208B2 (en) | 1990-06-14 | 1997-07-02 | 株式会社セガ・エンタープライゼス | Game device and television tuner cartridge for game device |
US5265888A (en) | 1990-06-22 | 1993-11-30 | Nintendo Co., Ltd. | Game apparatus and memory cartridge used therefor |
JP2610200B2 (en) | 1990-10-02 | 1997-05-14 | 株式会社セガ・エンタープライゼス | Image processing device |
JPH04140792A (en) | 1990-10-02 | 1992-05-14 | Sega Enterp Ltd | Image processor |
JPH04261589A (en) * | 1991-02-05 | 1992-09-17 | Mitsubishi Electric Corp | Graphic display device |
US5400053A (en) | 1991-06-17 | 1995-03-21 | Chips And Technologies, Inc. | Method and apparatus for improved color to monochrome conversion |
CA2058219C (en) | 1991-10-21 | 2002-04-02 | Smart Technologies Inc. | Interactive display system |
GB9210786D0 (en) | 1992-05-20 | 1992-07-08 | Codemasters Ltd | Memory cartridges |
US5282621A (en) * | 1992-11-24 | 1994-02-01 | Tseng Ching J | Universal converter for non-exclusive cards of video game |
EP0608053B1 (en) | 1993-01-11 | 1999-12-01 | Canon Kabushiki Kaisha | Colour display system |
US5559954A (en) | 1993-02-24 | 1996-09-24 | Intel Corporation | Method & apparatus for displaying pixels from a multi-format frame buffer |
US5442375A (en) | 1993-03-25 | 1995-08-15 | Toshiba America Information Systems, Inc. | Method and apparatus for identifying color usage on a monochrome display |
US5959596A (en) | 1993-06-24 | 1999-09-28 | Nintendo Co., Ltd. | Airline-based video game and communications system |
JP3366413B2 (en) | 1993-07-27 | 2003-01-14 | 任天堂株式会社 | Display information conversion apparatus and information processing system |
JPH07211410A (en) | 1994-01-25 | 1995-08-11 | Nintendo Co Ltd | Connector and adaptor using it |
JP3368967B2 (en) * | 1994-01-25 | 2003-01-20 | 任天堂株式会社 | Conversion device for game machines |
US5781758A (en) * | 1995-03-23 | 1998-07-14 | Apple Computer, Inc. | Software emulation system with reduced memory requirements |
US5854620A (en) | 1995-06-23 | 1998-12-29 | Cirrus Logic, Inc. | Method and apparatus for converting monochrome pixel data to color pixel data |
US6058288A (en) * | 1995-08-07 | 2000-05-02 | Sextant In-Flight Systems, Llc | Passenger service and entertainment system |
US5819063A (en) * | 1995-09-11 | 1998-10-06 | International Business Machines Corporation | Method and data processing system for emulating a program |
US6007428A (en) * | 1995-10-09 | 1999-12-28 | Nintendo Co., Ltd. | Operation controlling device and video processing system used therewith |
US5790825A (en) * | 1995-11-08 | 1998-08-04 | Apple Computer, Inc. | Method for emulating guest instructions on a host computer through dynamic recompilation of host instructions |
US5775993A (en) * | 1996-01-31 | 1998-07-07 | Innovative Gaming Corporation Of America | Roulette gaming machine |
US6084600A (en) * | 1996-03-15 | 2000-07-04 | Micron Technology, Inc. | Method and apparatus for high-speed block transfer of compressed and word-aligned bitmaps |
US5768593A (en) | 1996-03-22 | 1998-06-16 | Connectix Corporation | Dynamic cross-compilation system and method |
US5748945A (en) * | 1996-05-31 | 1998-05-05 | International Business Machiens Corporation | Method for slave DMA emulation on a computer system bus |
US5785598A (en) | 1996-06-18 | 1998-07-28 | United Microelectronics Corporation | Software cartridge being extensible with additional programs and/or data and the method of fabricating the same |
US5903760A (en) * | 1996-06-27 | 1999-05-11 | Intel Corporation | Method and apparatus for translating a conditional instruction compatible with a first instruction set architecture (ISA) into a conditional instruction compatible with a second ISA |
US5790096A (en) | 1996-09-03 | 1998-08-04 | Allus Technology Corporation | Automated flat panel display control system for accomodating broad range of video types and formats |
US5892939A (en) | 1996-10-07 | 1999-04-06 | Honeywell Inc. | Emulator for visual display object files and method of operation thereof |
JPH10137447A (en) | 1996-11-13 | 1998-05-26 | Hori Denki Kk | Software emulator for executing differently described software and input-output device in certain game device |
US6020751A (en) | 1997-01-02 | 2000-02-01 | Intel Corporation | Method and apparatus for stress testing of a circuit board assembly |
US6047373A (en) | 1997-01-02 | 2000-04-04 | Intel Corporation | Method and apparatus for setting the operating parameters of a computer system |
JPH10328408A (en) | 1997-05-29 | 1998-12-15 | Sony Corp | Computer game machine |
JPH11207034A (en) | 1997-11-20 | 1999-08-03 | Nintendo Co Ltd | Game system capable of playing between different kinds of game machines through use of backup data |
US6167365A (en) * | 1998-02-06 | 2000-12-26 | Texas Instruments Incorporated | Method of initializing CPU for emulation |
JP4140791B2 (en) | 1998-04-17 | 2008-08-27 | 新日本石油株式会社 | Lubricating oil composition |
JP4140792B2 (en) | 1998-04-23 | 2008-08-27 | 株式会社コスモ総合研究所 | Chlorosulfonic acid derivatives of cyclic phenol sulfides and process for producing the same |
US6315669B1 (en) * | 1998-05-27 | 2001-11-13 | Nintendo Co., Ltd. | Portable color display game machine and storage medium for the same |
JP3874536B2 (en) | 1998-05-27 | 2007-01-31 | 任天堂株式会社 | Portable color display game machine and storage medium thereof |
US6247172B1 (en) * | 1998-07-02 | 2001-06-12 | Hewlett-Packard Company | Method for a translation system that aggressively optimizes and preserves full synchronous exception state |
US6192446B1 (en) * | 1998-09-03 | 2001-02-20 | Micron Technology, Inc. | Memory device with command buffer |
US6409602B1 (en) | 1998-11-06 | 2002-06-25 | New Millenium Gaming Limited | Slim terminal gaming system |
US6115054A (en) | 1998-12-29 | 2000-09-05 | Connectix Corporation | Graphics processor emulation system and method with adaptive frame skipping to maintain synchronization between emulation time and real time |
US6747642B1 (en) * | 1999-01-29 | 2004-06-08 | Nintendo Co., Ltd. | Method and apparatus for providing non-photorealistic cartoon outlining within a 3D videographics system |
US6658056B1 (en) * | 1999-03-30 | 2003-12-02 | Sony Corporation | Digital video decoding, buffering and frame-rate converting method and apparatus |
US6390920B1 (en) | 1999-06-18 | 2002-05-21 | Rockwell Collins, Inc. | Vehicle entertainment system having seat controller cards programmed to operate as both browser and server |
US6935954B2 (en) * | 2000-02-24 | 2005-08-30 | Nintendo Of America Inc. | Sanity system for video game |
US20010029205A1 (en) * | 2000-03-30 | 2001-10-11 | Sagahiro Taho | Game program delivery system and apparatus used in same |
US6955606B2 (en) * | 2000-03-30 | 2005-10-18 | Nintendo Co., Ltd. | Game information storage medium and game system using the same |
US6862565B1 (en) * | 2000-04-13 | 2005-03-01 | Hewlett-Packard Development Company, L.P. | Method and apparatus for validating cross-architecture ISA emulation |
US6383080B1 (en) * | 2000-05-09 | 2002-05-07 | Nintendo Co., Ltd. | Kiosk for printing and communicating video game images |
US7445551B1 (en) * | 2000-05-24 | 2008-11-04 | Nintendo Co., Ltd. | Memory for video game system and emulator using the memory |
US6651132B1 (en) | 2000-07-17 | 2003-11-18 | Microsoft Corporation | System and method for emulating the operation of a translation look-aside buffer |
US7506265B1 (en) | 2000-07-17 | 2009-03-17 | Microsoft Corporation | System and method for displaying images of virtual machine environments |
US7069205B1 (en) | 2000-07-17 | 2006-06-27 | Microsoft Corporation | System and method for emulating the operation of a video graphics adapter |
US6636214B1 (en) * | 2000-08-23 | 2003-10-21 | Nintendo Co., Ltd. | Method and apparatus for dynamically reconfiguring the order of hidden surface processing based on rendering mode |
US6672963B1 (en) * | 2000-09-18 | 2004-01-06 | Nintendo Co., Ltd. | Software implementation of a handheld video game hardware platform |
US6884171B2 (en) * | 2000-09-18 | 2005-04-26 | Nintendo Co., Ltd. | Video game distribution network |
US8157654B2 (en) * | 2000-11-28 | 2012-04-17 | Nintendo Co., Ltd. | Hand-held video game platform emulation |
US8267780B2 (en) * | 2004-03-31 | 2012-09-18 | Nintendo Co., Ltd. | Game console and memory card |
US7765539B1 (en) * | 2004-05-19 | 2010-07-27 | Nintendo Co., Ltd. | System and method for trans-compiling video games |
US7389500B2 (en) * | 2005-07-08 | 2008-06-17 | Microsoft Corporation | Selective pre-compilation of virtual code to enhance boot time emulator performance |
US7830388B1 (en) * | 2006-02-07 | 2010-11-09 | Vitie Inc. | Methods and apparatus of sharing graphics data of multiple instances of interactive application |
US20100227682A1 (en) * | 2009-03-04 | 2010-09-09 | Microsoft Corporation | Awarding of avatar items in video game environment |
-
2003
- 2003-10-23 US US10/690,818 patent/US8157654B2/en not_active Expired - Fee Related
-
2012
- 2012-04-04 US US13/439,770 patent/US8795090B2/en not_active Expired - Fee Related
-
2014
- 2014-06-23 US US14/312,190 patent/US9839849B2/en not_active Expired - Lifetime
-
2017
- 2017-11-08 US US15/807,395 patent/US20180065045A1/en not_active Abandoned
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10207191B2 (en) | 2005-05-17 | 2019-02-19 | Electronic Arts Inc. | Collaborative online gaming system and method |
US10967276B2 (en) | 2005-05-17 | 2021-04-06 | Electronic Arts Inc. | Collaborative online gaming system and method |
US10610786B2 (en) | 2016-03-08 | 2020-04-07 | Electronic Arts Inc. | Multiplayer video game matchmaking optimization |
US11141663B2 (en) | 2016-03-08 | 2021-10-12 | Electronics Arts Inc. | Multiplayer video game matchmaking optimization |
US10729975B1 (en) | 2016-03-30 | 2020-08-04 | Electronic Arts Inc. | Network connection selection processing system |
US10286327B2 (en) | 2016-10-21 | 2019-05-14 | Electronic Arts Inc. | Multiplayer video game matchmaking system and methods |
US10751629B2 (en) | 2016-10-21 | 2020-08-25 | Electronic Arts Inc. | Multiplayer video game matchmaking system and methods |
US11344814B2 (en) | 2016-10-21 | 2022-05-31 | Electronic Arts Inc. | Multiplayer video game matchmaking system and methods |
CN108939538A (en) * | 2018-07-24 | 2018-12-07 | 合肥爱玩动漫有限公司 | A kind of disconnection reconnecting method for web game |
US12017140B2 (en) | 2021-06-07 | 2024-06-25 | Sony Interactive Entertainment LLC | Systems and methods for emulation of graphical and audio parameters during a play of a legacy game |
Also Published As
Publication number | Publication date |
---|---|
US20140349751A1 (en) | 2014-11-27 |
US8795090B2 (en) | 2014-08-05 |
US9839849B2 (en) | 2017-12-12 |
US20130095922A1 (en) | 2013-04-18 |
US20040157664A1 (en) | 2004-08-12 |
US8157654B2 (en) | 2012-04-17 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20180065045A1 (en) | Hand-held video game platform emulation | |
US6672963B1 (en) | Software implementation of a handheld video game hardware platform | |
US7837558B2 (en) | Game console and emulator for the game console | |
US7338376B2 (en) | Video game distribution network | |
US8016681B2 (en) | Memory card for a game console | |
US8821287B2 (en) | Video game display system | |
US6322447B1 (en) | Portable color display game machine and storage medium for the same | |
KR100823786B1 (en) | Display, displaying method, and computer-readable information recording medium having a program recorded thereon | |
US7771280B2 (en) | Game console connector and emulator for the game console | |
US6468161B1 (en) | Video game device and method of displaying images of game, and storage medium storing programs for causing a computer to execute the method | |
KR100878964B1 (en) | Game machine, game machine control method, and computer-readable information recording medium having a program recorded thereon | |
JP2003515766A (en) | Method and apparatus for displaying high color resolution on a handheld LCD device | |
US7369665B1 (en) | Method and apparatus for mixing sound signals | |
JP3297410B2 (en) | Image generation system and information storage medium | |
JP4394211B2 (en) | Image generation system and information storage medium | |
JP2003255926A (en) | Device and program for image display | |
JP4693153B2 (en) | Image generation system, program, and information storage medium | |
JPH07323161A (en) | Electronic game device | |
JP2002078964A (en) | Entertainment device, command input acceptance method and command display method | |
JPH07323160A (en) | Electronic game device | |
JP2000148133A (en) | Image display method and image processing device | |
JP2002078960A (en) | Game system, storage medium and entertainment device | |
CA2452387A1 (en) | Image and sound processing apparatus |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |