aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source/doc/porting.txt725
-rw-r--r--source/docs/changes.txt2459
-rw-r--r--source/docs/control-inputs.txt68
-rw-r--r--source/docs/controls.txt97
-rw-r--r--source/docs/gpl-2.0.txt339
-rw-r--r--source/docs/lgpl-2.1.txt504
-rw-r--r--source/docs/porting.html371
-rw-r--r--source/docs/portsofsnes9x.txt118
-rw-r--r--source/docs/snapshots.txt84
-rw-r--r--source/docs/snes9x-license.txt174
-rw-r--r--source/docs/snes9x.conf.default238
11 files changed, 4452 insertions, 725 deletions
diff --git a/source/doc/porting.txt b/source/doc/porting.txt
deleted file mode 100644
index 3d28eec..0000000
--- a/source/doc/porting.txt
+++ /dev/null
@@ -1,725 +0,0 @@
- How to Port Snes9x to a New Platform
- ====================================
-
-Version: 1.01
-Date: 23-December-1998
-
-(c) Copyright 1998 Gary Henderson (gary@daniver.demon.co.uk)
-
-Introduction
-============
-
-This is brief description of the steps involved in porting Snes9x, the Super
-Nintendo Entertainment System emulator, to new hardware which is at least
-similar to Workstation or PC. It describes what code you have to write and
-what functions exist that you can make use of. It also gives some insights as
-to how Snes9x actually works, although that will be subject of another
-document yet to be written.
-
-Host System Requirements
-========================
-
-A C++ compiler, so you can compile the emulator! Snes9x really isn't written
-in C++, it just uses the C++ compiler as a 'better C' compiler to get inline
-functions and so on. With some modification, it could be converted to be
-compiled with an ordinary C compiler. Snes9x isn't very C type safe and
-will probably not work on a system who's integers are less than 32-bits wide
-without lots of editing.
-
-If the host system uses a CPU that implements the i386 instruction set then
-you will also want to use the three assembler CPU cores, although I recently
-scrapped the SPC700 assembler code (too many bugs) and replaced it with
-compiler generated assembler code that I haven't got around to optimising
-yet. The 65c816 and SPC700 code needs to be assembled using the GNU
-assembler that comes with gcc and the Super FX code assembled with NASM
-v0.97 or higher. gcc is available from lots of sites. NASM is available from
-http://www.cryogen.com/Nasm
-
-A fast CPU. SNES emulation is very compute intensive: two, or sometimes three
-CPUs to emulate, an 8-channel 16-bit stereo sound digital signal processor
-with real-time sample decompression, filter and echo effects, two custom
-graphics processor chips that can produce transparency, scaling, rotation
-and window effects in 32768 colors, and finally hardware DMA all take their
-toll on the host CPU.
-
-Lots of RAM. The SNES itself has 128k work RAM, 64k V-RAM and 64k sound CPU
-RAM. If a Super FX game is being emulated, that usually comes with another
-64k inside the game pack. Snes9x itself needs 4Mb to load SNES ROM images
-into (or 6Mb if I ever figure out the SNES memory map of the 48Mbit ROM
-images out there), 256k to cache decompressed sound samples in, 512k to
-cache converted SNES tiles in, and another 64k for S-RAM emulation. And
-that's not counting a few large lookup tables that the graphics code needs
-for speeding up transparency effects plus few other tables used by the ZSNES
-Super FX code. It all adds up to 7Mb (ish). Add to that RAM needed to
-store the actual emulator code and RAM required by the host operating system
-and any other process that is running; that's lots of RAM. Well, it is if
-your host system only has a few mega-bytes of RAM available.
-
-An 8-bit, 256 color (one byte per pixel) or deeper display, at least 256x239
-pixels in resolution, or 512x478 if you're going to support the SNES'
-hi-res. background screen modes. Ideally, a 16-bit, 65536 color screen mode
-is required if you want to support transparency at speed, as that is what the
-code renders internally. Any other format screen, with transparency enabled,
-will require picture format conversion before you can place the rendered
-SNES image on to the screen.
-
-Sound output requires spooling 8-bit or 16-bit, mono or stereo digital sound
-data to the host computer's sound hardware. The DOS port uses interrupts
-from the sound card to know when more sound data is required, most other
-ports have to periodically poll the host sound hardware to see if more data
-is required; if it is then the SNES sound mixing code provided by Snes9x is
-called to fill an area of system memory with ready mixed SNES sound data,
-which then can be passed on to the host sound hardware. Sound data is
-generated as an array of bytes (uint8) for 8-bit sound or shorts (int16) for
-16-bit data. Stereo sound data generates twice as many samples, with each
-channel's samples interleaved, first left's then right's.
-
-For the user to be able to control and play SNES games, some form of input
-device is required, a joystick or keyboard, for example. The real SNES can
-have 2 eight-button digital joy-pads connected to it or 5 joy-pads when an
-optional multi-player adaptor was purchased, although most games only require
-a single joy-pad. Access to all eight buttons and the direction pad, of
-course, are usually required by most games. Snes9x does emulate the
-multi-player adaptor hardware, if you were wondering, but its still up to
-you to provide the emulation of the individual joy-pads.
-
-The SNES also had a mouse and light gun available as optional extras,
-Snes9x can emulate both of these using some form of pointing device,
-usually the host system's mouse.
-
-If an accurate, constant SNES play rate is required, then a real-time timer
-will be needed that can time intervals of 16.7ms (NTSC frame time) or 20ms
-(PAL frame time).
-
-Some SNES game packs contained a small amount of extra RAM and a battery so
-ROMs could save a player's progress through a game for games that takes many
-hours to play from start to finish. Snes9x simulates this S-RAM by saving
-the contents of the area of memory normally occupied by the S-RAM into file
-then automatically restoring it again the next time the user plays the same
-game. If the hardware you're porting to doesn't have a hard disk available
-then you could be in trouble.
-
-Snes9x also implements freeze-game files which can record the state of the
-SNES hardware and RAM at a particular point in time and can restore it to
-that exact state at a later date - the result is that users can save a game
-at any point, not just at save-game or password points provided by the
-original game coders. Each freeze file is over 400k in size. To help save
-disk space, Snes9x can be compiled with zlib, which is used to compress the
-freeze files, reducing the size to typically below 100k. Download zlib from
-its homepage at http://www.cdrom.com/pub/infozip/zlib/, compile Snes9x with
-ZLIB defined and link with zlib. zlib is also used to load any compressed
-ROM images Snes9x my encounter, compressed with gzip or compress.
-
-Porting
-=======
-
-In theory you will only need to edit port.h, then in a separate file write
-all the initialisation code and interface routines that Snes9x expects the
-you to implement. You, no doubt, will discover otherwise....
-
-There are several compile-time only options available:
-
-DEBUGGER
---------
-
-Enables extra code to assist me in debugging SNES ROMs. The debugger has only
-ever been a quick-hack by me and user-interface to debugger facilities is
-virtually non-existent. Most of the debugger information is output via
-stdout and enabling the compile-time options slows the whole emulator down
-slightly. However, the debugger options available are very powerful; you
-could use it to help get your port working. You probably still want to ship
-the finished version with the debugger disabled, it will only confuse
-non-technical users.
-
-VAR_CYCLES
-----------
-
-I recommend you define this. The main CPU in the SNES actually varies in
-speed depending on what area of memory its accessing and the ROM access
-speed of the game pack; defining VAR_CYCLES causes Snes9x to emulate this,
-using a good approximation, rather than fixed cycle length as ZSNES does. The
-resultant code is slightly slower. Leaving it undefined results in many more
-emulation timing errors appearing while playing games.
-
-CPU_SHUTDOWN and SPC700_SHUTDOWN
---------------------------------
-
-Again I recommend defining both of these. They are both speed up hacks.
-When defined, Snes9x starts watching for when either the main or sound CPUs
-are in simply loops waiting for a known event to happen - like the end of
-the current scan-line, and interrupt or a sound timer to reach a particular
-value. If Snes9x spots either CPU in such a loop it uses its insider
-knowledge to simply skip the emulation of that CPU's instructions until the
-event happens. It can be a big win with lots of SNES games.
-
-I'm constantly amazed at the ingenuity of some programmers who are able to
-produce complex code to do simple things: some ROM's wait loops are so
-complex Snes9x fails to spot the CPU is in such a loop and the shutdown
-speed up hacks don't work.
-
-You might be wondering why VAR_CYCLES, and the two SHUTDOWN options have to
-be enabled with defines, well, in the past they sometimes introduced
-problems with some ROMs, so I kept them as options. I think I've fixed all
-the problems now, but you never know...
-
-SPC700_C
---------
-
-Define this if you are using the C/C++ version of the SPC700 CPU core. It
-enables a ROM compatibility feature that executes SPC700 instructions during
-SNES DMA, it allows several games to start that would otherwise lock up and
-fixes music pauses when ROMs do lots of DMA, usually when switching between
-game screens.
-
-ZLIB
-----
-
-Define this if you have the zlib library available and you want it to
-compress freeze-game files to save disk space. The library is also used to
-support compressed ROM images.
-
-NO_INLINE_SET_GET
------------------
-
-Define this to stop several of the memory access routines from being
-defined in-line. Whether the C++ compiler actually in-lines when this symbol
-is not defined is up to the compiler itself. In-lines functions can speed up
-the C++ CPU emulations on some architectures at the cost of increased code
-size. Try fiddling with this option once you've got port working to see if
-it helps the speed of your port.
-
-EXECUTE_SUPERFX_PER_LINE and ZSNES_FX
--------------------------------------
-
-Define these if you're going to be using the ZSNES Super FX i386 assembler
-code, otherwise leave them both undefined. In theory,
-EXECUTE_SUPERFX_PER_LINE can also be defined when using the C++ Super FX
-emulation code, but the code is still buggy and enabling the option
-introduces more problems than it fixes. Any takers for fixing the C++ code?
-
-JOYSTICK_SUPPORT, SIDEWINDER_SUPPORT and GRIP_SUPPORT
------------------------------------------------------
-
-These options enable support for various input devices in the UNIX and MS-DOS
-port code. They're only of interest if you're able to use the existing UNIX
-or MS-DOS port specific code.
-
-port.h
-======
-
-If the byte ordering of the target system is least significant byte first,
-make sure LSB_FIRST is defined in this header, otherwise, make sure its not
-defined.
-
-If you're going to support 16-bit screen rendering (required if you want
-transparency effects) and your system doesn't use RGB 565 - 5 bits for red,
-6 bits for green and 5 bits for blue - then you'll need make sure RGB555,
-BGR565 or BGR555 is defined instead. You might want to take a look at the
-*_LOW_BIT_MASKs, *_HI_BIT_MASKs and BUILD_PIXEL macros to make sure they're
-correct, because I've only every tested the RGB565 version, though the Mac
-port uses the RGB555 option. If your system is 24 or 32-bit only, then
-don't define anything; instead write a conversion routine that will take a
-complete rendered 16-bit SNES screen in RGB565 format and convert to the
-format required to be displayed on your hardware.
-
-port.h also typedefs some types, uint8 for an unsigned, 8-bit quantity,
-uint16 for an unsigned, 16-bit quantity, uint32 for a 32-bit, unsigned
-quantity and bool8 for a true/false type. Signed versions are also
-typedef'ed.
-
-The CHECK_SOUND macro can be defined to invoke some code that polls the
-host system's sound hardware to see if it can accept any more sound data.
-Snes9x makes calls to this macro several times when it is rendering the SNES
-screen, during large SNES DMAs and after every emulated CPU instruction.
-
-Since this CHECK_SOUND macro is invoked often, the code should only take a
-very small amount of time to execute or it will slow down the emulator's
-performance. The Linux and UNIX ports use a system timer and set a variable
-when it has expired; the CHECK_SOUND only has to check to see if the
-variable is set. On the MS-DOS and Mac ports, the sound hardware is not
-polled at all, instead it is driven by interrupts or callbacks and the
-CHECK_SOUND macro is defined to be empty.
-
-Initialisation Code
--------------------
-
-This is what the Linux, UNIX and MS-DOS ports do, I suspect your code
-might be similar:
-
-- The Settings structure is initialised to some sensible default values -
- check the main function in unix.cpp for the values it uses.
-
-- The command line is parsed, options specified override default values in
- the Settings structure and specify a ROM image filename that the user
- wants loaded. Your port could load user preferences from a file or some
- other source at this point. Most values, with a little care, can be changed
- via a GUI once the emulator is running.
-
-- Some Settings structure value validation takes place, for example if
- transparency effects are requested the code also makes sure 16-bit
- screen rendering is turned on as well.
-
-- Memory.Init() and S9xInitAPU() are called, checking neither failed. The
- only reason they would fail is if memory allocation failed.
-
-- Memory.LoadROM (filename) is called to load the specified ROM image into
- memory. If that worked Memory.LoadSRAM (sram_filename) is called to load
- the ROM's S-RAM file, if one exists. The all current ports base the
- sram_filename on the filename of the ROM image, changing the file's
- extension (the .smc or whatever bit) and changing the directory where its
- located - you won't be able to save S-RAM files onto a CD if that's where
- the ROM image is located!
-
- If your port has a GUI, you can delay this step until the user picks an
- image to load.
-
- SNES roms images come in all shapes and sizes, some with headers, some
- without, some have been mangled by the copier device in one of two ways, and
- some split into several pieces; plus the SNES itself has several different
- memory map models. The code tries to auto-detect all these various types,
- but sometimes the SNES ROM header information has been manually edited by
- someone at some stage and the code guesses wrong. To help it out it these
- situations, the Settings structure contains several options to force a
- particular ROM image format; these values must be initialised prior to each
- call to Memory.LoadROM(filename).
-
-- The Linux and UNIX ports now do some more operating system initialisation
- ready for a system timer to be started.
-
-- The host display hardware is now initialised. The actual screen depth and
- resolution should be picked based on the user preferences if possible.
- The X Window System port can't control the screen depth or resolution, if
- the user requests transparency effects but the display hardware is only
- set to 8-bit, it has to invoke an extra step of converting the 16-bit SNES
- rendered screen to a fixed palette 8-bit display just before the SNES
- screen is copied to the display hardware.
-
- The GFX.Screen pointer needs to be initialised to point to an array of
- uint8 for 8-bit screen rendering or uint16 for 16-bit rendering, cast to
- an array of uint8. The array needs to be at least 256x239 bytes or shorts
- in size for lo-res only support (Settings.SupportHiRes = FALSE) or
- 512x478 for lo-res and hi-res support. If transparency effects are
- required, the GFX.SubScreen array also needs to be initialised to another
- identically sized array of the same type, otherwise it can be just
- initialised to NULL.
-
- The GFX.Pitch variable needs to be set to the number of bytes on each line
- of the arrays, e.g. 256 for lo-res only support, up to 1024 for 16-bit
- hi-res support. If GFX.Screen is pointing into an existing array, one
- created by the library function rather than just calling malloc or new,
- then set GFX.Pitch to the number of bytes per line of that array,
- including any padding the library function may have added.
-
- If the target hardware supports fast access to video RAM, the screen is in
- 16-bit format supported by the SNES rendering code and you can double
- buffer the display, you might want to point GFX.Screen directly at the
- video buffer RAM. You will need to recompute the GFX.Delta value every
- time you change the GFX.Screen value to double-buffer the rendering and
- display.
-
-- A call to S9xGraphicsInit() is made; make sure all your graphics rendering
- options are setup correctly by now. If later, you want to change some
- settings, for example 16-bit to 8-bit rendering, call S9xGraphicsDeinit()
- first, change your settings, GFX.Screen and GFX.SubScreen arrays, etc.,
- then call S9xGraphicsInit() again.
-
-- S9xInitSound(int playbackrate, bool8 stereo, int sound_buffer_size)
- is now called, which in turn will call your S9xOpenSoundDevice function -
- see below.
-
-- The display is switched to graphics mode using a call to S9xGraphicsMode().
-
-- The system timer is started; its used for keeping the emulator speed
- relatively constant on the MS-DOS port and noting when the sound hardware
- sound should be able to accept more sound data on the Linux and UNIX ports.
-
-- A main loop is entered which is just a loop constantly calling
- S9xMainLoop() then polling the operating system for any pending events
- such as key presses and releases, joystick updates, mouse position
- updates, GUI user interaction, etc.
-
- Pause functionality can be implemented by skipping the call to S9xMainLoop
- and muting the sound output by calling S9xSetSoundMute (TRUE).
-
- Don't enter the main loop until a SNES ROM image has been loaded, or at
- least skip calling S9xMainLoop inside the loop until one is and make sure
- S9xReset is called instead before entering the main loop. The Mac port
- implements this technique by starting in pause mode and refusing to unpause
- until a ROM image is loaded.
-
- S9xMainLoop processes SNES CPU emulation, SNES screen rendering, DMA and
- H-DMA emulation, until emulated scan-line 0 is reached, then it returns.
- Now is your chance to process any system events pending, scan the
- keyboard, read joystick values, etc.
-
- If DEBUGGER compile-time support is enabled and the CPU emulation has hit
- a break point or single-stepping is switched on, or the DEBUG_MODE_FLAG is
- set in the CPU.Flags variable, then the S9xMainLoop routine returns early,
- allowing you to act on the event in some way. The Linux, DOS and UNIX ports
- respond to the DEBUG_MODE_FLAG being set by calling S9xDoDebug(), which in
- turn outputs the current instruction and loops reading commands from stdin
- and outputting debug information, currently via stdout. The debugger
- desperately needs rewriting to support a GUI interface, more descriptive
- commands and better error handling; maybe one day...
-
-Existing Interface Routines
----------------------------
-
-These are routines already written that you will either need to call or
-might find useful.
-
--> bool8 Memory.Init ()
-
-Allocates and initialises several major lumps of memory, for example
-the SNES ROM and RAM arrays, tile cache arrays, etc. Returns FALSE if
-memory allocation fails.
-
--> void Memory.Deinit ()
-
-Undoes the memory allocations made by Memory.Init.
-
--> bool8 S9xGraphicsInit ()
-
-Allocated and initialises several lookup tables used to speed up SNES
-graphics rendering. Call after you have initialised the GFX.Screen,
-GFX.SubScreen and GFX.Pitch values. If Settings.Transparency is false it
-does not allocate tables used to speed up transparency effects. If you
-want to provide the user with option to turn the effects on and off during
-game play, make sure Settings.Transparency is true when this function is
-called, it can later be set to FALSE.
-
-Returns FALSE if memory allocation fails.
-
--> void S9xGraphicsDeinit ()
-
-Undoes the memory allocations made by S9xGraphicsInit.
-
--> bool8 S9xInitAPU ()
-
-Allocates and initialises several arrays used by the sound CPU and sound
-generation code.
-
--> void S9xDeinitAPU ()
-
-Undoes the allocations made by S9xInitAPU.
-
--> bool8 S9xInitSound (int mode, bool8 stereo, int buffer_size)
-
-Does more sound code initialisation and opens the host system's sound hardware
-by calling the S9xOpenSoundDevice function provided by you.
-
--> void S9xReset ()
-
-Resets the SNES emulated hardware back to the state it was in at 'switch-on'
-except the S-RAM area is presevered. The effect is it resets the current game
-back to the start. This function is automatically called by Memory.LoROM.
-
--> bool8 Memory.LoadROM (const char *filename)
-
-Attempts to load the specified ROM image filename into the emulated ROM area.
-There are many different SNES ROM image formats and the code attempts to
-auto-detect as many different types as it can and in a vast majority of the
-cases gets it right. However, some ROM images have been edited by someone at
-some stage or have been mangled by the ROM copier that produced them and
-LoadROM needs help. Inparticular, it can't auto-detect the odd way in which
-some Super FX games have been mangled and needs to be told, via
-Settings.Interleaved2, that the ROM image is in that format, or that
-odd-sized ROM images have a 512 byte copier header.
-
-There are several other ROM image options in the Settings structure;
-allow the user to set them before calling LoadROM, or make sure they all
-reset to default values before each call to LoadROM.
-
--> bool8 Memory.LoadSRAM (const char *filename)
-
-Call this routine to load the associated S-RAM save file (if any). The
-filename should be based on the ROM image name to allow easy linkage.
-The current ports change the directory and the filename extension of the ROM
-filename to derive the S-RAM filename.
-
--> bool8 Memory.SaveSRAM (const char *filename)
-
-Call this routine to save the emulated S-RAM area into a file so it can
-be restored again the next time the user wants to play the game. Remember
-to call this when just before the emulator exits or when the user has been
-playing a game and is about to load another one.
-
--> void S9xMainLoop()
-
-The emulator main loop. Call this from your own main loop that calls this
-function (if a ROM image is loaded and the game is not paused), processes
-any pending host system events, then goes back around the loop again until
-the emulator exits.
-
-S9xMainLoop normally returns control to your main loop once every emulated
-frame, when it reaches the start of scan-line zero. However, the routine
-can return more often if the DEBUGGER compile-time flag is defined and the
-CPU has hit a break point, or the DEBUG_MODE_FLAG bit is set in CPU.Flags
-or instruction single-stepping is enabled.
-
--> void S9xMixSamples (uint8 *buffer, int sample_count)
-
-Call this routine from your host sound hardware handling code to fill the
-specified buffer with ready mixed SNES sound data. If 16-bit sound mode is
-choosen, then the buffer will be filled with an array of sample_count int16,
-otherwise an array of sample_count uint8. If stereo sound generation is
-selected the buffer is filled with the same number of samples, but in pairs,
-first a left channel sample followed by the right channel sample.
-
-There is a limit on how much data S9xMixSamples can deal with in one go and
-hence a limit on the sample_count value; the limit is the value of the
-MAX_BUFFER_SIZE symbol, normally 4096 bytes.
-
--> bool8 S9xSetSoundMute (bool8 mute)
-
-Call with a TRUE parmeter to prevent S9xMixSamples from processing SNES
-sample data and instead just filling the return buffer with silent sound
-data. Useful if your sound system is interrupt or callback driven and the
-game has been paused either directly or indirectly because the user
-interacting with the emulator's user interface in some way.
-
--> bool8 S9xFreezeGame (const char *filename)
-
-Call this routine to record the current SNES hardware state into a file,
-the file can be loaded back using S9xUnfreezeGame at a later date effectively
-restoring the current game to exact same spot. Call this routine while
-you're processing any pending system events when S9xMainLoop has returned
-control to you in your main loop.
-
--> bool8 S9xUnfreezeGame (const char *filename)
-
-Restore the SNES hardware back to the exactly the state it was in when
-S9xFreezeGame was used to generate the file specified. You have to arrange
-the correct ROM is already loaded using Memory.LoadROM, an easy way to
-arrange this is to base freeze-game filenames on the ROM image name. The
-Linux, UNIX and DOS ports load freeze-game files when the user presses a
-function key, with the names romfilename.000 for F1, romfilename.001 for F2,
-etc. Games are frozen in the first place when the user presses Shift-function
-key. You could choose some other scheme.
-
--> void S9xNextController ()
-
-The real SNES allows several different types of devices to be plugged into
-the game controller ports. The devices Snes9x emulates are a joy-pad,
-multi-player adaptor (allowing a further 4 joy-pads to be plugged in),
-a 2-button mouse and a light gun known as the SuperScope.
-
-Each call to S9xNextController will step the current emulated device on to
-the next device in the sequence multi-player, joy-pad, mouse on port 1,
-mouse on port 2, light gun then back to multi-player again. Defines
-allocating a number of each device type are in snes9x.h. The currently
-selected device is stored in IPPU.Controller if you want to give some
-feedback to the user. The initial value of IPPU.Controller (set when
-S9xReset is called) is obtained from Settings.ControllerOption based on
-currently enabled options.
-
-Some ROMs object to certain non-joy-pad devices being plugged into the real
-SNES while they are running, all Super FX games should only allow joy-pads to
-be plugged in because the Super FX chip and any other device would overload
-the SNES power supply. Tetris and Dr. Mario also objects for reasons best
-known to itself. For this reason there are switches in the Settings
-structure to enable and display the emulation of the various devices.
-
-const char *S9xGameGenieToRaw (const char *code, uint32 &address, uint8 &byte)
-
-const char *S9xProActionReplayToRaw (const char *code, uint32 &address,
- uint8 &byte)
-
-const char *S9xGoldFingerToRaw (const char *code, uint32 &address, bool8 &sram,
- uint8 &num_bytes, uint8 bytes[3])
-
-void S9xApplyCheats (bool8 apply)
-
-void S9xRemoveCheats ()
-
-void S9xAddCheat (uint32 address, bool8 cpu_address, bool8 sram, uint8 num_bytes,
- uint8 byte1, uint8 byte2, uint8 byte3)
-
-void S9xDeleteCheats ()
-
-void S9xDoDebug ()
-
-Interface Routines You Need to Implement
-----------------------------------------
-
-bool8 S9xOpenSnapshotFile (const char *base, bool8 read_only, STREAM *file)
-***************************************************************************
-void S9xCloseSnapshotFile (STREAM file)
-***************************************
-
-Routines to open and close freeze-game files. STREAM is defined as a
-gzFile if ZLIB is defined else its defined as FILE *. The read_only parameter
-is set to TRUE when reading a freeze-game file and FALSE when writing a
-freeze-game file.
-
-void S9xExit ()
-***************
-
-Called when some fatal error situation arises or when the 'q' debugger
-command is used. The Mac port just beeps and drops back to the GUI when
-S9xExit is called, the MS-DOS, Linux and Solaris ports all call exit () to
-terminate the emulator process.
-
-void S9xParseArg (char **argv, int &index, int argc)
-****************************************************
-
-void S9xExtraUsage ()
-*********************
-
-If you're going to be using the simple command line parser, when it
-encounters an unknown option it calls S9xUsage which is supposed to report
-all options the generic parse knows about (I haven't been keeping it up to
-date of late). S9xUsage then, in turn calls S9xExtraUsage which you
-implement to report any port-specific options available.
-
-void S9xGraphicsMode ()
-***********************
-void S9xTextMode ()
-*******************
-
-The SNES debugger calls these routines to switch from a graphics screen
-mode used to display the SNES game to a debugger screen used to display
-debugger output. If the SNES screen can be displayed at the same time as
-a text display, as would be the case when the host system implements a
-graphical window system, or you're not going to support the SNES debugger,
-then these routines should do nothing.
-
-On the X Window System UNIX/Linux port, these routines do nothing where as
-on the MS-DOS port they switch between a graphics screen mode and a text-only
-screen mode.
-
-bool8 S9xInitUpdate ()
-**********************
-
-Called just before Snes9x starts to render a SNES screen. The Windows port
-uses this call to lock Direct X screen area to allow exclusive access; on
-other existing ports its implemented as an empty function.
-
-bool8 S9xDeinitDisplay (int width, int height, bool8 sixteen_bit)
-*****************************************************************
-
-Called once a complete SNES screen has been rendered into the GFX.Screen
-memory buffer, now is your chance to copy the SNES rendered screen to the
-host computer's screen memory. The problem is that you have to cope with
-different sized SNES rendered screens. Width is always 256, unless you're
-supporting SNES hi-res. screen modes (Settings.SupportHiRes is TRUE), in
-which case it can be 256 or 512. The height parameter can be either 224 or
-239 if you're only supporting SNES lo-res. screen modes, or 224, 239, 448 or
-478 if hi-res. SNES screen modes are being supported.
-
-All current ports support scaling the SNES screen to fill the host system's
-screen, the many ports even supports interpolation - blending the colours of
-adjacent pixels to help hide the fact they've been scaled - and scan-line
-simulation - slightly darkening every other horizontal line.
-
-Don't forget that if you're just placing the SNES image centerally in the
-screen then you might need to clear areas of the screen if the SNES image
-changes size between calls to S9xDeinitDisplay. The MS-DOS and UNIX ports
-currently don't do this which results in junk being left on the screen if
-the ROM changes SNES screen modes.
-
-The sixteen_bit is just a copy of the Settings.SixteenBit setting and if
-TRUE indicates a 16-bit SNES screen image has been rendered, 8-bit otherwise.
-
-void S9xMessage (int type, int number, const char *message)
-***********************************************************
-
-I've started work on converting all the old printfs into calls to this
-routine. When Snes9x wants to display an error, information or warning
-message, it calls this routine. Check in messages.h for the types and
-individual message numbers that Snes9x currently passes as parameters.
-
-The idea is display the message string so the user can see it, but you
-choose not to display anything at all, or change the message based on the
-message number or message type.
-
-Eventually all debug output will also go via this function, trace information
-already does.
-
-bool8 S9xOpenSoundDevice(int mode, bool8 stereo, int buffer_size)
-*****************************************************************
-
-S9xInitSound calls this function to actually open the host operating system's
-sound device, or initialise the sound card in MS-DOS port.
-
-The mode parameter is the value passed in on the command line with the -r
-command line flag, assuming you're using the Snes9x parser. Its meant to
-indicate what playback the sound hardware should be set to, value 1 to 7.
-I think the real SNES sound chip playback rate is 30kHz, but such high
-playback rates take a lot of native CPU power to emulate. The default
-playback rate is 22kHz for the MS-DOS and UNIX ports.
-
-The stereo flag indicates if the user wants stereo sound. Again, stereo
-sound takes more CPU to power to emulate compared to mono sound.
-
-The buffer_size value indicates what sample buffer size the user wants,
-usually zero, meaning you should pick the value best suited to the current
-playback rate. Sound data is normally passed to the sound hardware in
-blocks, the smaller the block the less latency between the SNES game playing
-a sound and it being heard by the user. But if you pick a too smaller value,
-and you're having to periodically poll the operating system to see if it can
-accept more sound data, then the sound output will break up because other
-actions such as rendering the SNES screen can prevent you from polling the
-hardware often enough and the operating system runs out of sound data to
-play.
-
-The MS-DOS port uses a buffer size of 128 samples since the sound card
-sends an interrupt when more data is required which is acted upon promptly,
-where as the Linux and Solaris ports use a buffer size of 512 samples or
-more depending on the playback rate. Stereo and 16-bit sound both double the
-actual size of the buffer in bytes.
-
-uint32 S9xReadJoypad (int which1_0_to_4)
-****************************************
-
-This function is called to return a bit-wise mask of the state of one of the
-five emulated SNES controllers. Return 0 if you're not supporting controllers
-past a certain number or return the mask representing the current state of
-the controller number passed as a parameter or'ed with 0x80000000.
-
-Symbolic constants are defined in snes9x.h indicating the bit positions of
-the various SNES buttons and direction indicators; they're all in the form
-SNES_X_MASK where X is the SNES controller button name.
-
-The MS-DOS and X Window System ports record what keys are currently pressed
-and use that to build up a mask, the Windows port polls the operating system
-when S9xReadJoypad is called to find out what keys are pressed. All ports
-also implement host joysticks and joy-pads via this interface.
-
-bool8 S9xReadMousePosition (int which1_0_to_1, int &x, int &y, uint32 &buttons)
-*******************************************************************************
-
-Used by Snes9x to get the current position of the host pointing device,
-usually a mouse, used to emulated the SNES mouse. Snes9x converts the x and
-y values to delta values required by the SNES mouse, so the actual x and y
-values are unimportant, only the change in value since the last call to
-this function is used.
-
-Graphical windowing systems normally restrict the movement of the pointer on
-the screen, if you're porting to such an environment you might want to make
-a note of the change in position in the mouse since the last time you asked
-the operating system the mouse position, add this change in value to some
-saved x and y value, the reposition the pointer back to the centre of the
-SNES display window. The saved x and y values will be the values returned
-by this function.
-
-The buttons return value is a bit-wise mask of the two SNES mouse buttons,
-bit 0 for button 1 (left) and bit 1 for button 2 (right).
-
-bool8 S9xReadSuperScopePosition (int &x, int &y, uint32 &buttons)
-*****************************************************************
-
-void S9xSetPalette ()
-*********************
-
-void S9xSyncSpeed ()
-S9xUnixProcessSound
-void _makepath(char *, char const *, char const *, char const *, char const *)
-void _splitpath(char const *, char *, char *, char *, char *)
-
-
-Sound Generation
-----------------
-
-Settings
---------
diff --git a/source/docs/changes.txt b/source/docs/changes.txt
new file mode 100644
index 0000000..0f1027f
--- /dev/null
+++ b/source/docs/changes.txt
@@ -0,0 +1,2459 @@
+Snes9x 1.53
+
+- Rebuilt IRQ handling. (zones)
+- Improved overall timings, now Snes9x can handle events in
+ a opcode a little. (zones)
+- Improved screen interlace and sprite interlace supports. (OV2, zones)
+- Fixed Hi-Res pixel plotter. (BearOso, zones, OV2)
+- Fixed C4 for Mega Man X2's "weapon get" screen. (Jonas Quinn)
+- Fixed Super Buster Bros. graphics after reset. (Jonas Quinn)
+- Improved SA-1 support. (zones)
+- Added SA-1 CC2 support. (Jonas Quinn, byuu)
+- Fixed SA-1 NMI override mode. (zones)
+- Fixed Dual Orb 2 sound glitch. (byuu)
+- New APU timing hack, fixes various games that exhibit
+ problems with Blargg's SNES_SPC library. (OV2)
+- Fixed the problem that echo buffer breaks IPL ROM. (zones, OV2)
+- Fixed movie snapshot unfreeze inconsistency. (gocha)
+- Faster config file saving. (OV2)
+- Fixed BlockInvalidVRAMAccess config file option.
+ (windows port, unix port and gtk legacy config) (Jonas Quinn)
+- Remove POSIX dup and access calls, and rename qword to
+ fix compilation with Cell SDK. (BearOso)
+- Fixed PS3 version save state crash by using heap
+ allocation for soundsnapshot. (danieldematteis)
+- Fixed crash relating to double-closed descriptor. (BearOso)
+- Removed CPUShutdown speedhack, DisableHDMA and
+ DisableIRQ options. (zones)
+- Removed remaining outdated asm code. (zones)
+- JMA 64 bit support. (kode54, Nach, friedrich.goepel)
+- GTK+, Win32, Mac: Added optional Hi-Res blending. (BearOso, OV2, zones)
+- GTK+, Win32: Support for bsnes-style XML shaders. (BearOso, OV2)
+- Win32: Full unicode support. (OV2)
+- Win32: Restored OpenGL mode. (OV2)
+- Win32: x64 version. (OV2)
+- Win32: HLSL shader support. (mudlord)
+- Win32: Win7 jumplist synchronizes with recent roms list. (OV2)
+- Win32: Updated menu structure. (OV2)
+- Win32: Drag&Drop support for ROMs. (gocha, OV2)
+- Win32: Reworked movie-recording with size selection. (gocha, OV2)
+- Win32: Restored SPC save option. (OV2)
+- Win32: Fixed vsync in DirectDraw. (OV2)
+- Win32: Improved window position saving. (OV2)
+- Win32: Restored compile with DEBUGGER. (gocha)
+- Win32: Fixed various edge-case errors and/or possible
+ leaks. (Brian Friesen)
+- Win32: Config file option to always center image. (OV2)
+- Win32: Fixed "Turbo Down mode" hotkey assignment. (gocha)
+- Win32: Added and fixed Autofire for D-pad. (gocha)
+- Win32: Fixed aggressive soundsync wait. (OV2)
+- Win32: Added window size presets. (OV2)
+- Mac : Added pause and frame advance functions. (zones)
+- Mac : Now you can choose any folder for saving files. (zones)
+- Mac : Updated Music Box (mostly internally). (zones)
+- Mac : Fixed gliches in open/save dialogs on 10.6. (zones)
+- Mac : Fixed display configuration in windowed mode. (zones)
+- Unix : Fixed segfault and hang-up with -DNOSOUND. (zones)
+- GTK+ : Added ability to set specific folders for SRAM,
+ patches, snapshots, etc. (BearOso)
+- GTK+ : Fixed many permissions issues with config folders. (BearOso)
+- GTK+ : Updated compatibility with latest GTK+ and
+ GtkBuilder. Added experimental support for GTK+ 3.x. (BearOso)
+- GTK+ : Updated software output to use cairo and added the
+ ability to use bilinear-filtering with it. (BearOso)
+- GTK+ : Fixed issues where cheats wouldn't stay enabled. (BearOso)
+- GTK+ : Fixed focus issue when there is no window manager. (BearOso)
+- GTK+ : Fixed X Visual incompatibilities and expose
+ problems in the Xv and OpenGL outputs. (BearOso)
+- GTK+ : Fixed vsync with new X Server and NVIDIA drivers. (BearOso)
+- GTK+ : Added "Reduce input lag" option to OpenGL output. (BearOso)
+- GTK+ : Added a visual indication of the expected video
+ refresh rate for the currently selected sound input rate. (BearOso)
+
+Snes9x 1.52
+- IMPORTANT NOTICE: The structure of savestates (also known
+ as snapshots / freeze files) is incompatible with older
+ versions! Snes9x 1.52 cannot read the savestates created
+ by 1.51 or older. (zones)
+- Highly acculate SPC700 and S-DSP emulation. (Blargg)
+- Replaced APU emulation cores (SPC700 and S-DSP) with
+ ones provided by Blargg's SNES_SPC library. This renders
+ savestates incompatible with older versions. (BearOso, zones)
+- SPC7110 emulation. (byuu, neviksti)
+- Merged bsnes' SPC7110 emulation code. Note that the .rtc
+ file of Far East of Eden Zero is incompatible with older
+ versions. (zones)
+- Removed graphics pack support. It's no more necessary. (zones)
+- Replaced S-RTC emulation code with bsnes' one to keep the
+ good compatibility of .rtc files between the two
+ emulators. As a result, Daikaijuu Monogatari 2 now
+ outputs the .rtc file, and its .srm file is incompatible
+ with older versions. (zones)
+- Added savestate supports for DSP-2, DSP-4, ST-010 and
+ OBC1. (zones)
+- Added UPS support. (byuu)
+- Fixed DSP-4 AI problem. (Jonas Quinn)
+- Fixed invalid memory accesses in C4 and OBC1 codes. (zones)
+- Fixed invalid memory accesses in BSX codes. My mistake. (zones)
+- Fixed the read value of $213e, $4210 and $4211. (zones)
+- Fixed the writing of word values at the memory boundary. (zones)
+- Fixed the bug that the unnecessary SA-1 emulation
+ continues once any SA-1 games are launched. (zones)
+- Removed old color blending codes. (zones)
+- Removed too-old Snes96 and ZSNES snapshot support. (zones)
+- Updated command-line options. (zones)
+- Code cleaning. (zones)
+- GTK+ : Added a port of Snes9x to the GTK+ toolkit. (BearOso)
+- Unix : Reconstructed and simplified all the contents.
+ Some features have been removed to be simple, and many
+ options have changed. GTK+ port is recommended for most
+ of Linux users. (zones)
+- Win32: Now uses snes9x.conf to prevent problems with
+ modified meaning of settings. (OV2)
+- Win32: Removed broken OpenGL mode. (OV2)
+- Win32: Removed support for 8bit output. (OV2)
+- Win32: Reworked settings dialogues to accomodate the
+ new APU core and display settings. (OV2)
+- Win32: Updated defaults to use D3D and XA2 (better
+ Vista and Win7 support). (OV2)
+- Win32: Direct3D and XAudio2 support. (OV2)
+- Win32: Added Blargg's ntsc filter (three presets). (OV2)
+- Mac : Fixed corrupted screenshot on Intel Mac. (zones)
+- Mac : Fixed sudden abort in QuickTime movie export on
+ Intel Mac. (zones)
+- Mac : Changed sound settings for the new APU core. (zones)
+- Mac : Changed the default folder which Snes9x looks for
+ to 'Application Support' folder. (zones)
+- Mac : Changed folder names: 'IPSs' -> 'Patches',
+ 'BIOSs' -> 'BIOSes'. (zones)
+- Mac : Added Blargg's ntsc filter. (zones)
+- Mac : Internal changes for Leopard and Snow Leopard. (zones)
+
+Snes9x 1.51
+- Added DSP1 and SuperFX savestate support. (nitsuja)
+- Added screen state GFX to save states. (optional) (nitsuja)
+- Fixed desync when loading inconsistent state in playback. (nitsuja)
+- When playback reaches a movie's end, recording continues
+ instead of the movie suddenly closing. (after recording) (nitsuja)
+- can now record resets and mouse/superscope/justifier(s) (nitsuja)
+- Added same-line-comment support for config files. (nitsuja)
+- input display for all controllers (including peripherals) (nitsuja)
+- Win32: Now uses .cfg file instead of Windows registry. (nitsuja)
+- Win32: open ROM dialog bugfixes and speedup and facelift (nitsuja)
+- Win32: option to use standard file open dialog for ROMs (nitsuja)
+- Win32: maintain aspect ratio and bilinear filter stretch (nitsuja)
+- Win32: optional removal of the dreaded "black bar" (nitsuja)
+- Win32: Added EPX,EPX2,EPX3,HQ2X,HQ3X,TV3X,DM3X filters. (nitsuja)
+- Win32: Added hires support for Interlace and TV Mode. (nitsuja)
+- Win32: text removed from .avi output (optional) (nitsuja)
+- Win32: better directory management, customizeable (nitsuja)
+- Win32: Screenshot support is back. (nitsuja)
+- Win32: Netplay is back (but still not very good). (nitsuja)
+- Win32: Made OpenGL Bi-linear an advanced .cfg option. (nitsuja)
+- Win32: cheat search improvements (address, watch, SuperFX)(nitsuja)
+- Win32: Added non-modal ("active") cheat search option. (nitsuja)
+- Win32: new hotkey-config dialog and configurable hotkeys (nitsuja)
+- Win32: Fixed joystick config in input dialog. (nitsuja)
+- Win32: Fixed hires and extended height .avi output. (nitsuja)
+- Win32: various small GUI improvements (nitsuja)
+- Win32: Netplay fixes. (nitsuja)
+- "Fake Mute" desync workaround option for movies, until
+ all ports have deterministic sound. (Bisqwit, nitsuja)
+- Fix for save state blocks > 999999 bytes. (Bisqwit)
+- C4 games now save C4 data in save states. (DeHackEd)
+- Unix: Framework for high-speed seeking. Specify a frame
+ number in a movie, and the emulator will run at
+ maximum speed to that frame. Untested. (DeHackEd)
+- X11: Support for window exposure. When a window is
+ damaged due to overlay, being iconified, etc. it will
+ be repainted correctly. (DeHackEd)
+- Unix: parameter: -autodemo <filename> loads a movie for
+ playback on startup. Only the x11 code handles this
+ right now. (DeHackEd)
+- Unix: parameter: -oldturbo, the turbo button renders all
+ frames when fast-forwarding. (DeHackEd)
+- Unix: parameter: -upanddown, override U+D and
+ L+R protection. (DeHackEd)
+- Unix: parameter: -mute, currently linux only, blocks out
+ audio output from your speakers while still emulating
+ sound. Not fully tested. (DeHackEd)
+- Unix: parameter: -maxframes <target> during movie
+ playback, snes9x will exit when the target is hit. (DeHackEd)
+- Unix: parameter: -keypress shows to stderr and on-screen
+ the currently pressed buttons on joypad 1. (DeHackEd)
+- Unix: Stream dumping (NOT COMPLETE). With -dumpstreams,
+ raw video and raw audio are dumped to videostream%d.dat
+ and audiostream%d.dat, where %d increments on each CPU
+ reset, starting at zero. (DeHackEd)
+- Unix: Non-blocking sound on Linux. It makes seeking nicer.(DeHackEd)
+- Unix: Configurable sound device. (pierredavidbelanger)
+- configure.in now requires a sufficiently new version of
+ autoconf. (anomie)
+- Fixed slow versions of branch opcodes. (anomie)
+- Fixed the mosaic offset bug. (anomie)
+- No sorting by priority in C4 command 00 00. MegaMan X2
+ can go behind the legs of the intro stage boss. (anomie)
+- New RTO discovery, fixes Super Conflict: The Mideast
+ title screen. (anomie, byuu)
+- A 1->0 transition on $2100.7 causes OAM Address Reset. (anomie, byuu)
+- The final HDMA Indirect Address load is only weird
+ on the last channel of the scanline.
+ Touge Densetsu Saisoku Battle problem solved. (anomie, byuu)
+- Fixed BGnVOFS bug. Only HOFS needs ~&7 update. (byuu)
+- Fixed superfluous VIRQ triggers. (zones)
+- Fixed missing IRQ trigger just after the previous one. (zones)
+- Fixed missing IRQ while writing to $4200. (zones)
+- Fixed IRQ timing after WRAM refresh. (zones)
+- Fixed NMA timing after DMA transfer. (zones)
+- Fixed superfluous auto-joypad-reading. (zones)
+- Fixed missing WRAM refresh during DMA transfer. (zones)
+- Fixed DMA so that HDMA and any HC triggered events can
+ run during DMA transfer. (zones)
+- Roughly fixed the case that HDMA and DMA use the same
+ channel at the same time. HDMA kills DMA. Thanks byuu. (zones)
+- Changed initial DMA registers values. (zones)
+- Slightly modified APU execute timings. (zones)
+- Fixed APU I/O registers to get/set the proper value. (zones)
+- Blocked invalid VRAM writings, though you can turn off
+ this option due to Snes9x's inaccurate timings. (zones)
+- Omitted SPCTOOL, no one uses it. (zones)
+- Added Sufami Turbo support. (zones)
+- Added Same Game add-on cart support. (zones)
+- Fixed HiROM SRAM and DSP1-4 memory maps a little. (zones)
+- Improved mirroring. (Nach, grinvader, byuu)
+- CRC32 on BS dumps now follows uCONSRT standard. (Nach)
+- BS dumps now always run in NTSC mode. (Nach)
+- Unknown regions (generally betas) default to NTSC. (Nach)
+- Now support NSRT headers for setting up controllers. (Nach, nitsuja)
+- Unix: Fixed command line help output. (Nach)
+- Unix: Sound now defaults to 32KHz, Stereo, Interpolation
+ so Snes9x finally sounds like a real SNES by default. (Nach)
+- Win32: Saner defaults for movie record. (Nach)
+- Unix: Fixed crashing with mouse or super scope. (Nach)
+- Removed some weird code which was crashing Korean
+ League and its varients. (Nach)
+- Win32: Can now compile with MinGW. (Jonas Quinn, Nach)
+- Win32: Can now cross compile Snes9xw. (Nach)
+- Unix: SSnes9x compiles again. (Nach)
+- Win32: ZSNES C4 and SuperFX compiles once again. (Jonas Quinn)
+- Unix: Netplay Fixes. (Nach)
+- Unix: Netplay Improvements. (Fabianx)
+
+Snes9x 1.5
+- Pseudo-hires rendering flush, Old 2xsai endian fix (anomie)
+- Added 'oops' auto-snapshot support (anomie)
+- Fixed usage messages (Unix) (anomie)
+- Old split-ROM-in-zip bugfix (anomie)
+- ./configure fix for detecting libpng (anomie)
+- Fix "no PNG support" error message (anomie)
+- Anomie's control remapping patch (anomie)
+- Support for IPS patches in the zip file (anomie)
+- OBC1 savestate fix (Overload)
+- Fix turbo frameskip, X11 keyboard auto-repeat, VRAM reads (anomie)
+- Add some missing ifdefs (UNZIP_SUPPORT and ZLIB),
+ from AaronOneal (anomie)
+- Config file for Unix/X11 and Unix/SVGA (anomie)
+- CPU instruction fixes (mostly emulation mode & timing) (anomie)
+- Mode 7 fixes (anomie)
+- Rewrote the renderer. Enjoy! (anomie)
+- Correct-ish memmap boundary testing. (anomie)
+- Add support for saner directory structures under Unix (anomie)
+- Unix: Fixed detection of newer libpng (spotted by vapier) (PBortas)
+- Added 4-point gaussian interpolation and proper envelopes
+ many thanks to Brad Martin and TRAC. (zones)
+- Fixed several sound problems. (zones)
+- Fixed the memory access problem in C++ Super FX core. (zones)
+- Speed adjustment of C++ Super FX emulation. (zones)
+- Various timing fixes: NMI, IRQ, WRAM refresh,
+ cycles per line, HBlank start, etc.
+ Many thanks to byuu for much information. (zones)
+- Removed some game specific hacks. (zones)
+- Added partial Satellaview (BS) emulation. (Dreamer Nom, zones)
+- Added the Katakana font for onscreen messages. (107)
+- Updated JMA to v1 (Nach)
+- Unix: Fixed JMA options in config (Nach)
+- Unix: Removed --with(out)-asmcpu option in config
+ because the i386 assembler CPU core is out of date. (zones)
+- Unix: Changed the default settings in config. (zones)
+- Updated porting.html (porting.txt) in sync with 1.5. (zones)
+- Fixed buffer over/under flow due to incorrect logical
+ operator in S-RTC code (byuu)
+- Fixed HDMA flags bug. (byuu, anomie)
+- Fixed bugs causing crashing in Unix. (Nach)
+- Ported Snes9x to AMD64. (John Weidman, Nach, zones)
+- Completed DSP-1 code. (Andreas Naive, Overload, Nach)
+- Updated DSP-3 code. (Nach, z80 gaiden)
+- Updated DSP-4 code. (Dreamer Nom, Nach, z80 gaiden)
+- Overhauled BS detection. (Nach)
+- Improved Unix portability. (Nach, zones)
+- Fixed infiniti loop and invalid read bug in
+ C++ C4 core. (Nach)
+
+
+Snes9x 1.43
+- Win32: Disabled Netplay (funkyass)
+- Win32: Various fixes, including ROM dialog (funkyass)
+- Win32: New Input Config Dialog (funkyass)
+- Win32: added .avi output feature (blip)
+- Win32: fixed frame timings >100ms, added frame advance (blip)
+- Rewrote Unfreeze, renamed it S9xUnfreezeFromStream,
+ failing to load a freeze file no longer resets emulation (blip)
+- Fixed Unfreeze to restore IPPU.HDMA properly (blip)
+- Rewrote OBC1 code to match the real chip (Overload)
+- More updates the to DSP-1 code, fixes to projection (Overload, Andreas Naive)
+- Unix/X11: Rewrote keyboard setup code (Bisqwit)
+- Added movie recording+rerecording support (blip, Bisqwit)
+- Added -hidemenu CLI switch (funkyass)
+- fixed broken Win32 filters (lantus)
+- Added internal support for emulating the new-style SNES (MKendora)
+- Cleaned up many quirks of the cheat search engine (MKendora, Don Vincenzo)
+- Fix mosaic in hires SNES modes (Tokimeki Memorial) (MKendora, zones)
+- Rewrote Legend's hack, added another game to it (MKendora)
+- Optimized the Open ROM dialog (MKendora)
+- Rewrote the Seta DSP map (The Dumper, MKendora)
+- Began string isolation for the UI, eases translation (funkyass)
+- added -nopatch -nocheat, and -cheat CLI items (MKendora)
+- fixed a UI typo (funkyass)
+- fixed several C core stack ops in emulation mode (MKendora)
+- split emulation mode ops from native mode ops (MKendora)
+- Seta special chip emulation enhancements (Feather, The Dumper, Overload, MKendora)
+- code tweaks to the ST010 (Nach, pagefault)
+- fix some C/asm quirks and HDMA quirks (all my fault) (MKendora)
+- several timing hacks to fix games (lantus)
+- improved checksumming for odd mirrorings (MKendora)
+- Snes9x uses a standard zlib instead of a packaged one (PBortas)
+- Exhaust Heat 2 and regional ports are playable (Feather, The Dumper, Overload, MKendora)
+- Game Doctor dumps that are 24 Mbit are now supported by
+ a force option (MKendora, Nach)
+- SuperFx interleave format is now considered deprecated.
+ Support will be removed in future versions (Team decision)
+- made SuperFx interleave detection a compile option (MKendora)
+- added memory maps for slotted games (MKendora)
+- fixed a typo in the usage messages (MKendora)
+- fixed the bug that had nuked optimizations (The Dumper)
+- restored full speed optimizations in release builds (funkyass)
+- Added non-speed-hack version of color subtraction. (zones)
+- OpenGL info message font fix (zones)
+- APU timer fix (zones, Nach)
+- Fixed mouse offset in resized X11 window. (PhaethonH)
+- Fixed a (presumably) long-standing bug: Mode 6's BG is
+ depth 4, not depth 8! (anomie)
+- Unix: unmap all joystick buttons before applying -joymapX (anomie)
+- Win32: added a define to disable pausing when focus is
+ lost, NOPAUSE (funkyass)
+- Win32: Changed the default for Auto-save SRAM to 15 sec (funkyass)
+- Dreamcast: Added SH4 assembler (PBortas, Marcus Comstedt, Per Hedbor)
+- C90 and aclocal 1.8 warning fixes (thanks Ville Skytt) (PBortas)
+- Unix: AMD64 compilation fixes. (PBortas)
+- Added support for NSRT Team's JMA format (Nach, NSRT Team, funkyass)
+- Unix: Loading a zip file on binaries without zip support
+ will give an appropriate error message (Nach)
+- Unix: Added install target with proper --prefix handling. (PBortas)
+
+
+Snes9x 1.42
+- Added 8-bit rendering filters (funkyass)
+- Added Sanity Checks for the Display Dialog (funkyass)
+- New Layout for the Joypad Dialog, (funkyass)
+- Fixed that anoying Joypad dialog bug. Now check to see
+ if the axis exists before asking for the info form it (funkyass)
+- Added full POV support. (funkyass)
+- Fixed sram sizes for SuperFx games (Nach, MKendora)
+- Stopped saving sram for games with no battery (Nach, Mkendora)
+- Killed the gray line and slightly optimized Win32 GL (MKendora)
+- stack wrapping fix in C core (MKendora)
+- removed some dead hacks (Oda Nobunaga and Dezaemon) (MKendora)
+- fixed some DMA and HDMA modes (anomie, MKendora)
+- improved HDMA timing (anomie)
+- cleaned up load and deinterleave code (MKendora)
+- removed old UI DLL (MKendora)
+- new cheat dialogs (MKendora)
+- started Unicode preparation in Win32 UI (MKendora)
+- Implement odd sprite sizes, sprite priority rotation. (anomie)
+- RTO code that hopefully works. MK's #define is
+ "MK_DEBUG_RTO" to try to debug the RTO code. (anomie)
+- SDD1 decompression support for Linux. Also added a new
+ command line option -sdd1-pack. (anomie)
+- Added correct VRAM read logic. #define CORRECT_VRAM_READS
+ if you want it. (anomie)
+- removed the non-VAR_CYCLES path (MKendora)
+- changed access timing map to be address-based. (MKendora, anomie)
+- DSP-1 updates (Overload, Andreas Naive)
+- S-DD1 decompression support (Andreas Naive)
+- optimized S-DD1 code (anomie)
+- S-DD1 can use packs or decompression (MKendora)
+- More work on Exhaust Heat 2 (MKendora, Overload, The Dumper)
+- separated ROM detection from file reading (lantus)
+- fixed a mirroring bug in LoROMs (MKendora)
+- cleaned up some mapping issues (MKendora)
+- ST018 games now boot before locking up (Mkendora, Overload)
+- SA-1 state was not completely reset, crashed Marvelous (zones)
+- Removed sample caching. It caused problems, and was not
+ noticably faster. (MKendora)
+- Fixed interlace without breaking the displays for MK (anomie)
+- Fixed a PPU OpenBus hack (anomie)
+- Moved SPC7110 and S-DD1 regs to speed up the general case
+ of reading the $4xxx registers (MKendora)
+- altered Hi/Lo ROM detection to fix a few misdetects. (MKendora)
+- Implemented RTO flags. With MK's implementation of $213F's
+ interlace bit, we now pass the SNES Test Cart's
+ Electronics Test (anomie)
+- Fix sprite windowing bug (anomie)
+- Way back in 1.40 MK changed the Windows port to default
+ to a plain old joypad instead of the MP5. And then we
+ removed the hacks for games that dislike the MP5. So
+ we need to change the defaults elsewhere too... (anomie)
+- cleaned up the hacks section somewhat (MKendora)
+- removed some interleave hacks (MKendora)
+- fixed a bug in KartContents (MKendora)
+- transparency fix for Jurassic Park (lantus)
+- A hidden Win32 feature (MKendora)
+- Kludged Mark Davis until I get stable APU timing (MKendora)
+- Win32 renders overscan always, fixes some jumpy games (MKendora, lantus)
+- Fixed an FMOD bug (MKendora)
+- cosmetic tweaks (Everyone)
+- Fixed 2 special chip bugs in the C core (zones)
+- Added some sanity fixes to the C core, fixes MLBPA
+ Baseball for C core users (zones)
+- updated zlib source (includes 1.1.4-1 patch) (MKendora)
+- compiler warning fixes (PBortas)
+- Updated the SuperFx asm core (pagefault)
+- Kludged Unix compilation to produce working SuperFx (PBortas)
+ with the asm core.
+- Kludged VC to deal with optimization weirdness (MKendora)
+- Hacked Robocop vs. Terminator using Daffy Duck hack. Stops
+ flashing. (MKendora)
+- Added some defines to the asm core (MKendora)
+- Added possibility to take screenshots on Unix (PBortas)
+- Initialize the C SuperFx core better (PBortas)
+- Kludge a Japanese golf game until the APU timing is fixed (MKendora)
+
+
+Snes9x 1.41-1
+
+- Oops, in the asm CPU core i was stomping on %eax too
+ early, so register $4210 wasn't getting set properly. (anomie)
+
+
+Snes9x 1.41
+
+- Win32 controllers now stay the same between games (MKendora)
+- Win 32 Open ROM dialog fixes (MKendora)
+- Win32 Display dialog fixes (funkyass)
+- Win32 OpenGL ratio tweaking. (Reduces the gray line) (kode54)
+- Fixed Win32 superscope for those having issues (MKendora)
+- Generic accuracy fix in main SUperscope emulation (MKendora)
+- sprite bug fixed (gah! How'd we miss that) (anomie)
+- SPC saving compatibility fix (Caz and zones)
+- Window clipping update (anomie)
+- Mode 7 clipping fix (TRAC)
+- latching fix (anomie)
+- BS BIOS checksum and mapping fix (MKendora)
+- Working Uniracers hack (dma.cpp) (anomie)
+- HDMA Indirect Address fix for Romancing Saga 2 (anomie)
+- Better savestate hack, does it break anything? (anomie)
+- C4 C core fixes. Mostly Trapezoid (thanks Nach),
+ some s/short/int16/, some indentation. (anomie)
+- Damn, but the indentation in ppu.cpp was screwed up.
+ Killed some dead code too (twas commented forevermore). (anomie)
+- fixed a potential crash in S-DD1 logging (MKendora)
+- Improved accuracy of Hi/LoROM detection (~500 ROM test) (MKendora)
+- Hack for Moryou Senki Madara 2, don't call
+ SelectTileRenderer from DrawOBJS if BGMode is 5 or 6. A
+ real fix requires at least rewriting SelectTileRenderer,
+ or inlining a special version in DrawOBJS. (anomie)
+- DMA traces: add additional address info to reads too. (anomie)
+- Killed the old Borland Joypad dialog (funkyass)
+- Fixed issues with Dezaemon and CT, maybe others (anomie, MKendora)
+- Changed the internal snapshot key from \ to VK_F12 (funkyass)
+ Fixes issues with non-US keyboard layouts.
+- Fixed OAM reset to not occur during forced blank. (anomie)
+- Killed some dead OAM reset code that doesn't need saving. (anomie)
+- Unix/X11: Fixed screen jumping. CT enables overscan mid-
+ frame for only one frame, and we now update the rendered
+ screen height accordingly. Other ports are still broken. (anomie)
+- Unix/X11: Fixed possible TV mode crash. (anomie)
+- Fixed OAM reset timing (beginning of V-Blank rather than
+ end) for R-TYPE 3 (J). (anomie)
+- Unix/X11: Fixed OpenGL target (PBortas)
+- Unix/OSS: Fixed big endian sound (PBortas/ernstp)
+- Tweaked the About Dialog so its read-only and no scroll (funkyass)
+
+
+Snes9x 1.40
+
+- cleaned up a sound skipping code issue. Same as the
+ RTC issue (lantus)
+- re-fixed the invalid BRR header behavior twice (Lord Nightmare, FatlXception, Mkendora)
+- More BS mapping fixes. (The Dumper, MKendora)
+- Fixed Ranma Bun no 1 - Chonai Gekitou Hen (J) and
+ Street Combat (U). Interlace is not supported in the
+ non-Hi-res modes, as far as I can tell. (MKendora)
+- Also fixes Maka Maka (J). Frank Yang's report, and
+ anomie's code both provided clues to this one.
+- Removed special casing on setting 5c77 version to one.
+ This seems to be true for U and J units always. I need
+ it checked out on PAL... (neviksti)
+- Using SNEeSe's values for 5c78 and 5A22. Note we know
+ that the 5c78 version can also be 1 or 2, instead of 3. (TRAC, neviksti)
+- Added turbo buttons. Credit/blame for the design goes
+ to slack, Nave, Gogo, and myself. (MKendora)
+- fixed a bug in turbo (slack, MKendora)
+- Tried merging the behavior of Old $4200 with new $4200 (MKendora)
+- Made $4200's return value match what VSMC Explorer
+ showed on Fancia's SNES (MKendora)
+- Fixed a matrix multiplcation bug in ZSNES state loads (MKendora)
+- Fixed Dezaemon and Ys3 mode 7 (lantus)
+- Fixed H-DMA modes 5-7. Thanks to The Dumper for the
+ extra motivation needed. GunForce and Genocide 2 work. (The Dumper, MKendora)
+- Fixed BG3 Priority. I'm stupid. anomie had fixed it,
+ but lantus fixed it again, because I didn't use it. (anomie, lantus)
+- Added a Star Fox 2 hack, and an interleave skip (The Dumper, lantus, MKendora)
+- Cleared BS setting on load (lantus)
+- Fix for Mode 7 priorities. fixes F-1 Grand Prix (all 3) (anomie)
+- JANJYU GAKUEN 2 needs Multi-tap 5 off. (Frank Yang, MKendora)
+- HONKAKUHA IGO GOSEI: No multi-tap 5, allow mouse (lantus, MKendora)
+- Added a few missed conditional compiles (Nach)
+- disabled multitap 5 by default, added menu to enable (MKendora)
+- special thanks to anomie and lantus. One of them is
+ responsible for a bug fix I forgot already. (anomie, lantus)
+- Removed several Multitap5 disable hacks. (MKendora)
+- Added an SPC dumping upgrade from kode54 (kode54)
+- cleaned up some resource leaks (MKendora)
+- I forgot this since 1.39mk, but SPC700 flag fixes (anomie)
+- Mode 7 interpolation screen flip fix (anomie)
+- Updated SPC7110 code a bit, for compatibility (Daniel, anomie)
+- Changed RTC saving. (Byte exact to old format on Win32)
+ The submitted patch for "safety" doubled the file size,
+ so I had to write it in explicitly little-endian. (MKendora)
+- Removed the old hidden cursor (MKendora)
+- Applied a WAI correction from anomie. (anomie)
+- Added a patch for Pseudo hi-res (anomie)
+- Hacked around Word writes to $7F:FFFF. Thanks to lantus
+ and The Dumper for verification. (MKendora)
+- PPC compile fix? and debugger reversion (anomie)
+- Set defaults differently to improve sound quality. (MKendora)
+- Clear Force load settings after Init (lantus)
+- Made menu reset a soft reset. Fixed BL Sound Test & more (CaitSith2)
+- Fixed word writes to block bounds in asm core. (MKendora)
+- redone version of my bounds fix, only this one WORKS! (TRAC)
+- Thanks to TRAC for the AT&T syntax refresher! (TRAC)
+- Fixed screen saver disable (kode54)
+- Fixed OAM and sprite priority in the asm core (anomie)
+- Proper Interlace fix for mid-frame changes (anomie)
+- Fixed OpenGL to accomodate previous patch (MKendora)
+- Ported the "Settings" dialog to VC (MKendora)
+- Fixed ROM Info bugs (_pentium_five, MKendora)
+- Fixed non-stretched interlacing, but it's s.l.o.w. (anomie)
+- Superscope and Mouse need to be enabled by the menu. (MKendora)
+- Fixed HiROM sram reads in asm and C cores (anomie, MKendora)
+- Added Company 48 to the list. Thanks to _pentium_five_ (StatMat)
+- Set Super Drift Out's S-ram correctly. (Snes9xppSE Team)
+- Fixed NTSC timing. Helps ToP Intro greatly (kode54)
+- Added several entries to the company list, from uCON64 (Nach)
+- Lots more companies (StatMat, Nach)
+- Fixed Win32 Superscope support (NT kernel only?) (MKendora)
+- Added ZSNES OBC1 code ported from asm to C (sanmaiwashi)
+- Implemented Justifier emulation (neviksti, MKendora)
+- Fixed Rudora no Hihou's clip window bug (anomie)
+- Fixed Flintstones sprite issue (lantus)
+- Fixed sram mappings for Big Sky Troopers and
+ Taikyoku - IGO Goliath. Both map in bank F0 (MKendora)
+- Fixed a possible crash when switching audio settings (MKendora)
+- Added per-pack gfx pack configuration (MKendora)
+- Fixed glitches in DSP-1 games (Flintstones fix) (lantus)
+- Added delay to Superscope latching. Fixes X-Zone. (neviksti, MKendora, zones)
+- Added DSP-2 support (Overload, The Dumper, Lord Nightmare,
+ MKendora, neviksti)
+- Fixed Super Bases Loaded 2 (and J/K ports) DSP-1 seems
+ to ignore the A15 line in LoROM maps (MKendora)
+- Corrected $4200 again (The Dumper)
+- Corrected $2100, $2102, and $2102 read behavior (anomie)
+- Fixed Cancel on the Sound Options dialog. (MKendora)
+- Fixed the sound options dialog (Thanks, Quattro) (MKendora)
+- updated DSP-1 support to match chip better (Overload, neviksti, The Dumper)
+- added a few Ops to the DSP-4 routine (Nothing plays yet) (neviksti, The Dumper, Overload, MKendora)
+- added screenshot support (anomie, sanmaiwashi)
+- stubbed the ST010 chip in Exhaust Heat 2 (Overload, MKendora)
+- hacked around War 2410's lockup (pagefault, _Demo_, MKendora)
+- updated tests for type 1 ROMs (based on reset vector) (MKendora)
+- Emulation mode CPU fix (The Dumper)
+- Open Bus fixes (anomie)
+- Better Expansion port emulation (anomie)
+- More Open Bus fixes (Overload, anomie)
+- HDMA fixes (fix colors only in Full Throttle Racing) (anomie)
+- Migrated DKJM2 onto the Tales map (MKendora)
+- Tried to remove Dragon Knight 4 hack (LoROM sram fix) (MKendora)
+- Fixed ROM Mirroring for LoROMs (<= 32 Mbit) (MKendora, TRAC)
+- blocked wram to wram DMAs (neviksti)
+- fixed HiROM mirroring, too. Thanks TRAC! (MKendora, TRAC)
+- fixed C core RMW and Push ops to write in the correct
+ order, fixes Michael Jordan gfx. (anomie, Overload, MKendora)
+- set RDIO to start as 0xFF, fixes SuperFx games. (anomie, Overload)
+- New connect dialog (funkyass)
+- better conditional compile of FMOD (funkyass)
+- fixed screenshot code when libpng is not used (funkyass)
+- added portability fixes (zones)
+- fixed asm Pushes (anomie)
+- fixed asm LoROM s-ram decode (MKendora)
+- migrated DEZAEMON to standard LoROM map (MKendora)
+- fixed the Madara 2 OpenGL bug (key found in Rudra) (MKendora)
+- fixed asm RMW instructions (MKendora)
+- fixed ADC opcode (The Dumper)
+- added DSP-2 Op09 (The Dumper)
+- updated C4 C code (anomie)
+- updated C4 asm code (Nach)
+- Keep OpenGL in ratio (kode54)
+- Replaced many more Borland dialogs (funkyass, MKendora, Nach)
+- Added CRC32 to displayed ROM Info (Nach, MKendora)
+- Fix cheat support (The Dumper)
+- improved DMA timing (MKendora, Overload, The Dumper)
+- Fixed Mode 7 math, removed Dezaemon, Gaia, Ys 3 hacks (TRAC, MKendora)
+- Mode 7 flip fix (TRAC)
+- Multiple safety and initialization fixes (zones)
+- Platform safety fixes (PBortas)
+- Memmap cleanups (MKendora)
+- More preliminary work on special chips (The Dumper, Overload, MKendora)
+- Added color coding (MKendora)
+- Another HDMA fix (anomie)
+- added another known hack to the hacked games list (Nach)
+- ToP memmap changes (MKendora)
+- Checksum calculation changes (MKendora)
+- Special cased a few games for OAM issues (MKendora)
+- Reverted OAM reset to 1.39 timing (MKendora)
+- Reworked vram wrapping (zones, Mkendora)
+- Fixed $4210 and Super Professional Baseball 2 (Overload, MKendora)
+- Fixed APU RAM init (Overload, MKendora)
+- More support for Exhaust Heat 2 (not playable) (The Dumper, Overload, neviksti)
+- removed some debris from save states (MKendora)
+- fixed? Doom's save state bug (MKendora)
+- simple overdump detection warning (MKendora)
+
+
+1.39mk3b
+
+- Fixed the RTC detection. FINALLY done correctly (lantus, MKendora)
+
+
+1.39mk3a
+
+- neatened up the company table. (MKendora)
+- fixed a mistake in the ROM Info box (MKendora)
+- Added a Calulcated Size field to ROM INfo. (MKendora)
+- Added 3 more companies to the ROM Info table (MKendora)
+- Fixed BS detection (The Dumper)
+- Added a Legend-specific hack to get sound. I remembered
+ it being mentioned in the changelog. (Gary Henderson)
+- Unbroke the Star Ocean special cases (Trigger of Time, MKendora)
+- Company 255 is not Hudson-ZFE detects all Hudson games
+ without it, except a corrupt dump (StatMat, MKendora)
+- fixed a bug in the redone detection for the SPC7110 (CaitSith2)
+- 44Khz sound should be 44.1Kz. Changed, though you'll
+ need to re-set 44.1Khz to make it take effect. Not sure
+ if this affects non-Windows ports. (MKendora)
+- Added 32Khz playback (MKendora)
+- Inproved BS ROM mapping (_Demo_, The Dumper, MKendora)
+
+
+1.39mk3
+
+- Honkaku Syogi Fuunji Ryuou (J) fixed (force no multitap) (Frank Yang)
+ Also Fixed Super Castles (j).
+ Also fixed a bunch more. This dude e-mailed like 100 bugs
+ to my hosts, some already fixed in Snes9x1.39mk2, but
+ about 7 were clearly multi-tap5.
+- also fixed Dekitate High School. Error was in Japanese (Frank Yang, Tomato)
+- fixed 2 memory leaks (Aaron)
+- Dai Kaiju Monogotari 2 works as a 40 Mbit ROM. (MKendora, The Dumper)
+- Fixed the Flashback bug. Lots of info led to this. (neviksti, MKendora)
+ Thanks neviksti, The Dumper, TRAC, and FatlXception
+ for clarifying the behavior.
+- Fixed Sailor Moon Fuwa Fuwa Panic 2 to work with (neviksti, MKendora)
+ previous fix. It's a total hack, but it should sound
+ just like the old Snes9x did. neviksti strikes again!
+- Dirty hack to make 3 games deinterleave properly: (MKendora)
+ Wizardry 4, Mark Davis, and Honkakuha Igo Gosei(FX)
+ all work as well as the deinterleaved counterparts.
+ (The last is a hacked game, and you should get the
+ non-FX version)
+- Fixed Seima Jyuden Beasts and Blades. Another Multitap, (Frank Yang)
+ but for some reason, the hack requires the C cpu core.
+ Thanks to Tomato for taking a stab at the error message,
+ as well. It was too vague to be of use, he said. I
+ just tried it because it worked on other games.
+- Res Arcana fixed. Another Frank Yang report, another J (Frank Yang, MKendora)
+ error, but I can read kana well enough with a table!
+- Removed a Terranigma specific hack. Not sure, but the (anomie)
+ new behavior might have fixed Tin-Tin in Tibet's colors.
+- Dirty hack to work around a dirty hack. Both Yoshi's (MKendora)
+ Island (E) dumps should work now
+- Added the JumboLoROM memory map, Extends LoROM support (The Dumper, neviksti, MKendora)
+ to 48+ Megabits.
+- added an EXTBG fix, since iirc, TRAC is using it as well (anomie)
+ Does it actually fix anything?
+- Fixed crash in DSP Op06 (The Dumper)
+- Fixed a GUI error on my part (Trigger of Time)
+- Cleaned up some of the SPC7110 detection/size code. (MKendora)
+- Merged in XBox port changes to SPC7110 code (lantus)
+- Added a call to Memory.Deinit when exiting. (lantus, MKendora)
+- Many memory leaks fixed while chatting with lantus (lantus, MKendora)
+- Fixed that stubborn open/close leak (lantus)
+
+
+1.39mk2
+
+- hacked in Shien's Revenge (anomie)
+- fixed Orge Battle's green lines. (CPU source for DMA) (anomie)
+ - Looks interesting, and might apply to other DMA cases?
+- maybe "fixed" DKC's barrels? by treating $2001
+ as unmapped. The game worked before with a hack. (MKendora)
+- optimized SPC7110 slightly by removing extra setup work (MKendora)
+- Fixed DBZ 3 (Korean). S. Korea is, in fact, NTSC. (MKendora)
+- Fixed a hard-coded value in the SPC7110 (MKendora)
+- Added a Win port ROM Info dialog (MKendora)
+ - some companies aren't in the table I used.
+ If you encounter an Unimplemented company,
+ report it the the Snes9x development forum, with
+ the correct company and the number.
+
+
+1.39mk
+- SPC7110 support based on Dark Force's docs. (Dark Force, zsKnight,
+ The Dumper, MKendora)
+ Trust me when I say those guys deserve the credit more
+ than me. From what I'm told, Dark Force is the man
+ behind most of the reverse engineering, but they all
+ did a much harder bunch of work than I did following
+ their specs. It's plain and simple that these three
+ are the masterminds behind all SPC7110 support.
+
+ Dark Force for reverse engineering the chip (Extremely tough work!)
+ zsKnight for the original core, and probably other things
+ The Dumper for dumping the packs and doing hardware tests.
+
+ Also thanks to CaitSith2 for numerous bug reports
+ and a lot of bug fixes.
+
+- Theme Park hack removed, fixed via PPU latching (anomie, MKendora, TRAC)
+- WWF Wrestlemania hack removed (anomie, TRAC)
+- Strike Gunner hack fixed (anomie, MKendora, TRAC)
+- FF:MQ text fixed. May help other sprite issues. (TRAC)
+- Umi Hara Kawa Se timing corrected. (anomie)
+- S-DD1 packs load by the same rules as ZSNES (MKendora)
+- SPC7110 code builds in linux (Lord Nightmare, zinx)
+- Added The Dumper's DSP-1 updates (The Dumper)
+- SPC7110 is correctly displayed on load, RTC also noted. (MKendora)
+- Fixed a potential graphics problem (TRAC)
+ no known games fixed, but who knows?
+- Fixed Ballz3D (pagefault)
+- Re-fixed Ballz3D, via DSP op 0F (The Dumper)
+- included some of anomie's fixes. Many caused me grief,
+ so only Marko's Magic Football is intentionally fixed. (anomie)
+- finished zsnes save support, though I don't know how
+ well it will work with SPC7110 games (MKendora)
+- Added a new soundux.cpp again to fix some noise.
+ (Fixes the GW "fart track") (Lord Nightmare, info from Anti-Res)
+- Added 3 cache modes for SPC7110 games (MKendora)
+- Added new BRR decoder. Requires sample caching
+ and the Anti-Res decoder be disabled. (FatlXception, port by Lord Nightmare)
+- Added CaitSith2's RTC debugger. define RTC_DEBUGGER in
+ project settings to enable it. (CaitSith2)
+- SPC7110 per-game cumulative logging (MKendora)
+- other fixes that I've forgotten (sanma iwashi, TRAC, anomie, ????)
+
+- "I'm not worthy" thanks to the original SPC7110 crew (DF, zsKnight, and the Dumper)
+- Thanks again to the same people, because they deserve it!
+- thanks to The Dumper, Dejap, TRAC, and all the ZSNES crew for technical assistance
+- Thanks to most of the Snes9x mods for testing (no thanks to you, Raptor ;)
+- and thanks to TRAC and #mkendora for letting me vent at you.
+
+1.39
+- Added SDD-1 unknown graphics data logging at the dumper's request. A bit late
+ but might help with Street Fighter 2 Alpha's data dumping. Creates a
+ romname.dat file in the freeze file folder.
+- Implemented 16-bit texture support for OpenGL modes in Windows and Linux.
+ Had to support a new pixel format type to do it - RGB5551 (one bit of alpha)
+ which caused me some major problems - black was no longer always pixel value
+ zero!
+- Removed the Bump map OpenGL mode from the Windows port (didn't look so good
+ anyway and was slow).
+- Added a hidden novelty OpenGL mode (clue: a keyboard shortcut activates it)
+- Reverted back to FMod version 3.20 after reports that version 3.33 broke
+ AD3 support.
+- Implemented a better work-around for the broken select system call in the
+ Linux kernel - the original work-around was long-winded and stopped working
+ when I implemented OpenGL support under Linux.
+- Added the same speed-up hack to the OpenGL code that the Glide code already
+ supported. Basically, if your OpenGL implementation supports 16-bit textures
+ then OpenGL mode should be as fast, or faster than the 3dfx Glide mode.
+- Hopefully fixed Glide support.
+- Reverted back to the original colour blending code. The newer code, although
+ more accurate in most cases, had too many glitches and was slower.
+- Included multiple Japanese games fixes from Iswashi San.
+- Fixed a timing problem caused by a speed up hack that was affecting Top Gear
+ 300. No the game still isn't playable yet, but I noticed the problem while
+ investigating the DSP-4 chip used by the game.
+1.38
+- Added support for Star Ocean and Street Fighter 2 Alpha decompressed graphics
+ packs from dejap. Used a binary chop search rather than a linear search to
+ locate correct decompressed graphics more quickly - should help emulation
+ speed during later stages of the game.
+- Included OpenGL support into the Linux port and speeded up the Windows OpenGL
+ implementation slightly. The real speed up would occur if I could figure out
+ how/if 16-bit textures are supported in OpenGL because at the moment the
+ 16-bit software rendered SNES image must be converted to 24-bit before being
+ uploaded as a texture...
+- Included the latest ZSNES DSP-1 code. Now Pilotwings, SD Racer and Suzuka 8
+ Hours are playable. Aim For The Ace, Super Air Diver 1 & 2 and Syutoko Battle 94
+ are also playable, but with bugs. Thanks to zsKnight, _demo_, et al for all
+ their hard work.
+- Another Daffy Duck: Marvin Missions screen flicker problem worked around -
+ writing to the IRQ enable register shouldn't clear any pending IRQs, but
+ Sieken 3 seems to require this or else the game hangs. Special-cased Daffy
+ Duck for now.
+- An NMI emulation bug was triggering a Panic Bomberman World game bug,
+ crashing it. Basically, if a game enables NMIs after the normal trigger
+ point, the NMI should not trigger if the game has already read the NMI clear
+ register.
+- Panic Bomberman World requires SPC700 memory to be initialised to zero on
+ reset otherwise the game hangs when a tune finishes and another one should
+ start.
+- Added mouse pointer auto-hide to the Windows port. Much better than the turn
+ the mouse pointer into a black dot method I was using before.
+- Included the latest ZSNES Super FX code. Not sure if it fixes actually fixes
+ any games.
+- Added an offset hack for Strike Gunner to get the scrolling ground layer
+ to line up correctly - another offset-per-tile bug hacked around for now.
+- Arrr! Left in some debugging code in the last release that prevented all
+ games that need the slower SPC700 timing from working. Removed it.
+- Hmm. The broken cut-scenes in Deep Space 9 seem to indicate that I haven't
+ got the emulated clock speed of the 65c816 CPU correct yet. And not by a
+ little bit - a 9% too slow error. Hacked special timing for the game for now.
+- Added triple-buffering to Windows port - enabling double-buffering actually
+ enables triple-buffering if you have enough free video RAM, defaulting to
+ double-buffering if you don't.
+- Fixed another crash bug in the interpolated mode 7 code - if no scaling
+ was being used (either up or down) and screen repeat was enabled and the
+ screen was flipped horizontally, the routine would crash Snes9x. Was causing
+ Snes9x to crash during rock monster boss stage of Castlevania 4.
+- Oops. Got the initialisation of the default SNES screen width and height
+ round the wrong way - could cause a X Windows System error message on the
+ UNIX port after loading a ZSNES freeze file.
+- Included the unofficial Windows port emulation fixes for several games including
+ Kentouou World championship and TKO Super Championship.
+- Included Iwashi San's improved Anti Res. sound sample decoding routine and
+ updated the C version to match.
+- Included Anti Res. improved sample decompression code he sent me ages ago,
+ but for some reason I didn't include. Sorry. This version seems good enough
+ to leave enabled all the time.
+1.37
+- Added fix for Captain America's corrupt graphics - a ROM bug causes it to
+ read from what I thought should be an unmapped memory area, but it expects
+ the value returned to be zero.
+- Added code to support games that switch to the hi-res. SNES screen mode part
+ way down the screen while using the 3dfx bi-linear filter mode. The code
+ basically has to back out of the speed up hack it was using when the game
+ switches resolutions.
+- Fixed support for games that have mixed lo-res. (256x224), medium res.
+ (512x224) and hi-res. (512x448) all on the same screen - corrects the display
+ of Majin Tensei 2.
+- Added support for games that use sub-screen addition to the back-drop layer
+ while displaying hi-res. graphics - something I thought the SNES couldn't do
+ but the game Marvelous uses this.
+- Reworked the UNIX/Linux output image handling code: the image doesn't always
+ have to be scaled when hi-res. support is enabled, the PutImage operation
+ only updates the area of the screen it has to, the SNES image is now always
+ centred in the window/full-screen area and if the SNES image changes size
+ between frames, the old screen areas are now correctly cleared.
+- Fixed the corrupt graphics problem during the battle scene of Last Bible 3 -
+ it requires that previously unknown DMA mode 5 should just act the same as
+ DMA mode 1.
+- Fixed a nasty bug when H-IRQs were being reused on the same scanline - a logic
+ bug could cause H-DMA processing for that line to be skipped. Was causing
+ the bridge and the start banners to be the wrong colours in Top Gear 2.
+- Added Kreed's display processing modes to the Linux port, including his new
+ asm version of the Super2xSaI mode and the new software bi-linear filtering
+ mode.
+- Think I might have figured out the odd Mode 7 glitch problems the games
+ Illusion and Gaia and Chase HQ were having. My original fix was to mod the
+ centre X & Y values with 1024, but looks like the true fix is to mod
+ X + horizontal offset and Y + vertical offset with 1024 when screen wrapping
+ is enabled.
+- Disabled H-DMA'ing into V-RAM via registers 2118/2119. The game Hook
+ deliberately does this causing graphic corruption while dialog boxes are
+ displayed. Maybe the real SNES disallowed this and it was left in the game by
+ mistake? Not sure what effect the game was trying to produce because
+ disabling the emulation of this feature doesn't seem to affect the game at
+ all, other than stopping the corruption.
+ + Also fixes graphics junk problem on first screen of Bugs Bunny.
+- Added a 'region-free' timing hack for Power Rangers Fight - without it the
+ NTSC version was displaying badly glitching graphics; I'd already fixed the
+ PAL version.
+- Added true priority-per-pixel mode 7 support (the previous support was just
+ a hack to get the colours correct) - level 2 of Contra 3 used this feature.
+- The Japanese, German, French and Spanish version of Illusion of Gaia needs the
+ slow SPC700 timing.
+- Deleted the Breath of Fire 2 S-RAM hack for the hacker intro version -
+ according to reports it was causing problems for the non-hacked version.
+- Legend, the PAL version, never sets the sound master volume control - Snes9x
+ was defaulting this to off, I guess the real SNES must default it to full
+ volume; changed Snes9x. The NTSC version of Legend does set the master
+ volume level, but sets it to off just after the title screen. Hmm. The -nmv
+ command-line switch allows you to hear sound in this version.
+- Panic Bomber World was tripping an SA-1 emulation bug - the WAI instruction
+ emulation code was setting the 'waiting for interrupt' flag on the wrong CPU
+ causing the main SNES to skip an instruction when the next interrupt occurred.
+- Panic Bomber World, Bomberman 4 and UFO Kamen Yakisoban all need the slower
+ SPC700 timing.
+- Oops! The Super Formation Soccer 95 fix was causing Aero 2 to lock up. This
+ means I have no no idea what value the DMA in progress register should
+ represent. I've hacked it and made it toggle between 0 and $ff on each read
+ which gets both games working, for now...
+- The ROM de-interleaving code always assumed the blocks were rearranged based
+ on a power of two, but Francois found a copy of Soldiers of Fortune where
+ this was not the case. Corrected the code.
+1.36
+- Finally worked out why the menu items weren't being highlighted in several
+ ROMs, including Battletoads, U.N. Squadron and All Japan Pro Wrestling.
+ Two problems: its seems the SNES does halve the colour value result when
+ blending colours when only the fixed colour addition/subtraction is enabled,
+ but doesn't halve the result when sub-screen is being blended and its a clear
+ part of the sub-screen. The second problem was that I had an optimisation
+ that prevented the time consuming colour blending code from being called if
+ the colour being added/subtracted was black - adding zero to a number doesn't
+ affect the result, but not performing the side-effect of halving the result
+ does affect the final value...
+- Super Formation Soccer 95 requires that the DMA enabled register doesn't
+ always return zero, otherwise the game locks up.
+- Thanks to several people reporting a screen flickering problem in the
+ pseudo 3-d section of Jurassic Park 2 I've fixed a nasty problem in H-IRQ
+ handling code which could cause double-triggers or skip IRQs altogether.
+ With this fix I can now remove the special hacks for Ninja Warriors Again,
+ Chuck Rock and F-1 Grand Prix.
+- More games needing the slow SPC700 timing:
+ Zennihon Puroresu 2, Soulblazer and Robotrek.
+- The CPU idle time skipping code was skipping cycles during a software delay
+ loop in Itchy and Scratchy, causing screen flicker.
+- Looks like reading the value of register $2137 shouldn't clear a pending
+ IRQ - was causing screen flicker on Yoshi's Island.
+- Actraiser 1 & 2 both need the slow SPC700 timing.
+- Terranigma reads a sound channel's current sample output value and waits for
+ it to be zero before preceeding. I forgot to always return zero when a
+ channel was silent. This mistake was causing the game to lock up.
+ + Itchy and Scratchy and was causing the music to stop and samples to be cut
+ short in the Mario Early Years series.
+- Added a hack for Secret of the Evermore - at several points in the game, just
+ as the plane is about to land, it reads from unknown registers $4000 and
+ $4001 and, if it doesn't get the value its looking for, the game hangs or
+ displays corrupt graphics.
+- Silva Saga 2 was accidentally triggering a colour blending hack I put in
+ place Kirby Dreamland 3 and Kirby Superstar.
+- The ZSNES freeze-file loading code could leave a file open if the file wasn't
+ a valid ZSNES freeze file.
+- Super Punch-out requires certain DMA registers to be updated after the DMA
+ completes. Snes9x used to do that, but I must have accidentally left the code
+ commented out whilst investigating a different problem in another game.
+1.35
+- Added a recently played game list to the Windows port File menu so you can
+ quickly load up your favourite games.
+- Included IPS patching support based on code from Neill Corlett - just rename
+ the patch file to match your ROM image name but with a .ips extension and
+ copy it into your ROM or freeze-file folder.
+- Added John Weidman's and Darkforce's S-RTC, (Real Time Clock) emulation code.
+ The only game that seems to use it is Dai Kaijyu Monogatari II.
+- Included code from Nose000 for games with 128Kbytes of S-RAM. Now
+ Sound Novel-Tcool, Thoroughbred Breeder 3, RPG-Tcool 2 and Dezaemon are
+ supported.
+- The Windows port now has an option to make the 'turbo speed' button a toggle
+ button.
+- The optimised fixed colour addition/subtraction code was ignoring the colour
+ window. Thanks to John Weidman for pointing this out.
+- Added mode 7 and hi-res. hack for Dezaemon from Nose000 - the mode 7 hack
+ looks interesting (to me); I wonder if some other games would benefit?
+- Both Tales of Phantasia and Star Ocean need custom sound CPU timing. Hmm.
+ That's 4 ROMs now, there will be more... That means I still haven't
+ discovered all the major SNES timing quirks. :-(
+- Windows port now has an option to save the S-RAM data at any time.
+- Windows port saving SPC dumps now auto-increments the filename.
+- Added work-around for a Super Robot Wars Ex ROM bug - the game was checking
+ the wrong PPU register for end of h-blank. The game must have only worked by
+ chance rather than by design on a real SNES.
+1.34
+- Corrected the colour addition/subtraction and halve the result code not to
+ halve the result when only the fixed colour is used, i.e. the sub-screen is
+ clear. Discovered and fixed this awhile ago, but I accidentally reintroduced
+ the bug when adding some optimisations a few versions back.
+- Finally cleared the last of the offset per tile background mode bugs. There
+ was something odd about the tile at the left-hand edge of the screen that I
+ couldn't figure out - well now I have. Yoshi's Island level 6 boss screen,
+ Mario RPG mine cart screen and Jim Power title screen now all display
+ correctly.
+- Made reading blank areas of the SNES memory map return the middle byte of
+ the address - fixes Home Alone which tries to execute code in an empty part
+ of its memory map but only works because the real SNES seems to return the
+ middle byte of the address - $60 in this case, which corresponds to the
+ ReTurn from Subroutine instruction.
+- Added auto-cycle skipping disable for Earth Worm Jim 2 and several other
+ games that spool sample data using H-DMA as the sample is being played.
+ Improves some sound effects in these games.
+- Fixed joy-pad routines to only report up or left if down or right are also
+ pressed respectively. Works around a game bug in Empire Strikes Back in the
+ asteroid stage where the game crashes if both left and right are pressed -
+ something impossible to do on the original SNES game-pad.
+- Added custom SPC700 timing for Rendering Ranger R2 - the game now works with
+ full sound. No idea why it needs custom SPC700 timing.
+- The ROM type detection was broken for Treasure Hunter G and Test Drive 2 -
+ fixed the code so type 2 ROMs can be LoROM.
+- Adjusted the main CPU cycles per scan-line from 341 to 342 to give an exact
+ match for the timing required for Earth Worm Jim 2. All EWJ2 needs now
+ for perfect sound emulation is a method of synchronising the emulation
+ speed to the host hardware's sound card playback rate, oh, and a fast CPU!
+ The Linux port already has this but seems to be broken because games
+ play at double-speed when this option is enabled.
+- Some SPC700 code in Earth Worm Jim 2 seemed to prove that I had guessed the
+ clock speed of the SPC700 sound CPU incorrectly - out by almost a factor of
+ two, in fact. Changed the relative emulated clock speed of SPC700. Now
+ Chrono Trigger doesn't lock up at certain points anymore, the special SPC700
+ timing for games written by the Human Software company isn't required and
+ you can hear some more of the sound samples in Earth Worm Jim 2, etc.
+- H-IRQ triggering code was broken - if a ROM turned on H-IRQ but later turned
+ it off, Snes9x could continued to generate H-IRQs, crashing some games.
+- Added a generic test for Human Entertainment games - they need special
+ sound CPU timing to work. Gets Taekwon-Do working.
+- Disabled offset-per-tile mode for Theme Park; the world map screen is corrupt
+ with it enabled.
+- Yet more changes to the offset-per-tile backgrounds modes 2 and 4. Added
+ 64 tile wide screen support for Mario RPG's mine cart ride and fixed multiple
+ bugs with the handling of horizontal offset-per-tile used in Chrono Trigger's
+ fade in of the space ship.
+- New feature: Snes9x can now load ZSNES freeze state files! Just copy them
+ into the freeze file folder and Snes9x will load them when you load a freeze
+ file, but only if the corresponding native format Snes9x freeze file doesn't
+ exist.
+- Added memory map hack for Batman - Revenge of the Joker: its ROM header block
+ is in the wrong location and Snes9x incorrectly detected its ROM type.
+- Fixed an off-by-one-pixel clip window 2 bug when the window was set to clip
+ outside the window area; clip window 1 was already correct. Removed the bright
+ line bug at the left edge when the combat screen is appearing in Starfox and
+ the clip problem when text boxes zoom-out in Yoshi's Island.
+- Jim Power's title screen seems to prove that the per-tile offset data on
+ mode 2 isn't ignored for the left most tile as I originally thought.
+ Modified the code.
+- The recent timing changes highlighted another problem with Daffy Duck -
+ changed IRQ enable register to only clear pending IRQs if one has been pending
+ for several microseconds.
+- Speeded up the sprite data register handling slightly.
+- Finally got Aero the AcroBat 2 working, after many hours of investigation,
+ spread over several years - literally! Two problems. The SNES doesn't seem
+ to consider scan-line line zero to be part of the v-blank period even though
+ the line is never drawn and V-IRQs at the start of the scan-line have to be
+ delayed until a few microseconds into the line - Traverse: Starlight & Prairie
+ required this as well, so I removed the original, Traverse specific hack.
+ There's a problem with the in-game music that I'll investigate at a later
+ date.
+ - The in-game music problem just required ENVX emulation to be switched on,
+ off by default on the Linux port, on by default on the Windows port.
+- Fixed the mode 7 corruption problem on the title screen of Chase HQ using the
+ same trick as Illusion of Gaia - i.e. mod the mode 7 centre X & Y values with
+ 1024.
+- Fixed another crash bug in the interpolated mode 7 code - a portion of
+ the code was ignoring the screen flip value and the fact that X render
+ direction reversed if the screen was flipped horizontally. Was causing a
+ crash on the whale boss screen of Kirby Superstar.
+- Mortal Kombat 3 now auto-adjusts emulated cycles per scan-line work-around
+ a speech sample being cut short.
+- Added sample data register reading support to the sound DSP - somehow I
+ seem to have missed implementing this. Not sure if any ROM actually reads
+ the value.
+- Followed Sumire Kinoshita's suggestion and stopped clearing the ENDX flags
+ when the value is read, against my better judgement, and it does actually
+ improve speech samples in several games. Ooops! The Mortal Kombat series,
+ Magical Drop 2 and Metal Combat are the ones I've discovered so far.
+- WWF Arcade now auto-adjusts the cycles per scan-line value to work-around
+ a sound sample repeat problem.
+- Hmm. There's something about offset-per-tile mode I don't understand - WWF
+ Wrestlemania Arcade is getting corrupt graphics; not sure what effect the
+ ROM is trying to produce. Disabled offset-per-tile mode for the game for now.
+- Fixed Street Racer player 1 wobble problem during the soccer game by auto-
+ adjusting the cycles per scan-line value slightly.
+- Made Power Rangers Fight auto-adjust emulated cycles per scan-line to work
+ around a slight timing problem that causes an NMI to corrupt register
+ values that an IRQ handler is trying to update. Without it the scrolling
+ back-drop and fighter graphics are corrupt.
+- Illusion of Gaia seems to need the mode 7 centre X & Y values to be mod 1024
+ if the screen repeat flag is set. Fixes the island fly-over bug right at
+ the end of the intro but breaks a few other games. Hmm. Made it auto-switch
+ on for this game only.
+- Added memory map support for Radical Dreamers. Thanks to satellite hut master
+ for the information.
+- Made updates to the top bit of the sprite write address register be ignored
+ unless the low byte had been written to first. A ROM coding bug in
+ James Pond II requires this, otherwise it writes a junk byte value into the
+ main character's X position and Robocod wobbles around all over the place.
+- Reverted back to pre 1.31 way of initialising unknown register values -
+ Rock and Roll Racing was reading a junk register value and using the value
+ to set up DMA, which in turn was causing corruption on the player select
+ screen.
+- Added Star Ocean memory map - thanks zsKnight! The original ROM I was testing
+ was corrupt, no wonder I couldn't figure out the memory map myself! The game
+ still isn't playable, though, due to missing S-DD1 graphics decompression
+ (+ encryption?) emulation.
+- Started to dump some compressed data values from Street Fighter 2 Alpha in
+ the hope that one day someone will be able to crack the S-DD1's compression
+ algorithm.
+1.33a
+- C4 emulation wasn't being automatically enabled for Rockman X2 / X3 - the
+ Japanese versions of Megaman X2 / X3.
+- Fixed the Super FX plot table pointer that I accidentally broke while saving
+ 1Mb of workspace RAM - it was stopping all Super FX games from working.
+1.33
+- Noticed another problem with the CPU_SHUTDOWN code - Chrono Trigger locked
+ up during the intro but only when using the asm code CPU core. Found the
+ algorithm difference between the code and made the CPU match what the C
+ version was doing. Still not sure why it caused a problem in the first place.
+- Changed colour subtraction code to use Lindsey Dubb's newer version he sent
+ me some time ago but I 'forgot' to include. I say forgot, but I really put
+ off including it because, although it improves most games that use the
+ effect, it does result in one or two slight visual glitches.
+- Hacked in zsKnight's C4 emulation asm code - now both Megaman X2 and X3 are
+ playable. Still got to complete the reverse engineering of the i386 asm code
+ to C so other, non-Intel ports can have C4 emulation.
+- Shuffled the keyboard mapping a bit on the Linux port so now Tab key acts as
+ an emulation speed turbo button, `, # and ~ act as superscope turbo and
+ / acts as the superscope pause button.
+- Fixed asm CPU_SHUTDOWN code that I accidentally broke while trying to
+ optimise it! Thanks to all the people who noticed Snes9x's frame skipping
+ had changed between releases. Frames rates should be improved again for more
+ than 50% of games.
+- Re-enabled in-lining of the C SNES memory access routines, improves frame
+ rate by one or two on slower machines.
+- Optimised the asm 65c816 addressing mode emulation code a little.
+- Included some code changes making life easier for the Mac porter, John Stiles.
+- Added memory map support for Sufami Turbo using information supplied by
+ Nose0000. No idea if it works because I don't have the ROM.
+- Spent a few minutes trying to figure out the Star Ocean memory map so at
+ least the sound effects could be heard. But gave up after a couple of hours
+ due to laziness. If anyone knows the memory map details, let me know please!
+1.32a
+- The delay loading of the OpenGL DLLs on the Windows port was causing the
+ OpenGL initialisation code to fail. Reverted back to normal DDL loading but
+ with the side effect that Windows 95 users must visit the Microsoft web site
+ and download the OpenGL add-on before Snes9x will work for them.
+- Corrected the OpenGL bump-map display option - my attempt to get the
+ bi-linear OpenGL display option to work with Voodoo card's limited texture
+ size had broken the bump-map mode.
+1.32
+- Changed the Windows port to delay load the two OpenGL DLLs, so now they're
+ only loaded if you switch to OpenGL mode. The original version of Windows 95
+ didn't include the OpenGL DDLs, so Snes9x wouldn't even start on that
+ platform; now it should.
+- Added yet another sound buffer option to the Windows port - this time the
+ block size of sound data to mix. Some DirectSound sound card drivers only
+ report the play position moving in steps rather than continuous amounts and
+ Snes9x's default mix block size turned out to be smaller than this step
+ value on several cards.
+ Snes9x couldn't work out out where the true play position was accurately
+ enough resulting in broken, noisy sound output.
+- Modified the Windows frame timer code to use semaphores rather than events -
+ they should make Snes9x more reliable at not missing frame sync pulses when
+ Windows is busy doing background tasks.
+- Added SA-1 shutdown code - basically, Snes9x now stops emulating SA-1 CPU
+ instructions when the SA-1 enters an idle loop waiting for the main SNES
+ CPU to give it something to do. All SA-1 run much faster and smoother now.
+- Added multi-axis joystick/game controller support to the Windows port and
+ tweaked the dead-zone threshold position a little.
+- It looks like the SNES PPU was designed to support 128K of V-RAM but only
+ 64K was fitted; Snes9x wasn't wrapping all V-RAM address to stay within the
+ 64K limit causing a corrupt title screen on ReX Ronan - there will be others.
+- Added amend functionality to the Windows Cheat Entry dialog and added extra
+ text boxes for direct address and cheat value input rather than only being
+ able to type in a Game Genie or Pro-Action Reply code.
+- BS Suttehakkun2 was crashing just before start of play - the ROM was
+ performing a junk DMA that was corrupting RAM, crashing the game when it
+ went searching for a particular value.
+- F-1 Grand Prix requires IRQ triggering when IRQ scan-line register set to
+ current scan line, but Chuck Rock objects. Hmm. Chuck Rock seems to indicate
+ the CPU emulation is running too fast, but I can't see where the mistake is.
+ Special-cased Chuck Rock for now.
+- Optimised SNES DMA handling slightly - copying data to SNES V-RAM is now
+ significantly faster.
+- Windows Cheat search dialog was ignoring data type parameter in various
+ places which was causing problems when larger numbers were being searched
+ for.
+- Forced unknown PPU register reads to always return 0 - a coding bug in
+ Equinox shows that this is required. An earlier fix didn't work.
+- Puya Puya 2 & remix were objecting to an NMI being triggered when enabling
+ NMIs after scan-line 226, but Ys 5 seems to require this. Hmm. Added a hack
+ to support both games.
+1.31
+- Snes9x DirectSound code modified - the mixing block size is now always 10ms
+ for Windows 95/98/2000 and 20ms for NT 4.x, now there should be no need to
+ enable Sync Sound when a large sound buffer is required (helps emulation
+ speed). The maximum sound buffer length values have been updated to reflect
+ the smaller mixing block size.
+- Changed the DirectSound code back to use an offset from the play position
+ as the place to write new sample data into the sound buffer - on NT 4.x the
+ write position seems to vary randomly rather than being a fixed distance
+ in front of the play position as documented. Now I know why I used the play
+ position originally!
+- Changed the DirectSound code to fill the sound buffer at the write position
+ supplied by DirectSound, rather than just before the current play position -
+ should help reduce latency.
+- Added an auto-detect method for interleaved mode 2 Super FX ROM images -
+ well, not really auto-detect: if the game crashes and its a Super FX game,
+ Snes9x assumes its in interleaved mode 2, de-mangles the ROM image and tries
+ to run the game again.
+- Had to update the Snes9x Windows registry version number as the additional
+ diagonal settings make old registry settings incompatible.
+- Added diagonal keyboard controls to the Windows port, as requested by
+ several users.
+- Changed PPU code to return zero when reading non-existent registers - the
+ game Equinox relies on this due to an original game coding bug.
+- Included FMOD sound driver support to Windows port - people experiencing
+ broken sound or delayed sound, etc, might want to give it a try.
+- Tales of Phantasia - un-interleaved format ROM memory map changes to match
+ odd ZSNES format, now the hacked ROM works.
+- Changed NMI again. Made reading or writing to PPU register 0x4210
+ clear NMI pending flag again, without this Super Tennis does not work.
+- Changed NMI timing back to be the same as several versions ago and just
+ special cased Cacoma Knight instead - although kept the code to prevent
+ the re-triggering of an NNI more than once in the same frame.
+1.30
+- Forgot to force GUI surface to be displayed when some dialogs where popped
+ up - problem only happened on full-screen mode with triple or double
+ buffering enabled, or when using 3dfx mode. It appeared as if Snes9x had
+ locked up, but pressing Esc would pop down the hidden dialog.
+- Added a couple of options to the Settings dialog. Now its possible to
+ disable S-RAM auto-save which was causing Snes9x to write to the hard disk
+ every 30 seconds on some games, causing the occasional skipped frame.
+- Fixed Reset option which was accidentally broken when Netplay support was
+ added.
+- Added support for Dirt Racer - it leaves the Super FX chip running all the
+ time, so the default CPU emulation method never allocated any time to other
+ CPUs and the emulation seemed to lock up.
+- NMI timing changed again. Now an NMI can only be triggered once per
+ frame and enabling an NMI after the normal trigger scan line triggers
+ an NMI immediately. This fixes display glitches in Ys 5, Stargate and
+ Daffy Duck.
+- Fixed the WAI instruction to only 'wake up' once an actual NMI has
+ triggered, rather than just waking up when it should have triggered.
+ This fixes Battletoads, broken since version 1.29(ish).
+- Changed NMI again. Made reading or writing to PPU register 0x4210 not
+ clear NMI pending flag. Seems to allow all the NMI timing sensitive ROMs
+ I had on my list to now work without any special hacks. Illusion of
+ Gaia now works again.
+- Another NMI fix - cleared the CPU pending NMI flag at start of frame;
+ Battletoads intro was crashing without this. A long DMA was stopping the
+ SNES CPU so it couldn't and shouldn't respond to the NMI signal from the PPU.
+- Fixed Netplay problem when game didn't have any S-RAM and Sync Using Reset
+ was being used. An error dialog was displayed and the client would disconnect
+ from the server.
+1.30b#1
+- The Windows auto-frame skip code was broken - badly. It didn't re-sync a
+ timer value with timer events being generated, causing Snes9x to deliberately
+ stop and wait for an event when it didn't need to, slowing down the overall
+ emulation speed and increasing the number of frames skipped.
+- Improved the Windows cheat search dialog - its now possible to compare
+ against a value and more comparison functions are available.
+- Finally worked out why Voodoo 3 support was so buggy in Snes9x - the Voodoo 3
+ card generates a WM_DISPLAYCHANGE message when switching to Voodoo mode (the
+ Voodoo 1 and 2 cards don't); Snes9x thought that some other application had
+ changed the screen depth or resolution and tried to adjust its window to
+ match - triggering another WM_DISPLAYCHANGE message. No idea how the code
+ worked at all; it must have been only by chance and very dependant on the
+ driver version you were using!
+- Implemented Netplay on the Windows port - but its buggy as hell. I seem to
+ be having major Windows multi-threading problems. Comments I've seen seem to
+ suggest that Windows 95/98 don't implement true multi-threading; hmm...
+- Not happy with the current Netplay, so I scrapped it and tried again;
+ the protocol is much improved and not using select to control game timing
+ seems to have removed lots of the threading-type problems I was having.
+- Attempted to switch to just using Borland's C++ Builder to build the Windows
+ port - and failed, again. Although C++ Builder can build Snes9x from sources,
+ it can't then link in the asm CPU cores. I had hoped Borland might have
+ fixed this with their latest release - they haven't.
+- Several attempts to get Anti Resonance's super-fast sound CPU and sound DSP
+ code working in Snes9x, but all failed. Part of the problem was his code was
+ written using TASM and the object files it generated would only work under
+ Windows - but all my SNES debugging code was in the Linux port. Anti' fixed
+ that, and I then had some success getting his code working, but its just too
+ unstable at the moment for a main-stream release.
+- Included an option to use Anti Resonance's alternate sample decoding routine;
+ it can approximate the wind and noise sound effects heard in several Square
+ Soft games.
+- Thanks to Lindsey Dubb for the mode 7 bi-linear filtering code - it
+ generates a nice smooth image when a game scales the screen using the SNES'
+ mode 7, but you'll a fast machine if you don't want the frame rate to drop.
+- Thanks again to Lindsey Dubb, he improved the colour addition/subtraction
+ subtraction routines - they are just a little slower but now mostly perform
+ full 15-bit precision addition and subtraction rather than the previous
+ 13-bits of precision. Many more colour shades can be seen - look at the
+ improved shading on the Mario Kart or F-Zero track for example.
+- Added a reverse stereo option, for people with sound cards that swap the two
+ channels.
+- Added a sound config dialog to the Windows port - now you can access extra
+ sound options that have always been there, but just no GUI interface to
+ access them.
+- Fixed the 32-bit windowed support on the Windows port.
+- Adjusted the NMI timing by a few microseconds to get Metal Warriors working
+ again.
+- Added a few more sound playback rate choices. Most modern sound cards allow
+ any value to be used from a large range, rather than just a select few, may
+ be I ought to add text field so you could just type a value in?
+- Used Factory Setup 4 to build a new installer package for the Windows port -
+ just shipping a zip file was confusing novice users and many (mostly AOL
+ users) seemed to have an odd program mapped to .zip files, further confusing
+ the issue.
+1.29
+- Disabled the SPC700 noise feature simulation used by Chrono Trigger and
+ Final Fantasy 3 until I work out why its being triggered by sound effects
+ that don't use it.
+- Rewrote/reorganised the DirectX and 3D/fx handling code, now both are never
+ enabled at the same time in Snes9X. It might fix the crashing problems some
+ Window port users are seeing. Changing between DirectX and Voodoo 3D/fx
+ modes now requires Snes9X to be restarted.
+- Tracked down and fixed the Chrono Trigger black screen problem on the Windows
+ port: a rogue asm instruction was left in by mistake after some code edits -
+ it was only by chance that the code worked on the Linux port.
+- Added some SNES debug options to the Windows port, but disabled by default,
+ on the shipped version.
+- Clicking on the column headings in the OpenROM dialog in the Windows port
+ now sorts by that column; plus added some slight screen update optimisations.
+- Added an optimisation to graphics rendering: don't add or subtract
+ sub-screen from background layers, or clear the sub-screen, if SNES fixed
+ colour is black and no background layers are enabled on sub-screen, even if
+ ROM tries to enable translucency effects for every background layer.
+ Discovered Sonic was doing this, there will be others.
+- Forgot to enable auto S-RAM save on Windows port, oops!
+1.28
+- Warning dialog added to the Windows port - if a ROM is loaded from a
+ read-only directory, e.g. a CD, and the freeze file folder is set to be the
+ same as the ROM image folder, then a warning is displayed when the game first
+ starts.
+- The Windows port now supports 5 joy-pads - Snes9x always did support 5 but
+ the Windows port lacked the GUI option to enable and configure it.
+- Added an about dialog to the Windows port.
+- The Windows port now has a simple settings dialog, only one option so far -
+ changing the freeze file and S-RAM save directory; much better than having to
+ use regedit at least.
+- Added a new cheat search dialog, you can use it to find where games are
+ storing life counters, health levels, etc. and then add cheats that stop the
+ values from changing.
+- Added a cheat code entry dialog to the Windows port; now Game Genie,
+ Pro-Action Replay and Gold Finger codes can be graphically entered and
+ edited.
+- Added a master cheat codes on/off toggle, available from the Cheats menu
+ on the Windows port.
+- Extended the number of cheats per game from 10 to 75.
+- Changed cheat code to reapply cheat every emulated frame so if RAM is being
+ patched the cheat value is continuously applied.
+- Wrote some new cheat search code, the code won't be useful until I get around
+ to writing a cheat search dialog.
+- Added automatic cheat code loading and saving using the same file format as
+ ZSNES.
+- Rewrote large parts of the Snes9x cheat handling code ready for adding
+ cheat dialogs to the Windows port.
+1.27
+- Added a flag to only enable SPC700 noise 'feature' when Chrono Trigger or
+ Final Fantasy 3 are loaded - the conditions that I thought were necessary to
+ trigger the feature where sometimes being met by other games.
+- Added a simulation of the SPC700 noise 'feature' where some games, notably
+ Chrono Trigger and Final Fantasy 3, play samples that deliberately overrun
+ outside a 16-bit value, the SPC700 sound DSP then for some reason starts to
+ generate a type of noise sound which the games use to generate wind and
+ swish type sound effects. Thanks to ZSNES for some of the information.
+- Fixed another sound interpolation problem, thanks to Mikael Bouillot -
+ the initial value of the sample byte being played was not being set correctly
+ when processing fractional offsets.
+- Added auto S-RAM save option; S-RAM is automatically written to a .srm file
+ a few seconds (30 by default) after a ROM writes to it - useful for people
+ who were playing games long into to night, only to lose their progress
+ after a power cut or machine crash.
+- NMI delay code changed again - the fix for Cacoma Knight was breaking
+ Tuff E Nuff; it would seem delaying NMI until the start of h-blank to too
+ long, added a cycle counter instead.
+- Fixed yet another clip window bug - clip window was being incorrectly set
+ at no range if colour window was enabled but background layer clip window
+ was disabled (meaning layer should not be clipped).
+ Fixes the sunken ship level on FF5.
+- Worked out (by example) how to add keyboard accelerators to the Windows port,
+ now toggling full screen using ALT+Return works.
+- Added mouse-warp to the Windows port so the the cursor doesn't wonder off the
+ Window while SNES mouse emulation is enabled.
+- Improved 3dfx support on Windows port - load dialog doesn't drop out of
+ bi-linear mode and underlying window zooms to full-screen so its easy to find
+ and click on the menu bar with the mouse.
+- Added Mouse and Superscope SNES emulation support to the Windows port, use
+ '7' on the keyboard to select.
+- Windows cursor now hidden unless super scope emulation is enabled.
+- Windows port now has command line parsing - cheapo way of adding Game Genie,
+ Pro Action Replay cheat codes, disabling sound CPU emulation for the
+ corrupt copy of Star Fox 2, etc. Also allows ROM images to be dropped onto
+ the Snes9x icon.
+- Cacoma Knight seems to provide proof that Snes9x triggers the SNES
+ non-maskable interrupt (NMI) too early. Changed interrupt to trigger at the
+ start of the next horizontal blank period. Will have to watch for it
+ causing problems for other ROMs.
+- Added a translucency hack - when a ROM tries to create a stipple background
+ pattern by enabling pseudo hi-res. and not enabling a background layer on
+ one of the screens, Snes9x changes the effect to use transparency effects
+ instead (the real SNES can't do transparency effects with pseudo hi-res.
+ enabled). Now the water in Kirby 3 is translucent.
+- SA-1 CPU reset bug fixed, now Jumpin' Derby boots and plays but with major
+ graphics problems.
+- Fixed nasty asm SA-1 custom hardware read/write bug that was causing the
+ course map not to be displayed on Augusta Masters and Pebble Beach.
+- Added SA-1 character conversion DMA support for all SNES depths, now
+ Augusta Masters and Pebble Beach work.
+- Merged in minor code changes for Linux running on the Alpha processor. Thanks
+ to Sadruddin Rejeb for the changes.
+- Added four more auto-multi-player-adaptor-emulation-off presets based on
+ code from Mystagogus.
+- Added DirectX3D output image processing support to the Windows port... and
+ removed it again because it causes my desktop machine to lock up. Back to
+ the drawing board...
+1.26
+- Fixed memory leak that crept in when SA-1 support was added when loading a
+ game freeze file.
+- Added SPC dumping option based on code from Cyber Warrior X that he sent me
+ ages ago but I've just found again while looking for something else!
+- Merged in most of the Amiga PPC port source code changes into the main
+ source code tree.
+- Keying on a sound channel seems to clear its last-sound-sample-block-just-
+ played flag. Chaos Engine/Soldiers of Fortune needs this.
+- Add multi-thread support to the UNIX ports for sound playing - required in
+ the Linux port to work around a Sound Blaster Live driver bug and useful if
+ you have multiple CPUs in your machine to help spread the emulation workload.
+1.25
+- Added BS 24Mbit ROM memory map, for Derby Stallion 96 and Sound Novel-TCool.
+ No idea if it works. Thanks to Nose0000 for the info and code.
+- Corrected unzip code not to loop forever if an encrypted zip file is loaded -
+ an error is generated instead.
+- Changed relative SPC700 cycle length for Mortal Kombat 3 to fix sample
+ repeat problems - I wish I knew exactly how fast the SPC700 is clocked.
+ Maybe I should write a test ROM and run it on a real SNES?
+1.24
+- 3dfx speed hack back again, only disabled when Seiken 3 is loaded.
+- Some minor SA-1 speed ups added - the SA-1 instruction skipping code will
+ have to wait until I have more time.
+1.23
+- Corrected a SA-1 reset bug that reset the SA-1 RAM bank pointer back to block
+ zero but didn't clear the RAM bank register. Was causing Kirby 3 to crash.
+- Fixed a wave clipping problem with interpolated sound that was causing noise
+ on sound output when certain sound samples were played.
+- Fixed a bug in the sync-sound code that could overrun the sound buffer by a
+ few bytes causing clicks on the sound output.
+- The sound sample repeat bug that has plagued Snes9x ever since is was called
+ Snes96 finally bit the dust - Snes9x continued to play sample loops
+ even if the game dynamically updated the sample not to loop. Fixes the
+ stutter in the Mortal Kombat series and improves the sound from several games
+ that download sound samples in real-time as they are played.
+- Rewrote the code the handled the SPC700's 64 byte shadow RAM area to fix a
+ possible sample corruption problem with ROMs that stored samples that
+ cross the 64 byte start area.
+- Added code to allow ROMs to change the sample being played the next time the
+ channel loops or is keyed on - not sure if it fixes anything but seems more
+ correct.
+- Added a zero-frequency fix to the stereo sound mixing code that I'd already
+ added to the mono code some time ago.
+- Changed the code to set the end-of-sample flag just before the last block is
+ played, rather than just after. Seems to help improve the sound on some
+ games.
+- Sound sample start code now doesn't reset the channel's envelope volume level
+ to zero before starting the sample - helps reduce the clicks being heard when
+ a channel envelope volume level hadn't reached zero before being keyed on
+ again.
+- Changed initialisation of sample-end-register to 0 rather than 255 - seems
+ more logical now I've thought about it. Not sure if it helps anything.
+1.22
+- Finally fixed the corrupt copy of Donkey Kong Country not working problem -
+ Snes9x thought the ROM used the same memory map as Street Fighter Alpha 2.
+- Added explode, un-shrink and un-reduce decompression modes support to the
+ unzip code.
+- Fixed offset per tile bug that crept in after me trying to fix the Starfox
+ on-tilt bug.
+- Made some fixes to the C Super FX emulation code, enough to get most 'FX
+ games playable on the Mac port.
+1.21
+- Finally worked out how character DMA worked on the SA-1 and implemented a
+ hacky, slow version, but its enough to get the level up screens displaying
+ correctly on Mario RPG.
+- Incorporated ZSNES' new optimised Super FX asm code - had to track down and
+ fix a nasty memory overwrite bug in the code first to get it to work.
+- Changed sample mixing code to not automatically wrap offsets to
+ keep inside the sound buffer, external port code is now expected to do that.
+ Helped me fix a problem in the Windows port that prevented very large sound
+ buffers from working, which are required for some badly written sound card
+ drivers.
+- Corrected a bug in the SA-1 C code where incorrect processor emulation
+ functions where called if the code was compiled with in-lining turned off.
+- Fixed crash bug in Super Mario RPG on the level up screen - forgot to mask
+ the enable bit from the RAM bank register. Thanks to Christian Wolf for
+ sending me a freeze file which made it easy to find the problem.
+- Fixed a lockup bug in the window clipping code, if the ROM ever turned off
+ the sub-screen completely the clipping code would enter an infinite loop.
+ Fixes The Cartoon Addams.
+- Made the Daffy Duck NMI fix only enable when Daffy Duck is loaded - fix was
+ causing problems for Breath Of Fire 1 and 2.
+1.20
+- Windows port no longer sets DirectSound to exclusive mode, so its now
+ possible to hear sound output from Windows apps while Snes9x has focus.
+- Fixed the freeze file loading and saving on the Windows port.
+- More GUI settings are saved in the registry on the Windows port now.
+- Added 3D/FX image scaling/filtering support to the Windows port.
+- Added the TV mode from the Mac/Linux ports to the Windows port.
+- Incorporated Kreed's new output image routines into the Windows port that
+ fixes RGB555 display colour problems. Many thanks to Kreed.
+- New auto-frame rate timing code on the Windows port, stops the silly speed
+ up problems when the old code tried to 'catch up' after the emulator had
+ been paused.
+- Increased the DirectSound secondary buffer length on the Windows port to
+ hopefully fix all the static/broken sound output problems some people were
+ experiencing.
+- Altered the ZSNES Super FX asm code so the Windows port could use it - all
+ previous versions of the Windows port were shipped using the C Super FX
+ emulation code which is a lot slower.
+- Implemented interpolated and sync-sound options on the Windows port.
+- Added an image stretch option to the Windows port - stretches the SNES image
+ to fill the whole screen or the Window. Looks really good on my TNT card
+ since that chips seems to filter the image as it scales it.
+- Implemented Windowed mode on the Windows port.
+- Added special SPC700 cycle timing for Empire Strikes Back.
+- Fixed the missing polygon problem for Super FX games - thanks to zsknight
+ for the information.
+- Implemented SA-1 support required for Mario RPG, Kirby Superstar,
+ Paradius 3, etc. but since only a good image of Mario RPG exists, I could
+ only test that game.
+- Fixed a graphics clip window bug: inverting the area of a clip area that
+ only consisted of empty bands should become the full width of the screen;
+ Mario Kart's rear-view mirror display needs it.
+- Fixed mode 7 render code to use correct z-buffer when rendering onto the
+ sub-screen. Fixes Final Fantasy V title screen.
+- Added horizontal offset per tile support in the offset per tile modes 2
+ and 6, and switchable horizontal/vertical offset in mode 4. Fixes Chrono
+ Trigger in several places and Mario All Stars title screens.
+- Changed SPC700 relative cycle length to 14, needed for Stunt Car Racer.
+- Enabled immediate triggering of NMI if NMI enable flag set while scan-line
+ was on first line of v-blank. Needed to fix a background jitter bug in
+ Daffy Duck: The Marvin Missions.
+- Altered ROM load code to ignore corrupt ROM map type byte in ROM header,
+ preventing the code erroneously detecting what it thinks are interleaved
+ ROMs. Fixes EEK! The cat, Formation Soccer, the corrupt copy of Donkey
+ Kong Country, ...
+- Disabled IRQ re-triggering if V-IRQ registers set to the current line. Fixes
+ Chuck Rock.
+- Fixed missing sprites in Andre Agassi Tennis - writing to low byte only of
+ the sprite write address register seems to also clear the hi-byte.
+1.19
+- Games written by the Japanese software company Human seem to need special
+ SPC700 sound CPU timing, so the ROM load and reset routines now check the
+ software author company and adjust the CPU cycle length accordingly.
+ It gets Clock Tower, Super Fire Pro-wrestling Premium, etc working.
+- Added ROM check sum calculation and testing code - Snes9x can now detect
+ pure, corrupt or hacked ROMs.
+- Noticed a fast way to implement the SNES 4096 colour mode, so I implemented
+ it. Now the colours in ActRaiser 2 look correct.
+- Corrected a noise frequency error thanks to information from Takehiro.
+- Added a 'start in full screen mode' flag to the Linux port.
+- While debugging the new graphics code I thought of a fast way to implement
+ the SNES direct colour mode, tried it out and now the colours in Actraiser 2
+ are correct.
+- Blast, forgot about the colour window and fixed colour effects. The separate
+ sub-screen is back again, but all the other graphics speed ups are there.
+- Now I've got a z-buffer I keep finding other ways to optimise the SNES
+ graphics rendering - no need for a separate sub-screen, no need to clear
+ the sub-screen to the fixed colour, no need to waste CPU time on translucency
+ effects on hidden pixels, no need to completely clear the main-screen to the
+ back drop colour, etc., etc.
+- Implemented a software z-buffer and changed the SNES graphics rendering to
+ use it (required change for future 3D card support). Finally fixes the
+ sprite-to-sprite priority bug that some games suffer from. Also a big speed
+ increasing for some games (10 fps+), others are slight losers.
+- Added code to skip the rendering of completely transparent graphic tiles
+ rather than comparing each pixel to see if it is transparent; helps the
+ frame rate a bit on some games.
+- Added a fixed for Tetris & Dr. Mario - the game didn't like a multi-player 5
+ adaptor plugged in to the real SNES when being played, so turned off the
+ adaptor emulation for this game.
+- Added hack for Final Fantasy II - if sync sound isn't on, make attack rate of
+ 1ms actually 0ms (old v1.16 behaviour). Causes a slight click but its better
+ than samples being cut short.
+- Fixed a clip window area invert bug if the colour window was enabled on
+ on one window and the other window was being used to clip a background layer.
+ Fixes the finial (I hope) display problem with Gun Hazard.
+- Added code to intersect the clip window areas if both a colour window and
+ a background layer clip window were enabled at the same time. Required by
+ Gun Hazard.
+- Forgot to mark graphic clip windows as needing recomputing when the master
+ colour window inside/outside/on/off/main-screen/sub-screen PPU register was
+ updated. Was causing display problems for Gun Hazard.
+- Internal H-DMA execution accelerator pointer variables where not always
+ being recomputed when started H-DMA part way into a frame. Was causing
+ display problems for Gun Hazard.
+- Made H-DMA continue for one extra scan-line to fix a disappearing monster
+ problem in Dragon Quest 5. Thanks to Alex Jackson for the bug report.
+- Zoop seems to require volume envelope height reading by the sound CPU to
+ always return 0 when the channel is in gain mode.
+- The sound code was ignoring updates to the ADSR volume envelope rates while
+ one was in progress. Fixed that and now the bird song at the start of
+ Chrono Trigger sounds correct.
+- Had to disable the CPU shutdown code for loops reading the horizontal beam
+ position, it was causing problems for Star Fox. Still no polygons though.
+- Oops, sound DSP noise output was broken - accidentally deleted an important
+ line while removing debug code ready for the last release.
+- Added initial 3Dfx support to the Linux port - basically using the Voodoo
+ card as a bi-linear filtering, scaling blitter. Actually slightly slower than
+ TV mode, for non-scrolling images due to poor texture upload speeds to the
+ card, but the full-screen feature is nice and the speed doesn't drop as more
+ of the screen changes.
+1.18
+- Implemented a sync-sound mode where sound data gets generated in sync with
+ SPC700 instructions being executed. Finally the sound Williams Arcade
+ classics can be heard. Also helps slight sound timing problems in many other
+ games but doesn't fix Mortal Kombat 2 like I thought it would - its
+ sound routine programmers must have been on drugs or something!
+- Added interpolated sound - gives low frequency sounds much more bass similar
+ to a real SNES especially with the playback rate ramped up to 44KHz.
+- Added on-screen messages as various emulation options are toggled on and off
+ using the in-game keys.
+- Fixed a PPU register read bug with the sprite register write position. Thanks
+ to Takehiro TOMINAGA for the bug report.
+- Altered the auto-frame skip timing code to only wait and re-sync to the end
+ of frame when frames haven't been skipped. Again thanks to Takehiro.
+- Speeded up the colour addition and subtraction code using ideas from
+ Takehiro.
+1.17
+- Linux and UNIX sound code now driven directly from signal timer handler
+ rather than the timer handler just setting a flag which had to be polled in
+ the main emulation code. Slightly faster execution.
+- Fixed the crash bug in the ZSNES Super FX asm code with Vortex - the game's
+ polygons still aren't visible though.
+- Implemented bent-line increase and exponential decay and sustain volume
+ envelopes - they should match, or at least be very similar to the real SNES
+ sound DSP chip now.
+- It would seem ROMs can key on sound channels even if the channel hasn't
+ been keyed-off, Pac-In-Time requires it. Changed code to allow it.
+- Quick mod to ZSNES Super FX code to get Winter Gold working - it was already
+ working with the C Super FX code.
+- Added emulation of the extra 1/2 scan-line per frame on PAL and NTSC -
+ should help improve music speed emulation.
+- Worked around the click sound heard when ROMs use 0 volume envelope attack
+ rate.
+- Removed the 'check for IRQ already happened' H-IRQ position register setting
+ code - it was causing problems for Ninja Warriors and was not required by
+ F1 Grand Prix.
+- Fixed a bug in the new sound code - the sustain part of the
+ attack-decay-sustain-release volume envelope was being skipped if the
+ sustain level wasn't at 100%. The fix has helped some music notes from
+ being cut off early in a few games.
+- Added fix to Pro Action Reply support (again). Thanks to Paul Shoener III for
+ the original fix and Gil Pedersen for reminding me to apply it!
+- Finally fixed the Tales of Phantasia 'bum note' problem! The ROM set its
+ sample directory to the upper-most page and I forget to code for the hidden
+ 64 bytes of RAM, that appear when the boot ROM is switched off, when fetching
+ sample addresses.
+- Adjusted the relative cycle length between the 65c816 and the SPC700 slightly
+ to get Terranigma working again.
+- Oops, the emulated joypads 3 and 4 via the emulated Multi-player 5 interface
+ weren't working. Thanks to Steffen Schwenke for the bug report.
+- Optimised the echo sound code - by-passed the the FIR filter code if only
+ a pass-through FIR filter was defined by the ROM.
+- Modified V and H-IRQ register changing code to trigger an IRQ immediately if
+ V-IRQ is enabled and the scan-lines match and either H-IRQ is not enabled or
+ the electron beam position has already gone past the trigger point. Fixes
+ the screen flicker in F1 Grand Prix.
+- Modified the priority-per-pixel mode 7 code to use BG#1's clipping data if
+ the top bit of the mode 7 pixel is set. Fixes initial track drive-through
+ display in F1 Grand Prix.
+- Modified the sprite priority levels for the priority-per-pixel mode 7
+ display. Now the car can be seen in F1 Grand Prix.
+- Wrote a sound DSP register recording scheme which 'plays back' the register
+ changes in sync with the sound generation code. I'm bit disappointed, it
+ only improves the sound in a very few games... Scrapped the code, it actually
+ causes more problems than it fixes. Oh, well, another 3 weeks work wasted...
+- Fixed a SPC700 wake up problem for Lufia I - made the SPC700 also wake up
+ when the 65c816 read from one of the four comm ports.
+- Included lots of sound code speed ups and sound quality improvements
+ from Takehiro TOMINAGA - many thanks go to him.
+1.16
+- Fixed a case where the -forcelorom option didn't work - the case was
+ required for Formation Soccer which claims in its ROM header to use the
+ same memory map as Super FX ROM, it doesn't.
+- Pulled apart a real SNES using a crowbar (great fun), just to look at what
+ speed the SPC700 is actually clocked at for more accurate relative emulation
+ speed.
+- Implemented SPC700 cycle counting in the hope the improved timing would fix
+ Tales'; no such luck but at least the -ratio option is obsolete now.
+- Implemented executing SPC700 instructions during DMA, fixes BSZelda and
+ Goal lock up at start and music pausing briefly when ROMs do lots of DMA,
+ usually between game screens.
+- Scrapped the i386 asm SPC700 code - it was the cause of the music not
+ restarting after a battle in Chrono Trigger and FF3 and I didn't realise
+ because the bug had already occurred in the test freeze-file I had.
+ Thanks to John Stiles for pointing out that the Mac port didn't have the
+ missing music problem.
+- Fixed RGB subtraction bug on displays with only 5 bits for green, e.g. RGB555
+ displays. The GREEN_HI_BIT variable was always set to a value for 6 bit
+ green displays.
+- Added the SA-1 memory map, still a long way to go before any SA-1 game will
+ run.
+1.15
+- Jumped versions to keep in sync with the DOS port release.
+1.14
+- Improved 8-bit sound generation slightly, but it still sounds very poor
+ compared to 16-bit sound.
+1.13
+- Implemented the Tales of Phantasia memory map using the information supplied
+ by zsKnight. Had to also implement a de-interleave routine to work around
+ a ROM feature and Snes9x CPU instruction fetching implementation detail.
+- Added a frames-per-second on-screen display option.
+- Fixed the final glitch bug with the Mario Kart track display - the byte code
+ for the termination of the DSP1 raster command wasn't been recognised.
+- Disabled a NMI/DMA hack for Rise of the Robots, was causing problems for
+ Mario Kart and 'Robots wasn't working correctly anyway.
+- Optimised the mode 7 rendering a little.
+- Changed tile rendering code to use offsets into screen buffer rather than
+ direct pointers ready for z-buffer implementation.
+1.12
+- Changed V-blank NMI to occur immediately after a WAI instruction, Toy Story
+ required this.
+- Fixed reading of H-DMA line counter register, Top Gear 3000 needed this.
+- Ripped off large parts of ZSNES's DSP1 code (with _Demo_'s and zsKnight's
+ approval). Now Mario Kart works almost 100%.
+- Added a check to see if a vertical scan-line IRQ register change will cause
+ a H-IRQ later on the current scan-line. Pilot Wings needed this.
+- Fixed possible crash bug in clip window code when both windows had two
+ spans. Could actually cause Chrono Trigger to crash the emulator.
+- Fixed a lock-up problem with the C Super FX code, Star Fox and executing
+ a few 'FX instructions per scan-line (required for Winter Gold).
+1.11
+- Partially fixed the DOS netplay server - the server timer is running too
+ slowly and it doesn't deal with disconnects correctly yet.
+- Corrected the sound echo delay - it was varying with the sound playback
+ rate chosen by the user - it shouldn't have been.
+- Implemented DOS netplay code - DOS server code still not working though.
+- Removed all floating point calculations from the sound generation code.
+- Fiddled with the pitch modulation code - my guess is the output of a
+ channel that is used to modulate the frequency of another channel is
+ automatically muted by the SPC700 chip. Just a guess, but the wind from
+ FF3 sounds 'better' but far from perfect.
+- Optimised the tile palette index calculation.
+- Optimised the planar to chunky tile conversion code.
+- Fixed X11 port to always scale SNES image if hi-res. only (no interpolation)
+ support is enabled.
+- Added zipped ROM image support using Gilles Vollant unzip code and
+ some code that Ivar (Lestat) sent me a long time ago.
+- 65c816 asm RTI instruction was destroying the program bank in emulation mode,
+ the C code was already correct. Caused C64E to break.
+1.10
+- Finished NetPlay v1 - allows up to five networked machines to play
+ multi-player SNES games, one player on each machine.
+- Switchable full-screen mode added to Linux X11 port, some code and ideas
+ nicked from Maciej Babinski's original Snes9x XFree86 DGA Linux port, the
+ UAE Amiga emulator, plus lots of my own code.
+1.08
+- Bug fixes to C Super FX emulation - now Winter Gold works correctly again.
+1.07
+- More DSP1 work. Mario Kart is now playable! The character projection code
+ is still broken so the opponents and obstacles aren't always positioned
+ correctly on screen and you keep bumping into them, but I can still keep
+ coming first!
+- Started work on NetPlay support.
+- Decreased sound card DMA buffer size on DOS port to improve sound generation
+ and sound CPU synchronisation in some games.
+- Included Linux joystick driver patches from Vojtech Pavlik so the port can
+ use the new v1.x joystick drivers, again written by Vojtech Pavlik. Allows
+ use of Micro$oft Sidewinder pads, NES and SNES pads, PlayStation pads,
+ Gamepad Pros, etc.
+- Added halve-the-result colour subtraction.
+1.06
+- Extended code to allow support for multiple 16-bit screen formats,
+ switchable at run-time, rather just supporting one, selectable at compile
+ time.
+- Added XFree86 DGA Linux port - code from Maciej Babinski.
+- More fixes to the X11 image format conversion and setup code.
+- The asm SetByte routine wasn't wrapping writes to S-RAM correctly, allowing
+ some ROMs to think they were running on a copier and put up an error
+ screen. Thanks to Nu of #rom for the report.
+- Added 'TV-Mode' support (interpolation and scan-lines) to the DOS and
+ UNIX ports from code based on John Stiles work.
+- Added v-sync option to the DOS port.
+- Added fix to Pro Action Reply support, thanks to Paul Shoener III.
+- Added ggi support (untested) to Linux port using patches from
+ Alexander Larsson (alla@lysator.liu.se).
+- Added 16 to 24/32 bit image conversion routines to the UNIX X11 code.
+- The SPC700 OR1 instruction was broken. Thanks to Pyrgopolinices for the
+ report.
+- DOS port was having trouble splitting and joining path names - caused
+ problems when specifying the full path name of a ROM when the ROM image
+ was on another drive.
+- If a ROM reset the sound DSP and then turned on echo effects but kept
+ the same echo delay setting, then the echo effects could not be heard.
+ Thanks to madec@mclink.it for the bug report and freeze file that made it
+ easy to find the problem.
+- DOS port was always using stereo sound setting, if sound card
+ supported it, regardless of the user preference.
+- Linux port X11 port could crash if window was resized while transparency
+ effects were enabled.
+- The colour subtraction accelerator look-up table was slightly wrong, causing
+ one bit of red, green blue values to 'spill' into the next field.
+- Allowed colour window to cut a hole in the main-screen and show the sub-
+ screen underneath. The effect is used by Illusion of Gaia.
+- Added support for colour subtraction, with the halve-the-result flag
+ set.
+- Included DSP1 code from _Demo_. Now you can see the track in Mario Kart and
+ the ground in Pilot Wings - still can't play the games though due to other
+ missing commands.
+- Added an NMI hack to work around a code bug in Battle Toads: BATTLEMANIACS,
+ its only by chance that the game works on a real SNES - And disabled it
+ again because it causes problems for Chrono Trigger.
+- A frame skip of zero was actually still skipping one frame. Thanks to
+ Marius Fodor for the info.
+- And yet more X-OR window bug fixes - now the effects during some of the more
+ 'posh' spells look correct in Chrono Trigger.
+- Yet another window area inversion bug - off by one pixel on right-hand edge.
+- Forgot to put dummy start and end points for XOR window combination modes -
+ now Uniracers looks correct and Sailor Moon looks like it does on a real
+ SNES.
+- Window clip code was using wrong index into a 2-dimensional array when
+ the whole of the main or sub-screens were clipped.
+1.05
+- The master volume disable code was looking that the wrong variable!
+- Fixed crash bug in newer sound code if a ROM tried to start a sample
+ playing who's data went past the end of SPC700 memory. (Cannon Fodder)
+1.04
+- Fixed DSP1 ROM header detection bug.
+- More DSP1 work; still nothing works, although I know the multiply command
+ is correct because I've compared the results against a real DSP1.
+1.03
+- Oops, the multi-player 5 disable code change broke the multi-player 5 being
+ the default controller.
+- Implemented the colour window on the main screen - now Zelda's oval zoom
+ window displays correctly and Krusty's Super Fun House clips the left-most
+ 8 pixels as it does on the real SNES.
+- TERRANIGMA didn't like me returning a random value when it attempted to
+ read a channel's the current sample byte.
+- Hacked in initial support for mode 7 priority-per-pixel - the priority bit
+ doesn't actually change the priority of the pixel but the two games that I
+ know of that use the feature look OK. (Winter Extreme Skiing and the
+ intro of Tiny Toons Adventures).
+- Colour addition/subtraction code now uses RGB565 rather than RGB555
+ calculations - helps a little with the loss of the bottom bit of SNES
+ colour data.
+- DSP1 emulation started - nothing works yet.
+1.02
+- Switched to adding back drop colour rather than fixed colour when
+ sub-screen addition is enabled but there's nothing on the sub-screen.
+ Uniracers seems to need it. - DISABLED it again. Causes problems for
+ other ROMs and Uniracers itself on later screens.
+- Fixed XOR window logic combination mode and area inversion code, now
+ Uniracers works correctly.
+- Oops, if colour window and half colour addition/subtraction were both
+ switched on, area outside colour window was still being halved, it shouldn't.
+ Hacky fix at the moment until I implement the correct fix.
+- Fixed several bugs with the mosaic effect and 16x16 tiles and a few
+ possible background scroll offset bugs and the mosaic effect.
+- Optimised the sound sample generation code for cases when the SNES
+ sample playback frequency was higher than the sound card playback rate.
+- Fixed possible click sound when a sample was first started to be played.
+1.01
+- Corrected scan-line count for PAL games - should be 312 lines verses 262 for
+ NTSC. Was causing slow music on PAL games.
+- Added error correction code to the SPC700 timer update code - the
+ SPC700 timers are updated using the emulated h-blank handler which is
+ called every emulated 63.6 microseconds (15.720KHz) but the SPC700 timers
+ need to be updated at multiples of 8KHz, hence the error. Was causing
+ music to be played slightly too fast.
+- Switched back to using C SPC700 code - the old SPC700 asm code was lacking
+ several optimisations that the C version had. It also had multiple
+ speed hack cycle skipping bugs. Plus I hadn't even finished optimising
+ all the code from the last time I converted the C compiler output.
+- Optimised SPC700 memory access routines a little.
+- Disabled code that prevented ROMs updating SPC700 timer values while the
+ timer was running - it seems like it is allowed, even though docs on the
+ 'net I've seen say its not.
+1.0
+- Fixed SuperScope support.
+- Added hi-res. option to my DOS port.
+- Fixed 4, 6, and 8 button standard PC joystick support.
+- Changed some types the source code was using BYTE -> uint8, WORD -> uint16,
+ DWORD -> uint32 and BOOL -> bool8, types were clashing Windows typedefs
+ but sizes didn't always match.
+0.99
+- 8-bit double height and/or width tile rendering was missing every other
+ group of 4 pixels - screen pointer advance count was wrong.
+- Asm SPC700 emulation was ignoring the Shutdown flag - the result is its
+ not possible to turn off cycle skipping for the SPC700 emulation.
+0.98
+- CPU to ROM address decoding code rewritten - used by Game Genie cheat codes,
+ orginal code might have been the cause of some Game Genie codes not working.
+- Started to remove printf calls and replace them with calls to S9xMessage,
+ port code can then dicide what to do with message.
+0.97
+- Re-enabled decompressed sample caching, still has a possible click problem
+ but the sound code is a lot faster with it enabled. Added command line option
+ to disable it if required.
+- Added '7' key support to rotate through available controller options, in
+ the order multi-player5, mouse on #1, mouse on #2, superscope,
+ standard controller and then back to multi-player5.
+- Hi-res. (512x448) support fixed.
+- Mouse support completed - Lemmings 2 and Mario Paint working a treat.
+- More colour window fixes.
+- Fixed freeze game problem when ZSNES SuperFX code is being used -
+ ZSNES 'FX state was not being saved and restored.
+- ZSNES SuperFX asm emulation code plugged in to Snes9x.
+0.96
+- Looks like if the colour window is not enabled at all and the colour
+ window selector is defined to only allow colour effects inside the colour
+ window, then no effects should be visible.
+- Offset-per-tile rendering code didn't support width 64 screen size, which
+ Chrono Trigger used on its title screen.
+- Contra 3 seems to prove that defining the clip window area to be 'outside'
+ a window that covers the whole screen is not an area with no range.
+ - No it doesn't. It proves that I shouldn't have initialised the right
+ window edges to 255! Contra 3 enables clipping windows without first
+ defining their range.
+- Debug frame advance feature was being prevented from forcing the next
+ frame to be rendered by SyncSpeed which was being called after the
+ debugger returned to the main loop.
+- H-DMA code was allowing ROMs to manually start H-DMA during the v-blank
+ period, ROMs shouldn't be allowed to do this.
+- Asm code would not push the correct CPU status onto the emulated stack if
+ returning from an NMI immediately triggered an IRQ - fixes Mortal Kombat 1
+ and War of the Gems.
+- 'd' dump memory debug command was not preserving the CYCLES count.
+- C versions of SNES memory access code had same problem as asm code on the DOS
+ port except it didn't cause a crash just ROMs failed to work correctly.
+- Asm i386 code was using signed compares to check for special case memory
+ areas - it was causing crash problems on the DOS port which was sometimes
+ returning valid address values with the top bit set - i.e. they seemed
+ like negative values!
+- Changed event reschedule code to always allow h-blank start events, used to
+ disable them during v-blank period.
+- Added code to HDMA when end of visible lines reached.
+- Changed register 4212 code not to always return h-blank when in v-blank.
+- Clipping fixed colour addition to background area was off by one pixel on
+ the right-hand edge.
+- HDMA: Finally worked out how the real SNES operates when ROMs manual
+ start H-DMA during the frame - ROMs must set up the H-DMA line count
+ and address values before H-DMA is started.
+- Fixed the asm code to remove all hard-wired structure offsets - one offset
+ into the IPPU structure was wrong in the code because the structure had
+ changed size.
+- Added colour window support and allowed graphic window settings to be
+ different on the main screen and sub screen, just like a real SNES.
+- SuperFX LJMP instruction had bank and address values swapped.
+- Fixed possible memory overwrite problem because OBJList array was one
+ element too short.
+- Added AND multi-graphic window combo support.
+- ROM image memory allocation allocates an extra 32K of RAM, then moves the
+ pointer forward by that amount - stops the SuperFX emulation from accessing
+ unallocated memory, possibly causing a crash.
+- SuperFX emulation now stores sign and zero flags in separate variables so
+ the MERGE instruction can set flags correctly.
+- Added 65c816 instruction skipping to i386 asm code when 65c816 waiting in
+ a simple loop for some 'event' to happen e.g. end of frame NMI.
+- Finally fixed the APU instruction skipping problem with the i386 asm
+ code when the WAI instruction is used - caused slow music on some ROMs.
+- Offset-per-tile modes don't seem to support screen size - Mario All Stars
+ Super Mario 2 requires this on title screen. Doesn't seem to effect
+ Tetris Attack or Puzzle Bobble.
+- Changed SNES select and start keys from shift and control to space and
+ enter - allows shift-fn key to save game positions without the SNES ROM
+ also getting a select joypad button press.
+- Multiplayer5 support for controllers 3+ was broken for ROMs that used
+ automatic hardware joypad reading rather than reading joypads serially.
+- ResetPPU was not clearing tile caches and marking OBJ as need recomputing.
+- Cached OBJ positions and sizes were not being recomputed if ROM changed
+ global OBJ sizes during frame.
+- Fixed brightness multiplication problem on 16-bit code for green.
+- SPC700 emulation now uses one variable to store ZERO and NEGATIVE flags.
+- SPC700 emulation now only increments PC once at end of instruction.
+- New ROM type and interleaved detection code.
+- Reading sound DSP register ENDX also clears the value. The docs on the
+ 'net said that only writing to the register cleared its value. Fixes
+ sound in Zoop.
+- Fixed mode 4 colour palette problem on background #2 in tile-based graphics
+ code.
+- Fixed graphics mode 4, offset-per-tile support. Only one set of offset data
+ that is switchable between horizontal and vertical, unlike modes 2 and 6
+ which allow separate horizontal and vertical offsets per tile.
+- Modified the APU timer code again, if the timer is enabled, a write to the
+ timer target register is only allowed if a value hasn't been written yet.
+ Fixed Donkey Kong Country 1 and Earth Worm Jim 1 & 2.
+- Attack rate of 0ms changed from 1ms back to 0ms because of a group of ROMs
+ that change from attack mode to decay mode in real-time. Will change back
+ when I've added better SPC700 CPU and sound generation sync code.
+- Added support for ROMs set a new sound timer value while the timer is
+ enabled (EWJ 1 & 2).
+- Added support for ROMs that read the sound envelope height (MK1, MK2, etc).
+- ROMs writing to the H-DMA enable register during visible scan-lines were
+ restarting H-DMA for that frame causing random screen effect corruption.
+- Echo feedback seems to be after the FIR filter, not before as a diagram I've
+ seen suggests.
+- Sound pitch modulation added.
+- Memory access routines changed to pass a single 24-bit address rather than
+ the previous separate 8-bit bank and 16-bit address parameters.
+0.3
+- Updates to A-Bus address during a frame must not update H-DMA address.
+ Fixes Actraiser 2 and Pacman 2.
+- Removed sound volume mangling - with echo support enabled it doesn't seem to
+ be required.
+- Attack rate of 0ms changed to 1ms to help prevent click sound with sudden
+ start of a sample playing.
+- Sample caching of samples that looped using part of the original sample
+ created a click on the sound output. Caching disabled for the moment. Would
+ require 512K of cache RAM to fix sample caching.
+- Colour addition/subtraction support added - but still a little buggy in
+ places and very slow.
+- 16-bit colour support added.
+- Sustain sound volume was not being set if a sample using ADSR was started
+ with both the attack rate and decay rate set to zero - resulted in missing
+ sound samples on with some games.
+- Sound echo support added.
+- Sound channel mixing code was not completely clearing a channel's sound
+ buffer when a channel finished playing a sample.
+- Sound mixing code rewritten to use one buffer, rather than writing each
+ channel into a separate buffer then combining them into one buffer.
+- Memory access routines rewritten to use an 8K block lookup table rather than
+ dedicated code for each ROM memory map - it was getting difficult to support
+ the new types of SNES ROM memory maps becoming apparent.
+- Sound sample decoding wasn't decoding sound samples correctly if a
+ previously cached sample was only partially overwritten by the ROM as
+ opposed to being completely replaced.
+- Sound sample decoding wasn't clipping generated sample values correctly.
+- Changed H-DMA to start in the current frame only if enable register is
+ written to during v-blank, h-blank or while the screen is blanked.
+- The SPC700 seems to start executing instructions before the 65c816 -
+ shorter reset pulse? (NO - forgot the SPC700 executes instructions while DMA
+ is taking place).
+- ROMs that reset the H-IRQ position so another IRQ would be triggered on the
+ same scan-line where not supported - Super Off-Road: The Baj needs it.
+- $4212 bit 7 needs to go high at the end of h-blank at line 224 not at the
+ start of h-blank - Bubsy needs it.
+- Sample decoding routine could write to memory outside sample cache area if
+ address of block to decode was greater than $0x10000 - 9.
+- Walking mario can be seen on map screen of MarioWorld - needed sprite
+ priority rotation working. ROM sets bit 7 of $2103 then sets rotation in
+ $2102. Reset rotation at start of v-blank not at end.
+0.24
+- Fixed reading of DMA register values - now Ms Pacman works.
+- Saved sprite memory address being restored on the wrong scan-line - caused
+ corrupt sprites on at least one game (GANBARE GOEMON 2).
+- Screen colour palette not being updated if ROM only wrote to low byte of
+ palette register.
+- Possible memory corruption fixed if a ROM tried to write to an invalid
+ sprite address via PPU registers.
+- X11 port support quick load and save by pressing function keys to load or
+ shift + function keys to save.
+0.23
+- Added option to disable graphic window effects - T2: The Arcade Game doesn't
+ seem to like them.
+- Mode 7 "outside screen area" register interpretation fixed - now the
+ Actraiser map screen looks a lot better.
+- Old DMA code hack for Battle Toads: Double Dragon removed as it was no
+ longer required and it was causing problems for Ys III.
+- Lowered max volume level of 16-bit sound mixing code to help with sound
+ clipping problems is lots of SNES sound channels are playing.
+0.22
+- Crash bug fixed in mode 7 graphics windows code
+0.21
+- Fixed a noise channel volume bug - noise waveform was getting clipped.
+- Fixed 24bit X Window System server support on the Solaris port.
+- Sprites in priority level 1 on mode 7 were being drawn incorrectly behind
+ graphics screen.
+- BG 3 priority 1 tiles sometimes not drawn dependent on the $2105 bit 3
+ setting.
+- Added graphic window support the tile redraw code.
+- Added mosaic support to tile redraw code.
+- Tile redraw code was drawing one line too many on screen-splits.
+- Tile-based redraw code made more intelligent about when a background should
+ be displayed or not.
+- Added wrap within bank support to large DMAs just to support Rock 'n' Roll
+ racing.
+0.20
+- DMA routines added lots of special cases and removed most calls to GetByte,
+ using a pointer instead.
+- Multiple using PPU registers is now only computed when first byte of result
+ is actually read.
+- Sound enabled by default if compiled without DEBUGGER defined.
+- Tile redraw method made the default.
+- Fixed CPU_SHUTDOWN so SPC700 continues to execute even if main CPU is
+ "skipping" cycles waiting for an event to happen.
+- More command line options added.
+- Default cycles-per-scan-line to execute lowered to 90% from 100%.
+- +/- keys now work even if auto-frame rate adjust was enabled.
+- SPC700 emulation partially rewritten in assembler.
+- Asm 65c816 code change to use same speed up techniques as the C++ code.
+- Minor speed tweaks to the sound decoding and mixing code.
+- C++ SPC700 emulation changed to use same method as 65c816 emulation for
+ computing and storing emulated CPU flags.
+- Mode 7 code rewritten and several scrolling offset bugs fixed.
+- Lo-ROM S-RAM memory map bug fixed - now Uniracers works.
+- Multiple speed ups and changes to the tile and line-based redraw code.
+- Tile and line redraw code changed to cache converted tiles between frames.
+- Variable cycle length timing made compile-tile switchable.
+- C++ 65c816 emulation changed to use several opcode jump tables to avoid
+ a register size comparison test on most emulated instructions.
+- C++ 65c816 emulation changed how is computes and stores emulated CPU flags.
+- Fixed high frequency sound playback bug - the sample rate calculation was
+ blowing the range of an unsigned long.
+- Fixed V-RAM reading so DKC3, Addams Family, Aladdin and Pacman all work.
+- Fixed sound code so ROMs can change from ADSR mode to decrease mode - fixes
+ lots of ROMs.
+0.12 released
+- Added dynamic speed regulation.
+- TCALL vector calculation change from n to 15 - n.
+- Fixed crash bug if ROM writes to sound DSP register numbers greater than
+ 127.
+- Fixed DOS memory locked for interrupt code.
+- Added long name versions of command line switches.
+- Added command line switch for SPC700_SHUTDOWN code and WAI cycle skipping
+ code.
+0.1 released
+- All DOS memory is now locked from being swapped.
+- Fixed DOS port keyboard polling code - could get confused if a keyboard
+ interrupt happened while keys were being checked.
+- SPC700 ADC instruction never cleared Overflow or Carry flags!
+- Changed selection of playback speeds for Solaris port.
+- Sample caching code was broken - cached samples were never used.
+- Added code speed ups for ROMs that use a lot of DMA to VRAM.
+- More cpu code asm speed up.
+- Fixed 16x16 size tiles on tile-based redraw code.
+- Fixed sound gain-mode increase and decrease volume envelopes.
+- Added code to support ROMs that reuse sprites in the same frame.
+- Fixed processing of negative volume levels.
+- Fixed SPC700 EOR1 instruction.
+- Added SPC700 shutdown code to stop executing SPC700 instructions if in
+ a tight loop waiting for a timer or for the 65C816 to respond.
+- DOS playback rate was being forced to 16KHz by Allegro - fixed.
+- Fixed bug in SPC700 MOV1 C,bit, address.
+- Fixed a off-by-one loop sample pointer bug in MixSamples.
+- Added command line flags for cached-tile based drawing and sub-screen
+ background layers priority swapping.
+- NOPE, got encoding of the OR1/EOR1,AND1 range of correct originally -
+ got duff information from an "SPC700" programmer.
+- More SPC700 fixes: got the encoding of the OR1/EOR1,AND1 range of
+ instructions wrong - I guessed wrong originally.
+- Sample looping bug fix on mono sound mixing code.
+- Sound pitch value no-longer clipped to 14 bits - apparently FF3 needs this.
+- Followed Paradox's suggestion and changed graphics code to place sub-screen
+ background layers below main-screen background layers. Helps lots of games
+ that use sub-screen addition/subtraction - now you don't have to toggle
+ background layers on and off so often just to see hidden text, characters,
+ or maps, etc. Made it switchable.
+ Acts as a good intermediate solution until sub-screen addition/subtraction
+ is actually implemented.
+- Modified sound skipper code to return random values when ROM is stuck
+ waiting for the SPC700 CPU to respond - helps several ROMs that previously
+ don't work with the currently selection of APU skippers.
+- Improved sound mixing code so volume is not attenuated so much, giving
+ better results on 8bit sound cards.
+- Changed the frequency at which the joystick polling routine is called - now
+ called every-other frame rather than every 3rd frame.
+- Recompiled Linux and DOS ports with the Pentium optimising version of gcc -
+ gives a few percent speed increase.
+- Changed V-RAM increment count from 64 to 128 - apparently Final Fantasy 3
+ needs this as well.
+- Fixed sprite priority bug with Mode 7 - apparently Final Fantasy 3 needs
+ this.
+- Fixed a screen clipping problem with the S-VGA mode.
+- Fixed bug that had crept in with -m 2 S-VGA mode (Linux version).
+- Fixed S-VGA Linux version with sound enabled.
+- The SPC700 ADC (X),(Y) instruction was broken - with all these SPC700 fixes
+ now many more ROMs work with sound enabled.
+- The SPC700 Pop PSW instruction was not resetting the direct page location.
+- The SPC700 instruction MOV A,[DP+X] was incorrectly doing a MOV A,DP+X.
+- Got the SPC700 SETx and CLRx instruction encoding swapped around.
+- Fixed #define problem that was stopping DOS snapshot saving from working.
+0.72 released
+- Fixed the DOS filename handling - old Unix code was screwing up with ROM
+ filenames that contained backslashes (\) - the ROM would load but S-RAM
+ loading and saving would fail and the default filename for snapshots
+ wouldn't work.
+- This time really fixed Allegro library keyboard handling (DOS port); it
+ was missing key some presses/releases (was stopping Chrono Trigger
+ Left + Right + A button combo from working).
+- Added code to automatically remove headers off S-RAM save files with
+ 512 byte headers.
+- 32Mbit ROMs in interleaved format are now automatically detected and
+ converted.
+- Added -ss 3 sound skip method support to the asm version - now NBA Live '96
+ works again.
+- Added support for multi-part ROM images.
+0.71 released
+- Made libgz.so statically linked (again) on Linux port - sorry.
+- Made writing to $4200 also clear any pending IRQs. This finally allows
+ Battle Toads: Double Dragon, Spawn and Sieken 3 all the work with the same
+ IRQ logic (but Sieken 3 still gets stuck in sound download code).
+- Fixed a H-DMA wobble bug - some frames could randomly miss a line of
+ H-DMA causing the F-Zero screen to wobble, and slight text character
+ corruption on games like DKC3.
+- Interleaved format ROM images are now swapped in-place, without the need
+ for a temp 4Mb buffer (saves lots of disk swapping on a 16Mb Windows 95
+ machine).
+0.7 released
+- Fixed Allegro library keyboard handling (DOS port); it was missing key
+ some presses/releases.
+- DOS port had a different MAX_PATH value which moved the location of the
+ SRAM size variable when using the asm CPU emulation core. This, in turn,
+ caused the SRAM emulation to fail on the DOS port. Donkey Kong County 2 & 3
+ were reporting a ROM copier was connected to the SNES and refused to run.
+- Fixed assembler version of XCE - it was always leaving the carry flag
+ clear - caused Killer Instinct and Super Punchout to think a ROM
+ copier was fitted to the SNES and they all refused to run.
+- Fixed assembler versions of MVN/MVP - they weren't setting the data bank
+ register to the destination bank of the instruction.
+- Fixed joystick detection on MS-DOS port - a single 2 or 4 button joystick in
+ port 1 was being ignored if a second joystick was not present in port 2.
+- Fixed an uninitialised variable in graphics code - was causing random
+ missing scan lines on Mode 7 screens.
+- Joysticks now scanned every 3rd frame (joystick scanning is slow in the PC).
+- Double-whoops, Metriod 3 had stopped working in v0.6 - fixed it
+ (memory map bug).
+- Made bit 6 of $4211 set if v-counter == v-timer-position.
+- Made reading of $4200 read $4212 instead.
+- Adjusted DMA timing to always access ROM memory at slow speed - this seems
+ to fix Battle Toads.
+- Added code to automatically clear pending IRQs when the horizontal line
+ is no longer equal to the horizontal timer line - this fixes Seiken 3, it
+ now just gets stuck in the sound CPU wait code - oh well.
+- Moved NMI back to its original pre-0.65 behaviour, now Puzzle Bobble works.
+- More graphics speed ups - the code to render background tiles with their
+ priority bits set is only called if there are actual priority-bit tiles.
+- Changed default frame skip rate from 1 to 2 - its seems most people don't
+ bother to read the docs, so I thought I'll help them out a bit!
+- Speeded up Mode 7 graphics on games like F-Zero that rewrite the matrix
+ registers on each scan line using H-DMA.
+- Reorganised the graphics code and did a slight speed up - graphics code
+ will be the next thing to rewrite in assembler.
+- Rewrote CPU core in assembler for Intel platforms - gives a very noticeable
+ speed increase.
+- Fixed several problems with the APU sound CPU emulation - its now getting
+ stable enough to try and implement sound.
+- Fixed bug that caused 1 byte of S-RAM to be emulated when ROM didn't
+ expect any - it was enough to stop Street Fighter 2 and others from
+ working - thanks Lord ESNES.
+- The TXS and TCS instructions shouldn't set the Z and N flags.
+- Looks like MVP/MVN instructions should ignore accumulator size - change
+ code to always use all 16 bits and exit with accumulator set to 0xffff.
+- Whoops, accidently left some test code in which was causing the V-BLANK
+ flag, bit 8 in register $4212, to be miss-calculated.
+- Fixed palette in mode 0.
+- Speeded up graphics drawing a little by skipping groups of 4 pixels that
+ were all transparent.
+0.65 released
+- S-VGA and MS-DOS ports now have a VGA mode command line flag.
+- Improved the fading code - should be much more smooth now.
+- Fixed second joy-pad support and re-mapped keys and joysticks to actually
+ make a match between what my docs said and a real SNES (SNES docs I'd
+ seen were wrong!).
+- Fixed a bug in Relative Long CPU addressing mode.
+- Ported Snes96 to MS-DOS.
+- Snapshot loading and saving no longer uses external gzip binary.
+- Added support for registers at $21c2 and $21c3.
+- Made reading the software latch for the horizontal and vertical counters also
+ clear any pending IRQ.
+- Added sprite priority rotation.
+- Rewrote parts of the graphics routines to fix a sprite-to-sprite priority
+ bug.
+- NMI flag changed again - now back to being reset by reading $4210 but
+ actual NMI is delayed.
+- Made mode 7 background colour 0 transparent - this fixed several sprite
+ priority problems a few games where having.
+- Finally worked out how sprite "Object Name Select" works and emulated it -
+ this fixes many (if not all) of the corrupted sprites some games
+ experienced.
+- Delayed NMI activation for one instruction to give time for loops that
+ wait for bit 7 of $4210 to go high.
+- Special-cased line count of 128 on H-DMA to mean repeat previous data with
+ a line count of 128 and not just terminate H-DMA on that channel.
+- APU sound CPU emulation added - just need to debug the thing.
+- Fixed Overflow flag setting in ADC and SBC instructions - it was never
+ being set.
+- Rewrote how CPU instructions are fetched and how values are pushed and pulled
+ from the stack - it gave a very large increase in emulation speed.
+- H-DMA was being started one scan-line too late.
+- Added CG-RAM reading support.
+- Added "Full Graphic" V-RAM reading.
+- Speeded up C version of CPU emulation quite a bit - could speed it up a
+ little more before rewriting in assembler.
+- Fixed bugs in 16x16 tile drawing on 2bit and 8bit deep screens.
+0.6 released
+- Speeded up 16x16 tile background rendering by removing a temp tile buffer
+ it was using. The speed up also fixed a vertical scroll bug.
+- Fixed slight window clipping on 16x16 tile backgrounds.
+- Added automatic PAL/NTSC mode switching.
+- Fixed background and sprites so only visible if on main-screen or
+ on sub-screen under correct circumstance.
+- Fixed lockup bug in DMA.
+- Stopped NMI flag from being reset by reading $4210 - was causing a couple
+ of games to get stuck.
+- Whoops, got horizontal and vertical Mode 7 flip bits around the wrong way!
+- Fixed MIT shared memory pixmap support for X11 version (it was always turned
+ off).
+- Fixed minor bug - first sprite in priority group was drawn twice. Didn't
+ cause any visual bugs, it just slowed down redrawing a little.
+- Fixed DMA bug - transfer byte count should be 0 after DMA has finished.
+- Fixed a scaling bug if width < height.
+- Interleaved ROM image support added.
+- 16bit and 24bit X11 server support added - with scaling.
+- Added window scaling on X11 version.
+- Partial clip windows added - the only window overlap option implemented at
+ the moment is OR, it seems it good enough for all the ROMs I've tested
+ it with.
+- Partial Mosaic effect added (pixels only growing vertically).
+- Missing Mode 7 "outside screen area" option added.
+- Fixed mode 7 screen wrap "outside screen area" option.
+- Used new event processing to finally fix H-IRQ so it triggers at the
+ correct position on the scan line.
+- New event processing added.
+- Linux version now statically links libgz.so (sorry).
+0.5 released
+- Linux S-VGA version changed from using a 320x240 ModeX screen (slow) to a
+ 256x256 chunky screen (faster) - thanks to Phillip Ezolt (pe28+@andrew.cmu.edu)
+ for information on how to do this.
+- Mode 7 screen flipping added.
+- Included Snes97's CPU emulation code into Snes96. Didn't fix any bugs but
+ slowed down the emulation some what and I couldn't compile it optimised
+ because it was so large - so I removed it again.
+- Added a few extra features available via the keyboard.
+- Fixed a H-DMA transfer mode - bad documentation.
+- Fixed H-DMA indirect addressing (it was using the wrong CPU memory bank).
+- The Linux slow down bug is my crappy laptop enabling battery saving features !
+- Changed graphics code to perform true line-by-line screen updates.
+- Fixed sprite drawing bugs.
+- Ported Snes97's graphics code to Snes96.
+- Fixed memory map for HiROM save RAM area.
+- Fixed HiROM memory map - now Killer Instinct and Donkey Kong County work !
+- OK the slow down bug is just actually my laptop trying to save battery
+ power by slowing the CPU clock!
+- The Linux slow down bug shows itself on DOS emulators running under DOSEMU
+ so it must be a kernel problem (or feature).
+- Fixed H-DMA (again) to be complete emulation - all I need now is line-by-line
+ screen update...
+- Fixed DMA to not copy too many bytes if byte count was not a multiple of
+ the transfer mode quantity (caused corruption on Super Mario World map screen).
+- Changed mapping of keyboard to joy-pad buttons and added additional
+ direction keys for joy-pad one so player one's right hand doesn't have to
+ obscure player two's keyboard joy-pad buttons.
+- Changed joystick button layout to match SNES if using a 6 button joy-pad.
+- Changed snapshot format so I can easily use libgz on Linux.
+- Added few speed up tweaks that will be lost again when I add line-by-line
+ screen update.
+- First visible scan-line changed from 8 to 1 to match with new docs.
+- New SNES information source found; fixed partial H-DMA emulation to include
+ indirect addressing support.
+- Snapshot files are now compressed.
+- Compressed ROM images now supported on Linux.
+- Snapshot loading and saving added.
+- Joystick support for Linux added. One 2, 4 or 6 button joystick, or two 2
+ button joysticks supported (PC hardware limitation).
+- SVGA full screen support added for Linux. Still has the X11 slow down bug so
+ can't blame the X11 server any more! Must be a kernel bug or a very odd
+ emulator bug.
+- Added emulation of two joy-pads on the PC/Sun keyboard.
+- Removed -i command line flag as it is no longer used. -h value range has also
+ changed: now 1 - 100 (percentage).
+- Actuate cycle counting rather than instruction counting now added including
+ fast and slow ROM timing - should give much better timing information when
+ line-by-line screen update added.
+- Bug fixed old-style joy-pad access used by some ROMs - Mario All Stars still
+ gives problems if enabled and I don't know why; but at least Super Bomberman
+ now works !
+- Looks like if both horizontal and vertical IRQ are enabled then IRQ should
+ only be triggered once per frame and not once per scan line - looking at the
+ IRQ handler of a couple of ROMs seems to confirm this.
+- Added initial cycle counting - not accurate enough for some ROMs though.
+- Finally worked out how the odd VRAM address increments should work but only
+ found one ROM, so far, that actually uses it.
+- Debugged the odd slow down problem with the Linux port - it seems to be a
+ bug in the X Window System server - starve the X server of keyboard presses
+ or mouse clicks or movement and the X server slows down, slowing down the
+ emulator with it !
+0.4 released
+- Fixed sprite vertical clipping at top of screen.
+- No need to invert the Mode 7 transformation matrix before use - the
+ ROM coder already had to!
+- Fixed Mode 7 scrolling offset when using special effects.
+- Added Mode 7 rotation, enlargement and reduction emulation.
+- DMA shouldn't zero the byte count value after a DMA has completed.
+- Added DMA reading (Addams Family was using it)
+- Fixed V-RAM read function - returned data should lag behind the V-RAM
+ address by one byte/word.
+- Added mode 7 graphics only.
+0.3 released
+- Speeded up the main CPU loop a bit.
+- Add more command line options:
+ -f <frame skip> (default 1)
+ -i <no instructions between polling X> (default 32768)
+ -h <number instructions per scan line> (default 45, some games allow a lower
+ setting resulting in a increased
+ emulated frame rate)
+ -t enable CPU tracing
+ -ss <sound CPU skip wait method> (default 0, more methods to be added)
+ -H disable H-DMA emulation
+ -F Force Hi-ROM memory map
+- Modified planar to chunky conversion to use look up tables.
+- But now Mario All Stars won't start. Made emulation of $4016 optional with
+ -o command line switch.
+- Thanks to Carlos (calb) of ESNES fame, I've added correct $4016 & $4017
+ joy-pad register processing - now several more ROMs will start once a
+ button is pressed and can be controlled.
+- DMA wasn't updating DMA registers with the final CPU address used after the
+ DMA had completed (caused sprite and background corruption with some ROMs).
+ Still suspect another DMA side effect isn't being emulated correctly though.
+- Fixed setting of CPU overflow flag in ADC and SBC instructions in decimal
+ mode.
+- Fixed MVP/MVN CPU instructions to leave X and Y values correct at end of
+ loop - several more ROMs now work. Still don't know if MVP/MVN instructions
+ should ignore the accumulator size flag or not.
+- Rewrote background drawing code - gives a large increase in speed.
+- Flag to only update X Windows colour palette when necessary was missing a
+ case - caused some ROMs to start with a black screen.
+- Code to only update background tiles when changed wasn't working so I
+ disabled it.
+- CPU WAI instruction needed to trigger on hardware IRQ even when interrupt
+ enable flag was false.
+- DMA was not transferring 65536 bytes when byte count was 0.
+- Fixed matrix 16bit x 8bit multiplication (old debug code was causing junk
+ value to be returned).
+- Fixed Makefile so version.h header file change recompiles file that shows
+ version number in window title.
+- Added more reporting of used but unimplemented missing hardware features to
+ debug command.
+- New ROM loading code from Jerremy included, can now cope with ROM images
+ with no 512 byte header.
+- Speeded up emulated memory access a little bit.
+0.2 released
+- Added matrix 16bit x 8bit multiplication for Super Off-Road Racer.
+- Added initial H-DMA emulation - visual effects using it will not be seen
+ correctly until screen is updated line-by-line rather than the whole screen
+ at end-of-frame.
+- Fixed horizontal sprite clipping (vertical clipping still has a problem).
+- Integrated large sprite bug fixes and new background drawing code from
+ Jerremy.
+- Fixed large size per-sprite flag; always stayed true after sprite size was
+ changed to large.
+- Rewrote the planar to chunky pixel conversion routines (still need more
+ work).
+- Made registers $4016 & $4017 always return $ff - lots of ROMs that previously
+ wouldn't go beyond the title screen thought old-style joy-pads were
+ connected and were waiting for the user to press a button on them.
+- Frame skip rate now set to 1 instead of 5 on my P166 laptop!
+- Fixed NMI v-blank flag being incorrect set, caused some ROMs to lock.
+- X keyboard autorepeat now switched off when emulator has keyboard focus.
+- Added number key options to toggle backgrounds 1 to 4 and objs (sprites) on
+ and off.
+- Fixed sprite clipping problems at edge of left hand side of screen.
+- Corrected Hi-ROM memory map (I think) (no I didn't)
+- Fixed most of the sprite-to-sprite priority problems.
+- Added sprite debug command, 'S'.
+- Added a debug command to show what missing hardware features a ROM was using.
+- Added horizontal and vertical beam position IRQ - horizontal always triggers
+ at start of line at the moment.
+- Fixed SBC instruction to set carry flag the correct way around.
+Initial release 0.1
+- Ported Windows 95 version of Snes96 to Linux on a PC and Solaris on a
+ SparcStation.
+- Corrected work RAM memory map.
diff --git a/source/docs/control-inputs.txt b/source/docs/control-inputs.txt
new file mode 100644
index 0000000..4faddc3
--- /dev/null
+++ b/source/docs/control-inputs.txt
@@ -0,0 +1,68 @@
+Control input names are completely defined by the individual ports. This
+document is intended to collect the rules for all ports.
+
+The various meta-characters in the rules are:
+ # - A number. The range is detemined by the context
+ ## - A two-digit number (i.e. with leading zeros)
+ [...] - Something optional
+ (...) - For grouping with |
+ | - "or", choose one of the options.
+ <...> - A named field
+ {...} - A list of possible values. Multiple values may be used, but they
+ must be in the order listed and joined with +-signs.
+ "" - 'ditto', used to indicate the same list as the above line.
+
+================================================================================
+Unix
+================================================================================
+
+Input names:
+ Jxx:Axis# Axis # on joystick xx. Axis0 may be
+ Up/Down, and Axis1 Left/Right.
+ Jxx:B# Button # on joystick xx.
+
+ Jxx:{M1,M2,M3,M4,M5,M6,M7,M8}+B# Used with the 'JSx Meta#' port
+ Jxx:{M1,M2,M3,M4,M5,M6,M7,M8}+Axis# command.
+
+ Jxx:X+B# Used to 'define' this key for all
+ Jxx:X+Axis# combinations of JS Meta.
+
+Port-specific Commands:
+ JSx Meta# Used to specify modifier keys (i.e. Shift, Control) to
+ affect the specified joystick. For example, you could
+ map J00:B20 to "JS0 Meta1", then map J00:B0 to "Joypad1
+ A" and J00:M1+B0 to "Joypad1 Turbo A". '#' may range
+ from 1-8.
+
+ Jsx ToggleMeta# Like the above, but toggles the meta-state each time
+ the button is pressed.
+
+================================================================================
+Unix/X11
+================================================================================
+
+Keyboard Input:
+
+ Note that only one keyboard (K00) is currently supported. If you know how
+ to support multiple keyboards (and can test it!), feel free to fix x11.cpp
+ and delete this note.
+
+ Keyboard modifiers are S=Shift, C=Control, A=Alt, M=Meta. Combine them in
+ order, i.e. all 4 would be "SCAM".
+
+ Kxx:<keyname> Key names are as recognized by XStringToKeysym.
+ Kxx:<mods>+<keyname> Note however that keys are mapped by keycode,
+ so for example on a standard qwerty keyboard
+ "K00:colon" and "K00:semicolon" are identical.
+
+Pointer Input:
+
+ Note that only one mouse (M00) is currently supported. If you know how to
+ support multiple pointing devices (and can test it!), feel free to fix
+ x11.cpp and delete this note.
+
+ Mxx:Pointer Map the mouse pointer. If someone has a mouse
+ Mxx:Pointer# device with multiple pointers, fix x11.cpp to
+ report that and you can use the second syntax.
+
+ Mxx:B# Mouse buttons.
diff --git a/source/docs/controls.txt b/source/docs/controls.txt
new file mode 100644
index 0000000..703cd33
--- /dev/null
+++ b/source/docs/controls.txt
@@ -0,0 +1,97 @@
+This lists the available commands, excluding the ones you get back from
+S9xGetAllSnes9xCommands(). The various meta-characters are:
+ # - A number. The range is detemined by the context
+ ## - A two-digit number (i.e. with leading zeros)
+ [...] - Something optional
+ (...) - For grouping with |
+ | - "or", choose one of the options.
+ <...> - A named field
+ {...} - A list of possible values. Multiple values may be used, but they
+ must be in the order listed and joined with +-signs.
+ "" - 'ditto', used to indicate the same list as the above line.
+
+Speeds are: Var, Slow, Med, and Fast. 'Var' starts slow and speeds up as the
+button is held.
+
+Axes are: Left/Right, Right/Left, Up/Down, Down/Up, Y/A, A/Y, X/B, B/X, L/R,
+and R/L. Negative is listed first (i.e. "Y/A" means negative deflection is
+towards Y, while "A/Y" means negative deflection is towards A).
+
+AxisToPointer, ButtonToPointer, and AxisToButtons allow for translating
+between different input types. There are 8 'pointers' with IDs
+PseudoPointerBase+0 to PseudoPointerBase+7, and 256 'buttons' with IDs
+PseudoButtonBase+0 to PseudoButtonBase+255. So for example,
+"AxisToButtons 0/255 T=50%" would take the axis data, and do
+S9xReportButton(PseudoButtonBase+0,1) when said axis goes past 50% in the
+negative direction and S9xReportButton(PseudoButtonBase+255,1) when it goes
+over 50% deflection in the positive direction. Similarly, it will do
+S9xReportButton(...,0) when the deflection drops under 50% in either
+direction. "ButtonToPointer 1u Slow" would move the pointer with ID
+PseudoPointerBase+0 up one pixel per frame as long as the button is pressed
+(reporting this change at the end of each frame).
+
+---------------
+Button Commands
+---------------
+
+Joypad# {Up, Down, Left, Right, A, B, X, Y, L, R, Start, Select}
+Joypad# Turbo ""
+Joypad# Sticky ""
+Joypad# StickyTurbo ""
+Joypad# ToggleTurbo ""
+Joypad# ToggleSticky ""
+Joypad# ToggleStickyTurbo ""
+
+Mouse# (L|R|LR)
+
+Superscope AimOffscreen
+Superscope {Fire, Cursor, ToggleTurbo, Pause}
+Superscope AimOffscreen ""
+
+Justifier# AimOffscreen
+Justifier# {Trigger, Start}
+Justifier# AimOffscreen ""
+
+ButtonToPointer #[u|d][l|r] <speed> ; NOTE: "# <speed>" is invalid
+
+-------------
+Axis Commands
+-------------
+
+Joypad# Axis <axis> T=#% ; T = 0.1 to 100 by tenths
+AxisToButtons #/# T=#% ; neg then pos, range 0-255, T as above
+AxisToPointer #(h|v) [-]<speed> ; NOTE: '-' inverts the axis
+
+----------------
+Pointer Commands
+----------------
+
+Pointer {Mouse1, Mouse2, Superscope, Justifier1, Justifier2}
+
+------
+Multis
+------
+
+Multis are a type of button command. The basic format of a multi is "{...}",
+where the '...' consists of 1 or more valid non-multi button command
+strings. The braces are literal, not metacharacters. Subcommands separated
+by commas are executed one after the next. Semicolons skip one frame before
+continuing subcommand execution. Semicolons may be repeated. When the multi
+button is pressed, each subcommand is 'pressed', and when the multi button
+is released each subcommand is 'released'.
+
+There are also press-only multis, defined as "+{...}". These act just like
+regular multis, with two differences: the multi is only run when you press
+the button (release isignored), and each subcommand must be prefixed with
+'+' or '-' to indicate whether the the subcommand should be pressed or
+released.
+
+For example: {Joypad1 A,Joypad2 A;Joypad3 A;;;;;QuickSave000}
+ This presses (or releases) A on pads 1 and 2, then waits one frame, then
+ presses A on pad 3, then waits 5 frames, then saves to snapshot 0 (on press
+ only).
+
+You may access the multi number in the returned s9xcommand_t structure as
+cmd.button.multi_idx. This may be used to assign the same multi to multiple
+buttons:
+ MULTI#<num> ; NOTE: that's a literal octothorpe
diff --git a/source/docs/gpl-2.0.txt b/source/docs/gpl-2.0.txt
new file mode 100644
index 0000000..d511905
--- /dev/null
+++ b/source/docs/gpl-2.0.txt
@@ -0,0 +1,339 @@
+ GNU GENERAL PUBLIC LICENSE
+ Version 2, June 1991
+
+ Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+License is intended to guarantee your freedom to share and change free
+software--to make sure the software is free for all its users. This
+General Public License applies to most of the Free Software
+Foundation's software and to any other program whose authors commit to
+using it. (Some other Free Software Foundation software is covered by
+the GNU Lesser General Public License instead.) You can apply it to
+your programs, too.
+
+ When we speak of free software, we are referring to freedom, not
+price. Our General Public Licenses are designed to make sure that you
+have the freedom to distribute copies of free software (and charge for
+this service if you wish), that you receive source code or can get it
+if you want it, that you can change the software or use pieces of it
+in new free programs; and that you know you can do these things.
+
+ To protect your rights, we need to make restrictions that forbid
+anyone to deny you these rights or to ask you to surrender the rights.
+These restrictions translate to certain responsibilities for you if you
+distribute copies of the software, or if you modify it.
+
+ For example, if you distribute copies of such a program, whether
+gratis or for a fee, you must give the recipients all the rights that
+you have. You must make sure that they, too, receive or can get the
+source code. And you must show them these terms so they know their
+rights.
+
+ We protect your rights with two steps: (1) copyright the software, and
+(2) offer you this license which gives you legal permission to copy,
+distribute and/or modify the software.
+
+ Also, for each author's protection and ours, we want to make certain
+that everyone understands that there is no warranty for this free
+software. If the software is modified by someone else and passed on, we
+want its recipients to know that what they have is not the original, so
+that any problems introduced by others will not reflect on the original
+authors' reputations.
+
+ Finally, any free program is threatened constantly by software
+patents. We wish to avoid the danger that redistributors of a free
+program will individually obtain patent licenses, in effect making the
+program proprietary. To prevent this, we have made it clear that any
+patent must be licensed for everyone's free use or not licensed at all.
+
+ The precise terms and conditions for copying, distribution and
+modification follow.
+
+ GNU GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License applies to any program or other work which contains
+a notice placed by the copyright holder saying it may be distributed
+under the terms of this General Public License. The "Program", below,
+refers to any such program or work, and a "work based on the Program"
+means either the Program or any derivative work under copyright law:
+that is to say, a work containing the Program or a portion of it,
+either verbatim or with modifications and/or translated into another
+language. (Hereinafter, translation is included without limitation in
+the term "modification".) Each licensee is addressed as "you".
+
+Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running the Program is not restricted, and the output from the Program
+is covered only if its contents constitute a work based on the
+Program (independent of having been made by running the Program).
+Whether that is true depends on what the Program does.
+
+ 1. You may copy and distribute verbatim copies of the Program's
+source code as you receive it, in any medium, provided that you
+conspicuously and appropriately publish on each copy an appropriate
+copyright notice and disclaimer of warranty; keep intact all the
+notices that refer to this License and to the absence of any warranty;
+and give any other recipients of the Program a copy of this License
+along with the Program.
+
+You may charge a fee for the physical act of transferring a copy, and
+you may at your option offer warranty protection in exchange for a fee.
+
+ 2. You may modify your copy or copies of the Program or any portion
+of it, thus forming a work based on the Program, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+ a) You must cause the modified files to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ b) You must cause any work that you distribute or publish, that in
+ whole or in part contains or is derived from the Program or any
+ part thereof, to be licensed as a whole at no charge to all third
+ parties under the terms of this License.
+
+ c) If the modified program normally reads commands interactively
+ when run, you must cause it, when started running for such
+ interactive use in the most ordinary way, to print or display an
+ announcement including an appropriate copyright notice and a
+ notice that there is no warranty (or else, saying that you provide
+ a warranty) and that users may redistribute the program under
+ these conditions, and telling the user how to view a copy of this
+ License. (Exception: if the Program itself is interactive but
+ does not normally print such an announcement, your work based on
+ the Program is not required to print an announcement.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Program,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works. But when you
+distribute the same sections as part of a whole which is a work based
+on the Program, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Program.
+
+In addition, mere aggregation of another work not based on the Program
+with the Program (or with a work based on the Program) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may copy and distribute the Program (or a work based on it,
+under Section 2) in object code or executable form under the terms of
+Sections 1 and 2 above provided that you also do one of the following:
+
+ a) Accompany it with the complete corresponding machine-readable
+ source code, which must be distributed under the terms of Sections
+ 1 and 2 above on a medium customarily used for software interchange; or,
+
+ b) Accompany it with a written offer, valid for at least three
+ years, to give any third party, for a charge no more than your
+ cost of physically performing source distribution, a complete
+ machine-readable copy of the corresponding source code, to be
+ distributed under the terms of Sections 1 and 2 above on a medium
+ customarily used for software interchange; or,
+
+ c) Accompany it with the information you received as to the offer
+ to distribute corresponding source code. (This alternative is
+ allowed only for noncommercial distribution and only if you
+ received the program in object code or executable form with such
+ an offer, in accord with Subsection b above.)
+
+The source code for a work means the preferred form of the work for
+making modifications to it. For an executable work, complete source
+code means all the source code for all modules it contains, plus any
+associated interface definition files, plus the scripts used to
+control compilation and installation of the executable. However, as a
+special exception, the source code distributed need not include
+anything that is normally distributed (in either source or binary
+form) with the major components (compiler, kernel, and so on) of the
+operating system on which the executable runs, unless that component
+itself accompanies the executable.
+
+If distribution of executable or object code is made by offering
+access to copy from a designated place, then offering equivalent
+access to copy the source code from the same place counts as
+distribution of the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 4. You may not copy, modify, sublicense, or distribute the Program
+except as expressly provided under this License. Any attempt
+otherwise to copy, modify, sublicense or distribute the Program is
+void, and will automatically terminate your rights under this License.
+However, parties who have received copies, or rights, from you under
+this License will not have their licenses terminated so long as such
+parties remain in full compliance.
+
+ 5. You are not required to accept this License, since you have not
+signed it. However, nothing else grants you permission to modify or
+distribute the Program or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Program (or any work based on the
+Program), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Program or works based on it.
+
+ 6. Each time you redistribute the Program (or any work based on the
+Program), the recipient automatically receives a license from the
+original licensor to copy, distribute or modify the Program subject to
+these terms and conditions. You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties to
+this License.
+
+ 7. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Program at all. For example, if a patent
+license would not permit royalty-free redistribution of the Program by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Program.
+
+If any portion of this section is held invalid or unenforceable under
+any particular circumstance, the balance of the section is intended to
+apply and the section as a whole is intended to apply in other
+circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system, which is
+implemented by public license practices. Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+ 8. If the distribution and/or use of the Program is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Program under this License
+may add an explicit geographical distribution limitation excluding
+those countries, so that distribution is permitted only in or among
+countries not thus excluded. In such case, this License incorporates
+the limitation as if written in the body of this License.
+
+ 9. The Free Software Foundation may publish revised and/or new versions
+of the General Public License from time to time. Such new versions will
+be similar in spirit to the present version, but may differ in detail to
+address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Program
+specifies a version number of this License which applies to it and "any
+later version", you have the option of following the terms and conditions
+either of that version or of any later version published by the Free
+Software Foundation. If the Program does not specify a version number of
+this License, you may choose any version ever published by the Free Software
+Foundation.
+
+ 10. If you wish to incorporate parts of the Program into other free
+programs whose distribution conditions are different, write to the author
+to ask for permission. For software which is copyrighted by the Free
+Software Foundation, write to the Free Software Foundation; we sometimes
+make exceptions for this. Our decision will be guided by the two goals
+of preserving the free status of all derivatives of our free software and
+of promoting the sharing and reuse of software generally.
+
+ NO WARRANTY
+
+ 11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
+FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
+OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
+PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
+TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
+PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
+REPAIR OR CORRECTION.
+
+ 12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
+WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
+REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
+INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
+OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
+TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
+YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
+PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
+POSSIBILITY OF SUCH DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Programs
+
+ If you develop a new program, and you want it to be of the greatest
+possible use to the public, the best way to achieve this is to make it
+free software which everyone can redistribute and change under these terms.
+
+ To do so, attach the following notices to the program. It is safest
+to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least
+the "copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the program's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License along
+ with this program; if not, write to the Free Software Foundation, Inc.,
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+
+Also add information on how to contact you by electronic and paper mail.
+
+If the program is interactive, make it output a short notice like this
+when it starts in an interactive mode:
+
+ Gnomovision version 69, Copyright (C) year name of author
+ Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
+ This is free software, and you are welcome to redistribute it
+ under certain conditions; type `show c' for details.
+
+The hypothetical commands `show w' and `show c' should show the appropriate
+parts of the General Public License. Of course, the commands you use may
+be called something other than `show w' and `show c'; they could even be
+mouse-clicks or menu items--whatever suits your program.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the program, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the program
+ `Gnomovision' (which makes passes at compilers) written by James Hacker.
+
+ <signature of Ty Coon>, 1 April 1989
+ Ty Coon, President of Vice
+
+This General Public License does not permit incorporating your program into
+proprietary programs. If your program is a subroutine library, you may
+consider it more useful to permit linking proprietary applications with the
+library. If this is what you want to do, use the GNU Lesser General
+Public License instead of this License.
diff --git a/source/docs/lgpl-2.1.txt b/source/docs/lgpl-2.1.txt
new file mode 100644
index 0000000..602bfc9
--- /dev/null
+++ b/source/docs/lgpl-2.1.txt
@@ -0,0 +1,504 @@
+ GNU LESSER GENERAL PUBLIC LICENSE
+ Version 2.1, February 1999
+
+ Copyright (C) 1991, 1999 Free Software Foundation, Inc.
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ Everyone is permitted to copy and distribute verbatim copies
+ of this license document, but changing it is not allowed.
+
+[This is the first released version of the Lesser GPL. It also counts
+ as the successor of the GNU Library Public License, version 2, hence
+ the version number 2.1.]
+
+ Preamble
+
+ The licenses for most software are designed to take away your
+freedom to share and change it. By contrast, the GNU General Public
+Licenses are intended to guarantee your freedom to share and change
+free software--to make sure the software is free for all its users.
+
+ This license, the Lesser General Public License, applies to some
+specially designated software packages--typically libraries--of the
+Free Software Foundation and other authors who decide to use it. You
+can use it too, but we suggest you first think carefully about whether
+this license or the ordinary General Public License is the better
+strategy to use in any particular case, based on the explanations below.
+
+ When we speak of free software, we are referring to freedom of use,
+not price. Our General Public Licenses are designed to make sure that
+you have the freedom to distribute copies of free software (and charge
+for this service if you wish); that you receive source code or can get
+it if you want it; that you can change the software and use pieces of
+it in new free programs; and that you are informed that you can do
+these things.
+
+ To protect your rights, we need to make restrictions that forbid
+distributors to deny you these rights or to ask you to surrender these
+rights. These restrictions translate to certain responsibilities for
+you if you distribute copies of the library or if you modify it.
+
+ For example, if you distribute copies of the library, whether gratis
+or for a fee, you must give the recipients all the rights that we gave
+you. You must make sure that they, too, receive or can get the source
+code. If you link other code with the library, you must provide
+complete object files to the recipients, so that they can relink them
+with the library after making changes to the library and recompiling
+it. And you must show them these terms so they know their rights.
+
+ We protect your rights with a two-step method: (1) we copyright the
+library, and (2) we offer you this license, which gives you legal
+permission to copy, distribute and/or modify the library.
+
+ To protect each distributor, we want to make it very clear that
+there is no warranty for the free library. Also, if the library is
+modified by someone else and passed on, the recipients should know
+that what they have is not the original version, so that the original
+author's reputation will not be affected by problems that might be
+introduced by others.
+
+ Finally, software patents pose a constant threat to the existence of
+any free program. We wish to make sure that a company cannot
+effectively restrict the users of a free program by obtaining a
+restrictive license from a patent holder. Therefore, we insist that
+any patent license obtained for a version of the library must be
+consistent with the full freedom of use specified in this license.
+
+ Most GNU software, including some libraries, is covered by the
+ordinary GNU General Public License. This license, the GNU Lesser
+General Public License, applies to certain designated libraries, and
+is quite different from the ordinary General Public License. We use
+this license for certain libraries in order to permit linking those
+libraries into non-free programs.
+
+ When a program is linked with a library, whether statically or using
+a shared library, the combination of the two is legally speaking a
+combined work, a derivative of the original library. The ordinary
+General Public License therefore permits such linking only if the
+entire combination fits its criteria of freedom. The Lesser General
+Public License permits more lax criteria for linking other code with
+the library.
+
+ We call this license the "Lesser" General Public License because it
+does Less to protect the user's freedom than the ordinary General
+Public License. It also provides other free software developers Less
+of an advantage over competing non-free programs. These disadvantages
+are the reason we use the ordinary General Public License for many
+libraries. However, the Lesser license provides advantages in certain
+special circumstances.
+
+ For example, on rare occasions, there may be a special need to
+encourage the widest possible use of a certain library, so that it becomes
+a de-facto standard. To achieve this, non-free programs must be
+allowed to use the library. A more frequent case is that a free
+library does the same job as widely used non-free libraries. In this
+case, there is little to gain by limiting the free library to free
+software only, so we use the Lesser General Public License.
+
+ In other cases, permission to use a particular library in non-free
+programs enables a greater number of people to use a large body of
+free software. For example, permission to use the GNU C Library in
+non-free programs enables many more people to use the whole GNU
+operating system, as well as its variant, the GNU/Linux operating
+system.
+
+ Although the Lesser General Public License is Less protective of the
+users' freedom, it does ensure that the user of a program that is
+linked with the Library has the freedom and the wherewithal to run
+that program using a modified version of the Library.
+
+ The precise terms and conditions for copying, distribution and
+modification follow. Pay close attention to the difference between a
+"work based on the library" and a "work that uses the library". The
+former contains code derived from the library, whereas the latter must
+be combined with the library in order to run.
+
+ GNU LESSER GENERAL PUBLIC LICENSE
+ TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
+
+ 0. This License Agreement applies to any software library or other
+program which contains a notice placed by the copyright holder or
+other authorized party saying it may be distributed under the terms of
+this Lesser General Public License (also called "this License").
+Each licensee is addressed as "you".
+
+ A "library" means a collection of software functions and/or data
+prepared so as to be conveniently linked with application programs
+(which use some of those functions and data) to form executables.
+
+ The "Library", below, refers to any such software library or work
+which has been distributed under these terms. A "work based on the
+Library" means either the Library or any derivative work under
+copyright law: that is to say, a work containing the Library or a
+portion of it, either verbatim or with modifications and/or translated
+straightforwardly into another language. (Hereinafter, translation is
+included without limitation in the term "modification".)
+
+ "Source code" for a work means the preferred form of the work for
+making modifications to it. For a library, complete source code means
+all the source code for all modules it contains, plus any associated
+interface definition files, plus the scripts used to control compilation
+and installation of the library.
+
+ Activities other than copying, distribution and modification are not
+covered by this License; they are outside its scope. The act of
+running a program using the Library is not restricted, and output from
+such a program is covered only if its contents constitute a work based
+on the Library (independent of the use of the Library in a tool for
+writing it). Whether that is true depends on what the Library does
+and what the program that uses the Library does.
+
+ 1. You may copy and distribute verbatim copies of the Library's
+complete source code as you receive it, in any medium, provided that
+you conspicuously and appropriately publish on each copy an
+appropriate copyright notice and disclaimer of warranty; keep intact
+all the notices that refer to this License and to the absence of any
+warranty; and distribute a copy of this License along with the
+Library.
+
+ You may charge a fee for the physical act of transferring a copy,
+and you may at your option offer warranty protection in exchange for a
+fee.
+
+ 2. You may modify your copy or copies of the Library or any portion
+of it, thus forming a work based on the Library, and copy and
+distribute such modifications or work under the terms of Section 1
+above, provided that you also meet all of these conditions:
+
+ a) The modified work must itself be a software library.
+
+ b) You must cause the files modified to carry prominent notices
+ stating that you changed the files and the date of any change.
+
+ c) You must cause the whole of the work to be licensed at no
+ charge to all third parties under the terms of this License.
+
+ d) If a facility in the modified Library refers to a function or a
+ table of data to be supplied by an application program that uses
+ the facility, other than as an argument passed when the facility
+ is invoked, then you must make a good faith effort to ensure that,
+ in the event an application does not supply such function or
+ table, the facility still operates, and performs whatever part of
+ its purpose remains meaningful.
+
+ (For example, a function in a library to compute square roots has
+ a purpose that is entirely well-defined independent of the
+ application. Therefore, Subsection 2d requires that any
+ application-supplied function or table used by this function must
+ be optional: if the application does not supply it, the square
+ root function must still compute square roots.)
+
+These requirements apply to the modified work as a whole. If
+identifiable sections of that work are not derived from the Library,
+and can be reasonably considered independent and separate works in
+themselves, then this License, and its terms, do not apply to those
+sections when you distribute them as separate works. But when you
+distribute the same sections as part of a whole which is a work based
+on the Library, the distribution of the whole must be on the terms of
+this License, whose permissions for other licensees extend to the
+entire whole, and thus to each and every part regardless of who wrote
+it.
+
+Thus, it is not the intent of this section to claim rights or contest
+your rights to work written entirely by you; rather, the intent is to
+exercise the right to control the distribution of derivative or
+collective works based on the Library.
+
+In addition, mere aggregation of another work not based on the Library
+with the Library (or with a work based on the Library) on a volume of
+a storage or distribution medium does not bring the other work under
+the scope of this License.
+
+ 3. You may opt to apply the terms of the ordinary GNU General Public
+License instead of this License to a given copy of the Library. To do
+this, you must alter all the notices that refer to this License, so
+that they refer to the ordinary GNU General Public License, version 2,
+instead of to this License. (If a newer version than version 2 of the
+ordinary GNU General Public License has appeared, then you can specify
+that version instead if you wish.) Do not make any other change in
+these notices.
+
+ Once this change is made in a given copy, it is irreversible for
+that copy, so the ordinary GNU General Public License applies to all
+subsequent copies and derivative works made from that copy.
+
+ This option is useful when you wish to copy part of the code of
+the Library into a program that is not a library.
+
+ 4. You may copy and distribute the Library (or a portion or
+derivative of it, under Section 2) in object code or executable form
+under the terms of Sections 1 and 2 above provided that you accompany
+it with the complete corresponding machine-readable source code, which
+must be distributed under the terms of Sections 1 and 2 above on a
+medium customarily used for software interchange.
+
+ If distribution of object code is made by offering access to copy
+from a designated place, then offering equivalent access to copy the
+source code from the same place satisfies the requirement to
+distribute the source code, even though third parties are not
+compelled to copy the source along with the object code.
+
+ 5. A program that contains no derivative of any portion of the
+Library, but is designed to work with the Library by being compiled or
+linked with it, is called a "work that uses the Library". Such a
+work, in isolation, is not a derivative work of the Library, and
+therefore falls outside the scope of this License.
+
+ However, linking a "work that uses the Library" with the Library
+creates an executable that is a derivative of the Library (because it
+contains portions of the Library), rather than a "work that uses the
+library". The executable is therefore covered by this License.
+Section 6 states terms for distribution of such executables.
+
+ When a "work that uses the Library" uses material from a header file
+that is part of the Library, the object code for the work may be a
+derivative work of the Library even though the source code is not.
+Whether this is true is especially significant if the work can be
+linked without the Library, or if the work is itself a library. The
+threshold for this to be true is not precisely defined by law.
+
+ If such an object file uses only numerical parameters, data
+structure layouts and accessors, and small macros and small inline
+functions (ten lines or less in length), then the use of the object
+file is unrestricted, regardless of whether it is legally a derivative
+work. (Executables containing this object code plus portions of the
+Library will still fall under Section 6.)
+
+ Otherwise, if the work is a derivative of the Library, you may
+distribute the object code for the work under the terms of Section 6.
+Any executables containing that work also fall under Section 6,
+whether or not they are linked directly with the Library itself.
+
+ 6. As an exception to the Sections above, you may also combine or
+link a "work that uses the Library" with the Library to produce a
+work containing portions of the Library, and distribute that work
+under terms of your choice, provided that the terms permit
+modification of the work for the customer's own use and reverse
+engineering for debugging such modifications.
+
+ You must give prominent notice with each copy of the work that the
+Library is used in it and that the Library and its use are covered by
+this License. You must supply a copy of this License. If the work
+during execution displays copyright notices, you must include the
+copyright notice for the Library among them, as well as a reference
+directing the user to the copy of this License. Also, you must do one
+of these things:
+
+ a) Accompany the work with the complete corresponding
+ machine-readable source code for the Library including whatever
+ changes were used in the work (which must be distributed under
+ Sections 1 and 2 above); and, if the work is an executable linked
+ with the Library, with the complete machine-readable "work that
+ uses the Library", as object code and/or source code, so that the
+ user can modify the Library and then relink to produce a modified
+ executable containing the modified Library. (It is understood
+ that the user who changes the contents of definitions files in the
+ Library will not necessarily be able to recompile the application
+ to use the modified definitions.)
+
+ b) Use a suitable shared library mechanism for linking with the
+ Library. A suitable mechanism is one that (1) uses at run time a
+ copy of the library already present on the user's computer system,
+ rather than copying library functions into the executable, and (2)
+ will operate properly with a modified version of the library, if
+ the user installs one, as long as the modified version is
+ interface-compatible with the version that the work was made with.
+
+ c) Accompany the work with a written offer, valid for at
+ least three years, to give the same user the materials
+ specified in Subsection 6a, above, for a charge no more
+ than the cost of performing this distribution.
+
+ d) If distribution of the work is made by offering access to copy
+ from a designated place, offer equivalent access to copy the above
+ specified materials from the same place.
+
+ e) Verify that the user has already received a copy of these
+ materials or that you have already sent this user a copy.
+
+ For an executable, the required form of the "work that uses the
+Library" must include any data and utility programs needed for
+reproducing the executable from it. However, as a special exception,
+the materials to be distributed need not include anything that is
+normally distributed (in either source or binary form) with the major
+components (compiler, kernel, and so on) of the operating system on
+which the executable runs, unless that component itself accompanies
+the executable.
+
+ It may happen that this requirement contradicts the license
+restrictions of other proprietary libraries that do not normally
+accompany the operating system. Such a contradiction means you cannot
+use both them and the Library together in an executable that you
+distribute.
+
+ 7. You may place library facilities that are a work based on the
+Library side-by-side in a single library together with other library
+facilities not covered by this License, and distribute such a combined
+library, provided that the separate distribution of the work based on
+the Library and of the other library facilities is otherwise
+permitted, and provided that you do these two things:
+
+ a) Accompany the combined library with a copy of the same work
+ based on the Library, uncombined with any other library
+ facilities. This must be distributed under the terms of the
+ Sections above.
+
+ b) Give prominent notice with the combined library of the fact
+ that part of it is a work based on the Library, and explaining
+ where to find the accompanying uncombined form of the same work.
+
+ 8. You may not copy, modify, sublicense, link with, or distribute
+the Library except as expressly provided under this License. Any
+attempt otherwise to copy, modify, sublicense, link with, or
+distribute the Library is void, and will automatically terminate your
+rights under this License. However, parties who have received copies,
+or rights, from you under this License will not have their licenses
+terminated so long as such parties remain in full compliance.
+
+ 9. You are not required to accept this License, since you have not
+signed it. However, nothing else grants you permission to modify or
+distribute the Library or its derivative works. These actions are
+prohibited by law if you do not accept this License. Therefore, by
+modifying or distributing the Library (or any work based on the
+Library), you indicate your acceptance of this License to do so, and
+all its terms and conditions for copying, distributing or modifying
+the Library or works based on it.
+
+ 10. Each time you redistribute the Library (or any work based on the
+Library), the recipient automatically receives a license from the
+original licensor to copy, distribute, link with or modify the Library
+subject to these terms and conditions. You may not impose any further
+restrictions on the recipients' exercise of the rights granted herein.
+You are not responsible for enforcing compliance by third parties with
+this License.
+
+ 11. If, as a consequence of a court judgment or allegation of patent
+infringement or for any other reason (not limited to patent issues),
+conditions are imposed on you (whether by court order, agreement or
+otherwise) that contradict the conditions of this License, they do not
+excuse you from the conditions of this License. If you cannot
+distribute so as to satisfy simultaneously your obligations under this
+License and any other pertinent obligations, then as a consequence you
+may not distribute the Library at all. For example, if a patent
+license would not permit royalty-free redistribution of the Library by
+all those who receive copies directly or indirectly through you, then
+the only way you could satisfy both it and this License would be to
+refrain entirely from distribution of the Library.
+
+If any portion of this section is held invalid or unenforceable under any
+particular circumstance, the balance of the section is intended to apply,
+and the section as a whole is intended to apply in other circumstances.
+
+It is not the purpose of this section to induce you to infringe any
+patents or other property right claims or to contest validity of any
+such claims; this section has the sole purpose of protecting the
+integrity of the free software distribution system which is
+implemented by public license practices. Many people have made
+generous contributions to the wide range of software distributed
+through that system in reliance on consistent application of that
+system; it is up to the author/donor to decide if he or she is willing
+to distribute software through any other system and a licensee cannot
+impose that choice.
+
+This section is intended to make thoroughly clear what is believed to
+be a consequence of the rest of this License.
+
+ 12. If the distribution and/or use of the Library is restricted in
+certain countries either by patents or by copyrighted interfaces, the
+original copyright holder who places the Library under this License may add
+an explicit geographical distribution limitation excluding those countries,
+so that distribution is permitted only in or among countries not thus
+excluded. In such case, this License incorporates the limitation as if
+written in the body of this License.
+
+ 13. The Free Software Foundation may publish revised and/or new
+versions of the Lesser General Public License from time to time.
+Such new versions will be similar in spirit to the present version,
+but may differ in detail to address new problems or concerns.
+
+Each version is given a distinguishing version number. If the Library
+specifies a version number of this License which applies to it and
+"any later version", you have the option of following the terms and
+conditions either of that version or of any later version published by
+the Free Software Foundation. If the Library does not specify a
+license version number, you may choose any version ever published by
+the Free Software Foundation.
+
+ 14. If you wish to incorporate parts of the Library into other free
+programs whose distribution conditions are incompatible with these,
+write to the author to ask for permission. For software which is
+copyrighted by the Free Software Foundation, write to the Free
+Software Foundation; we sometimes make exceptions for this. Our
+decision will be guided by the two goals of preserving the free status
+of all derivatives of our free software and of promoting the sharing
+and reuse of software generally.
+
+ NO WARRANTY
+
+ 15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
+WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
+EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
+OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY
+KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
+LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME
+THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
+
+ 16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN
+WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY
+AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU
+FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR
+CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE
+LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING
+RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A
+FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF
+SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+DAMAGES.
+
+ END OF TERMS AND CONDITIONS
+
+ How to Apply These Terms to Your New Libraries
+
+ If you develop a new library, and you want it to be of the greatest
+possible use to the public, we recommend making it free software that
+everyone can redistribute and change. You can do so by permitting
+redistribution under these terms (or, alternatively, under the terms of the
+ordinary General Public License).
+
+ To apply these terms, attach the following notices to the library. It is
+safest to attach them to the start of each source file to most effectively
+convey the exclusion of warranty; and each file should have at least the
+"copyright" line and a pointer to where the full notice is found.
+
+ <one line to give the library's name and a brief idea of what it does.>
+ Copyright (C) <year> <name of author>
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Lesser General Public
+ License as published by the Free Software Foundation; either
+ version 2.1 of the License, or (at your option) any later version.
+
+ This library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public
+ License along with this library; if not, write to the Free Software
+ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+
+Also add information on how to contact you by electronic and paper mail.
+
+You should also get your employer (if you work as a programmer) or your
+school, if any, to sign a "copyright disclaimer" for the library, if
+necessary. Here is a sample; alter the names:
+
+ Yoyodyne, Inc., hereby disclaims all copyright interest in the
+ library `Frob' (a library for tweaking knobs) written by James Random Hacker.
+
+ <signature of Ty Coon>, 1 April 1990
+ Ty Coon, President of Vice
+
+That's all there is to it!
+
+
diff --git a/source/docs/porting.html b/source/docs/porting.html
new file mode 100644
index 0000000..a2d3d49
--- /dev/null
+++ b/source/docs/porting.html
@@ -0,0 +1,371 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
+<html lang="en-US">
+ <head>
+ <meta http-equiv="content-type" content="text/html;charset=iso-8859-1">
+ <meta http-equiv="Content-Style-Type" content="text/css">
+ <meta name="description" content="How to Port Snes9x to a New Platform">
+ <style type="text/css">
+ <!-- ul { list-style-type:none } h2 { margin-top:3em } h3 { margin-top:2em } -->
+ </style>
+ <title>Porting Snes9x</title>
+ </head>
+ <body>
+ <h1 style="text-align:center">How to Port Snes9x to a New Platform</h1>
+ <div style="text-align:right">
+ Version: 1.53<br>
+ (c) Copyright 1998 Gary Henderson
+ </div>
+ <h2>Introduction</h2>
+ <p>
+ This is brief description of the steps to port Snes9x to the new platform. It describes what code you have to write and what functions exist that you can make use of. It also gives some insights as to how Snes9x actually works, although that will be subject of another document yet to be written.
+ </p>
+ <h2>System Requirements</h2>
+ <p>
+ A C++ compiler. For the most part Snes9x really isn't written in C++, it just uses the C++ compiler as a &ldquo;better C&rdquo; compiler to get inline functions and so on. GCC is good for compiling Snes9x (<a href="http://gcc.gnu.org/">http://gcc.gnu.org/</a>).
+ </p>
+ <p>
+ A fast CPU. SNES emulation is very compute intensive; two, or sometimes three CPUs to emulate, an 8-channel 16-bit stereo sound digital signal processor with real-time sample decompression, filter and echo effects, two custom graphics processor chips that can produce transparency, scaling, rotation and window effects in 32768 colors, and finally hardware DMA all take their toll on the host CPU.
+ </p>
+ <p>
+ Enough RAM. Snes9x uses 8MB to load SNES ROM images and several MB for emulating sound, graphics, custom chips, and so on.
+ </p>
+ <p>
+ A 16-bit color (two bytes per pixel) or deeper display, at least 512*478 pixels in resolution. Pixel format conversion may be required before you place the rendered SNES screen on to the display.
+ </p>
+ <p>
+ Sound output requires spooling 8-bit or 16-bit, mono or stereo digital sound data to the host sound system. Some ports can use interrupts or callbacks from the sound system to know when more sound data is required, most other ports have to periodically poll the host sound system to see if more data is required; if it is then the sound mixing code is called to fill the sound buffer with SNES sound data, which then can be passed on to the host sound system. Sound data is generated as an array of bytes (<code>uint8</code>) for 8-bit sound or shorts (<code>int16</code>) for 16-bit data. Stereo sound data generates twice as many samples, with each channel's samples interleaved, first left's then right's.
+ </p>
+ <p>
+ For the user to be able to control and play SNES games, some form of input device is required, a joypad or keyboard, for example. The real SNES can have 2 eight-button digital joypads connected to it or 5 joypads when an optional multi-player adaptor is connected, although most games only require a single joypad. Access to all eight buttons and the direction pad, of course, are usually required by most games. Snes9x does emulate the multi-player adaptor hardware, if you were wondering, but its still up to you to provide the emulation of the individual joypads.
+ </p>
+ <p>
+ The real SNES also has a SNES mouse, Super Scope and Justifier (light-gun) available as optional extras. Snes9x can emulate all of these using some form of pointing device, usually the host system's mouse.
+ </p>
+ <p>
+ Some SNES game cartridges contains a small amount of extra RAM and a battery, so ROMs could save a player's progress through a game for games that takes many hours to play from start to finish. Snes9x simulates this S-RAM by saving the contents of the area of memory occupied by the S-RAM into a file then automatically restoring it again the next time the user plays the same game. If the hardware you're porting to doesn't have a storage media available then you could be in trouble.
+ </p>
+ <p>
+ Snes9x also implements freeze-game files which can record the state of the SNES hardware and RAM at a particular point in time and can restore it to that exact state at a later date - the result is that users can save a game at any point, not just at save-game or password points provided by the original game coders. Each freeze file is over 400k in size. To help save disk space, Snes9x can be compiled with zlib (<a href="http://www.zlib.net/">http://www.zlib.net/</a>), which is used to GZIP compress the freeze files, reducing the size to typically below 100k. zlib is also used to load GZIP or ZIP compressed ROM images. Additionally, Snes9x supports JMA archives compressed with NSRT (<a href="http://nsrt.edgeemu.com/">http://nsrt.edgeemu.com/</a>).
+ </p>
+ <h2>Compile-Time Options</h2>
+ <h3><code>DEBUGGER</code></h3>
+ <p>
+ Enables extra code to assist you in debugging SNES ROMs. The debugger has only ever been a quick-hack and user-interface to debugger facilities is virtually non-existent. Most of the debugger information is output via stdout and enabling the debugger slows the whole emulator down slightly. However, the debugger options available are very powerful; you could use it to help get your port working. You probably still want to ship the finished version with the debugger disabled, it will only confuse non-technical users.
+ </p>
+ <h3><code>RIGHTSHIFT_IS_SAR</code></h3>
+ <p>
+ Define this if your compiler uses shift right arithmetic for signed values. For example, GCC and Visual C++ use shift right arithmetic.
+ </p>
+ <h3><code>ZLIB / UNZIP_SUPPORT / JMA_SUPPORT</code></h3>
+ <p>
+ Define these if you want to support GZIP/ZIP/JMA compressed ROM images and GZIP compressed freeze-game files.
+ </p>
+ <h3><code>USE_OPENGL</code></h3>
+ <p>
+ Define this and set <code>Settings.OpenGLEnable</code> to <code>true</code>, then you'll get the rendered SNES image as one OpenGL texture.
+ </p>
+ <h3>Typical Options Common for Most Platforms</h3>
+ <p><code>
+ ZLIB<br>
+ UNZIP_SUPPORT<br>
+ JMA_SUPPORT<br>
+ RIGHTSHIFT_IS_SAR<br>
+ </code></p>
+ <h2>Editing port.h</h2>
+ <p>
+ You may need to edit <code>port.h</code> to fit Snes9x to your system.
+ </p>
+ <p>
+ If the byte ordering of your system is least significant byte first, make sure <code>LSB_FIRST</code> is defined, otherwise make sure it's not defined.
+ </p>
+ <p>
+ You'll need to make sure what pixel format your system uses for 16-bit colors (<code>RGB565</code>, <code>RGB555</code>, <code>BGR565</code> or <code>BGR555</code>), and if it's not <code>RGB565</code>, define <code>PIXEL_FORMAT</code> to it so that Snes9x will use it to render the SNES screen. For example, Windows uses <code>RGB565</code>, Mac OS X uses <code>RGB555</code>. If your system supports more than one pixel format, you can define <code>GFX_MULTI_FORMAT</code> and change Snes9x's pixel format dynamically by calling <code>S9xSetRenderPixelFormat</code> function. If your system is 24 or 32-bit only, then don't define anything; instead write a conversion routine that will take a complete rendered 16-bit SNES screen in <code>RGB565</code> format and convert to the format required to be displayed on your system.
+ </p>
+ <p>
+ <code>port.h</code> also typedefs some types; <code>uint8</code> for an unsigned 8-bit quantity, <code>uint16</code> for an unsigned 16-bit quantity, <code>uint32</code> for a 32-bit unsigned quantity and <code>bool8</code> for a <code>true</code>/<code>false</code> type. Signed versions are also typedef'ed.
+ </p>
+ <h2>Controllers Management</h2>
+ <p>
+ Read <code>controls.h</code>, <code>crosshair.h</code>, <code>controls.txt</code> and <code>control-inputs.txt</code> for details. This section is the minimal explanation to get the SNES controls workable.
+ </p>
+ <p>
+ The real SNES allows several different types of devices to be plugged into the game controller ports. The devices Snes9x emulates are a joypad, multi-player adaptor known as the Multi Player 5 or Multi Tap (allowing a further 4 joypads to be plugged in), a 2-button mouse, a light gun known as the Super Scope, and a light gun known as the Justifier.
+ </p>
+ <p>
+ In your initialization code, call <code>S9xUnmapAllControl</code> function.
+ </p>
+ <p>
+ Map any IDs to each SNES controller's buttons and pointers. (ID 249-255 are reserved).
+ </p>
+ <p>
+ Typically, use <code>S9xMapPointer</code> function for the pointer of the SNES mouse, Super Scope and Justifier, <code>S9xMapButton</code> function for other buttons. Set <code>poll</code> to <code>false</code> for the joypad buttons, <code>true</code> for the other buttons and pointers.
+ </p>
+ <p>
+ <code>S9xMapButton(k1P_A_Button, s9xcommand_t cmd = S9xGetCommandT(&quot;Joypad1 A&quot;), false);</code>
+ </p>
+ <p>
+ In your main emulation loop, after <code>S9xMainLoop</code> function is called, check your system's keyboard/joypad, and call <code>S9xReportButton</code> function to report the states of the SNES joypad buttons to Snes9x.
+ </p>
+ <p>
+ <code>void MyMainLoop (void)<br>
+ {<br>
+ &nbsp;&nbsp;&nbsp;&nbsp;S9xMainLoop();<br>
+ &nbsp;&nbsp;&nbsp;&nbsp;MyReportButttons();<br>
+ }</code>
+ </p>
+ <p>
+ <code>void MyReportButtons (void)<br>
+ {<br>
+ &nbsp;&nbsp;&nbsp;&nbsp;S9xReportButton(k1P_A_Button, (key_is_pressed ? true : false));<br>
+ }</code>
+ </p>
+ <p>
+ Prepare your <code>S9xPollButton</code> and <code>S9xPollPointer</code> function to reply Snes9x's request for other buttons/cursors states.
+ </p>
+ <p>
+ Call <code>S9xSetController</code> function. It connects each input device to each SNES input port.<br>
+ Here's typical controller settings that is used by the real SNES games:
+ </p>
+ <p>Joypad<br>
+ <code>S9xSetController(0, CTL_JOYPAD, 0, 0, 0, 0);<br>
+ S9xSetController(1, CTL_JOYPAD, 1, 0, 0, 0);</code>
+ </p>
+ <p>Mouse (port 1)<br>
+ <code>S9xSetController(0, CTL_MOUSE, 0, 0, 0, 0);<br>
+ S9xSetController(1, CTL_JOYPAD, 1, 0, 0, 0);</code>
+ </p>
+ <p>Mouse (port 2)<br>
+ <code>S9xSetController(0, CTL_JOYPAD, 0, 0, 0, 0);<br>
+ S9xSetController(1, CTL_MOUSE, 1, 0, 0, 0);</code>
+ </p>
+ <p>Super Scope<br>
+ <code>S9xSetController(0, CTL_JOYPAD, 0, 0, 0, 0);<br>
+ S9xSetController(1, CTL_SUPERSCOPE, 0, 0, 0, 0);</code>
+ </p>
+ <p>Multi Player 5<br>
+ <code>S9xSetController(0, CTL_JOYPAD, 0, 0, 0, 0);<br>
+ S9xSetController(1, CTL_MP5, 1, 2, 3, 4);</code>
+ </p>
+ <p>Justifier<br>
+ <code>S9xSetController(0, CTL_JOYPAD, 0, 0, 0, 0);<br>
+ S9xSetController(1, CTL_JUSTIFIER, 0, 0, 0, 0);</code>
+ </p>
+ <p>Justifier (2 players)<br>
+ <code>S9xSetController(0, CTL_JOYPAD, 0, 0, 0, 0);<br>
+ S9xSetController(1, CTL_JUSTIFIER, 1, 0, 0, 0);</code>
+ </p>
+ <h2>Existing Interface Functions</h2>
+ <h3><code>bool8 Memory.Init (void)</code></h3>
+ <p>
+ Allocates and initializes several major lumps of memory, for example the SNES ROM and RAM arrays, tile cache arrays, etc. Returns <code>false</code> if memory allocation fails.
+ </p>
+ <h3><code>void Memory.Deinit (void)</code></h3>
+ <p>
+ Deallocates the memory allocations made by <code>Memory.Init</code> function.
+ </p>
+ <h3><code>bool8 S9xGraphicsInit (void)</code></h3>
+ <p>
+ Allocates and initializes several lookup tables used to speed up SNES graphics rendering. Call after you have initialized the <code>GFX.Screen</code> and <code>GFX.Pitch</code> values. Returns <code>false</code> if memory allocation fails.
+ </p>
+ <h3><code>void S9xGraphicsDeinit (void)</code></h3>
+ <p>
+ Deallocates the memory allocations made by <code>S9xGraphicsInit</code> function.
+ </p>
+ <h3><code>bool8 S9xInitAPU (void)</code></h3>
+ <p>
+ Allocates and initializes several arrays used by the sound CPU and sound generation code. Returns <code>false</code> if memory allocation fails.
+ </p>
+ <h3><code>void S9xDeinitAPU (void)</code></h3>
+ <p>
+ Deallocates the allocations made by <code>S9xInitAPU</code> function.
+ </p>
+ <h3><code>bool8 S9xInitSound (int buffer_ms, int lag_ms)</code></h3>
+ <p>
+ Allocates memory for mixing and queueing SNES sound data, does more sound code initialization and opens the host system's sound device by calling <code>S9xOpenSoundDevice</code>, a function you must provide. Before calling this function you must set up <code>Settings.SoundSync</code>, <code>Settings.SixteenBitSound</code>, <code>Settings.SoundPlaybackRate</code>, <code>Settings.SoundInputRate</code> (see section below) and <code>Settings.Stereo</code>.<br>
+ <code>buffer_ms</code>, given in milliseconds, is the memory buffer size for queueing sound data. <code>lag_ms</code> is allowable latency between when a sample is queued and when it is pulled in <code>S9xMixSamples</code>. Set <code>lag_ms</code> to zero if you have your own latency handling code in your port.
+ </p>
+ <h3><code>void S9xReset (void)</code></h3>
+ <p>
+ Resets the SNES emulated hardware back to the state it was in at &ldquo;switch-on&rdquo; except the S-RAM area is preserved (&ldquo;hardware reset&rdquo;). The effect is it resets the current game back to the start. This function is automatically called by <code>Memory.LoadROM</code> function.
+ </p>
+ <h3><code>void S9xSoftReset (void)</code></h3>
+ <p>
+ Similar to <code>S9xReset</code> function, but &ldquo;software reset&rdquo; as you press the SNES reset button.
+ </p>
+ <h3><code>bool8 Memory.LoadROM (const char *filepath)</code></h3>
+ <p>
+ Attempts to load the specified ROM image filename into the emulated ROM area. There are many different SNES ROM image formats and the code attempts to auto-detect as many different types as it can and in a vast majority of the cases gets it right.<br>
+ There are several ROM image options in the <code>Settings</code>structure; allow the user to set them before calling <code>Memory.LoadROM</code> function, or make sure they are all reset to default values before each call to <code>Memory.LoadROM</code> function. See <code>Settings.ForceXXX</code> in <code>snes9x.h</code>.
+ </p>
+ <h3><code>bool8 Memory.LoadMultiCart (const char *cartApath, const char *cartBpath)</code></h3>
+ <p>
+ Attempts to load multiple ROM images into the emulated ROM area, for the multiple cartridge systems such as Sufami Turbo, Same Game, etc.
+ </p>
+ <h3><code>bool8 Memory.LoadSRAM (const char *filepath)</code></h3>
+ <p>
+ Call this function to load the associated S-RAM save file (if any). The filename should be based on the ROM image name to allow easy linkage. The current ports change the directory and the filename extension of the ROM filename to derive the S-RAM filename.
+ </p>
+ <h3><code>bool8 Memory.SaveSRAM (const char *filepath)</code></h3>
+ <p>
+ Call this function to save the emulated S-RAM area into a file so it can be restored again the next time the user wants to play the game. Remember to call this when just before the emulator exits or when the user has been playing a game and is about to load another one.
+ </p>
+ <h3><code>void S9xMainLoop (void)</code></h3>
+ <p>
+ The emulator main loop. Call this from your own main loop that calls this function (if a ROM image is loaded and the game is not paused), processes any pending host system events, then goes back around the loop again until the emulator exits. <code>S9xMainLoop</code> function normally returns control to your main loop once every emulated frame, when it reaches the start of scan-line zero. However it may take a few frames when a huge memory transfer is being emulated. The function can return more often if the <code>DEBUGGER</code> compile-time flag is defined and the CPU has hit a break point, or the <code>DEBUG_MODE_FLAG</code> bit is set in <code>CPU.Flags</code> or instruction single-stepping is enabled.
+ </p>
+ <h3><code>void S9xMixSamples (uint8 *buffer, int sample_count)</code></h3>
+ <p>
+ Call this function from your host sound system handling code to fill <code>buffer</code> with ready-mixed SNES sound data. If 16-bit sound mode is chosen, then the buffer will be filled with an array of <code>sample_count</code> <code>int16</code>, otherwise an array of <code>sample_count</code> <code>uint8</code>. If stereo sound generation is selected the buffer is filled with the same number of samples, but in pairs, first a left channel sample followed by the right channel sample.<br>
+ If there are less queued samples than you request by <code>sample_count</code>, the function fills <code>buffer</code> with silent sound data and returns <code>false</code>. To avoid this shortage of queued samples, request larger buffer size when calling <code>S9xInitSound</code>, and handle sound latency safely.
+ </p>
+ <h3><code>int S9xGetSampleCount (void)</code></h3>
+ <p>
+ Returns the number of sound samples available in the buffer for your configured playback settings.
+ </p>
+ <h3><code>void S9xSetSamplesAvailableCallback (void (*) samples_available (void *), void *data)</code></h3>
+ <p>
+ Call this function to set up a callback that is run when sound samples are made available. <code>samples_available</code> is a function you provide that returns <code>void</code> and takes a pointer as an argument. <code>data</code> is a pointer that you may wish to pass to your callback or can be <code>NULL</code>. If you choose to provide a callback, you must call the provided <code>S9xFinalizeSamples</code> function inside it to actually buffer the samples. If you are using a callback-oriented sound API, it is recommended to set up a function that locks a common mutex during the calls to <code>S9xFinalizeSamples</code> and <code>S9xMixSamples</code> to prevent them from running at the same time and corrupting the sound buffer.<br>
+ If you wish to disable a callback you have set up or need to temporarily shut down your sound system, you may pass <code>NULL</code> for both arguments to revert to the built-in version.
+ </p>
+ <h3><code>bool8 S9xSyncSound (void)</code></h3>
+ <p>
+ Call this function to synchronize the sound buffers to the game state. If Snes9x is generating too much sound data, or a buffer-overrun is likely, this function will return <code>false</code>. In this case, you may wish to wait until your host sound system uses the available samples, and <code>S9xSyncSound</code> returns <code>true</code> before continuing to execute <code>S9xMainLoop</code>.
+ </p>
+ <h3><code>bool8 S9xSetSoundMute (bool8 mute)</code></h3>
+ <p>
+ Call with a <code>true</code> parameter to prevent <code>S9xMixSamples</code> function from processing SNES sample data and instead just filling the return buffer with silent sound data. Useful if your sound system is interrupt or callback driven and the game has been paused either directly or indirectly because the user interacting with the emulator's user interface in some way.
+ </p>
+ <h3><code>bool8 S9xFreezeGame (const char *filepath)</code></h3>
+ <p>
+ Call this function to record the current SNES hardware state into a file, the file can be loaded back using <code>S9xUnfreezeGame</code> function at a later date effectively restoring the current game to exact same spot. Call this function while you're processing any pending system events when <code>S9xMainLoop</code> function has returned control to you in your main loop.
+ </p>
+ <h3><code>bool8 S9xUnfreezeGame (const char *filepath)</code></h3>
+ <p>
+ Restore the SNES hardware back to the exactly the state it was in when <code>S9xFreezeGame</code> function was used to generate the file specified. You have to arrange the correct ROM is already loaded using <code>Memory.LoadROM</code> function, an easy way to arrange this is to base freeze-game filenames on the ROM image name. The UNIX/Linux ports load freeze-game files when the user presses a function key, with the names romfilename.000 for F1, romfilename.001 for F2, etc. Games are frozen in the first place when the user presses Shift-function key. You could choose some other scheme.
+ </p>
+ <h3><code>void S9xDumpSPCSnapshot (void)</code></h3>
+ <p>
+ Call this funtion to make a so-called SPC file, a snapshot of SNES sound state. Actual dump occurs at the first key-on event after this function is called.
+ </p>
+ <h3><code>void S9xSetInfoString (const char *string)</code></h3>
+ <p>
+ Call this function if you want to show a message onto the SNES screen.
+ </p>
+ <h3>Other Available Functions</h3>
+ <p>
+ See <code>movie.h</code> and <code>movie.cpp</code> to support the Snes9x movie feature.<br>
+ See <code>cheats.h</code>, <code>cheats.cpp</code> and <code>cheats2.cpp</code> to support the cheat feature.
+ </p>
+ <h2>Interface Functions You Need to Implement</h2>
+ <h3><code>bool8 S9xOpenSnapshotFile (const char *filepath, bool8 read_only, STREAM *file)</code></h3>
+ <p>
+ This function opens a freeze-game file. <code>STREAM</code> is defined as a <code>gzFile</code> if <code>ZLIB</code> is defined else it's defined as <code>FILE *</code>. The <code>read_only</code> parameter is set to <code>true</code> when reading a freeze-game file and <code>false</code> when writing a freeze-game file. Open the file <code>filepath</code> and return its pointer <code>file</code>.
+ </p>
+ <h3><code>void S9xCloseSnapshotFile (STREAM file)</code></h3>
+ <p>
+ This function closes the freeze-game file opened by <code>S9xOpenSnapshotFile</code> function.
+ </p>
+ <h3><code>void S9xExit (void)</code></h3>
+ <p>
+ Called when some fatal error situation arises or when the &ldquo;q&rdquo; debugger command is used.
+ </p>
+ <h3><code>bool8 S9xInitUpdate (void)</code></h3>
+ <p>
+ Called just before Snes9x begins to render an SNES screen. Use this function if you should prepare before drawing, otherwise let it empty.
+ </p>
+ <h3><code>bool8 S9xDeinitUpdate (int width, int height)</code></h3>
+ <p>
+ Called once a complete SNES screen has been rendered into the <code>GFX.Screen</code> memory buffer, now is your chance to copy the SNES rendered screen to the host computer's screen memory. The problem is that you have to cope with different sized SNES rendered screens: 256*224, 256*239, 512*224, 512*239, 512*448 and 512*478.
+ </p>
+ <h3><code>void S9xMessage (int type, int number, const char *message)</code></h3>
+ <p>
+ When Snes9x wants to display an error, information or warning message, it calls this function. Check in <code>messages.h</code> for the types and individual message numbers that Snes9x currently passes as parameters.<br>
+ The idea is display the message string so the user can see it, but you choose not to display anything at all, or change the message based on the message number or message type.<br>
+ Eventually all debug output will also go via this function, trace information already does.
+ </p>
+ <h3><code>bool8 S9xOpenSoundDevice (void)</code></h3>
+ <p>
+ <code>S9xInitSound</code> function calls this function to actually open the host sound device.
+ </p>
+ <h3><code>const char *S9xGetFilename (const char *extension, enum s9x_getdirtype dirtype)</code></h3>
+ <p>
+ When Snes9x needs to know the name of the cheat/IPS file and so on, this function is called. Check <code>extension</code> and <code>dirtype</code>, and return the appropriate filename. The current ports return the ROM file path with the given extension.
+ </p>
+ <h3><code>const char *S9xGetFilenameInc (const char *extension, enum s9x_getdirtype dirtype)</code></h3>
+ <p>
+ Almost the same as <code>S9xGetFilename</code> function, but used for saving SPC files etc. So you have to take care not to delete the previously saved file, by increasing the number of the filename; romname.000.spc, romname.001.spc, ...
+ </p>
+ <h3><code>const char *S9xGetDirectory (enum s9x_getdirtype dirtype)</code></h3>
+ <p>
+ Called when Snes9x wants to know the directory <code>dirtype</code>.
+ </p>
+ <h3><code>const char *S9xChooseFilename (bool8 read_only)</code></h3>
+ <p>
+ If your port can match Snes9x's built-in <code>LoadFreezeFile</code>/<code>SaveFreezeFile</code> command (see <code>controls.cpp</code>), you may choose to use this function. Otherwise return <code>NULL</code>.
+ </p>
+ <h3><code>const char *S9xChooseMovieFilename (bool8 read_only)</code></h3>
+ <p>
+ If your port can match Snes9x's built-in <code>BeginRecordingMovie</code>/<code>LoadMovie</code> command (see <code>controls.cpp</code>), you may choose to use this function. Otherwise return <code>NULL</code>.
+ </p>
+ <h3><code>const char *S9xBasename (const char *path)</code></h3>
+ <p>
+ Called when Snes9x wants to know the name of the ROM image. Typically, extract the filename from <code>path</code> and return it.
+ </p>
+ <h3><code>void S9xAutoSaveSRAM (void)</code></h3>
+ <p>
+ If <code>Settings.AutoSaveDelay</code> is not zero, Snes9x calls this function when the contents of the S-RAM has been changed. Typically, call <code>Memory.SaveSRAM</code> function from this function.
+ </p>
+ <h3><code>void S9xToggleSoundChannel (int c)</code></h3>
+ <p>
+ If your port can match Snes9x's built-in <code>SoundChannelXXX</code> command (see <code>controls.cpp</code>), you may choose to use this function. Otherwise return <code>NULL</code>. Basically, turn on/off the sound channel <code>c</code> (0-7), and turn on all channels if <code>c</code> is 8.
+ </p>
+ <h3><code>void S9xSetPalette (void)</code></h3>
+ <p>
+ Called when the SNES color palette has changed. Use this function if your system should change its color palette to match the SNES's. Otherwise let it empty.
+ </p>
+ <h3><code>void S9xSyncSpeed (void)</code></h3>
+ <p>
+ Called at the end of <code>S9xMainLoop</code> function, when emulating one frame has been done. You should adjust the frame rate in this function.
+ </p>
+ <h2>Global Variables</h2>
+ <h3><code>uint16 *GFX.Screen</code></h3>
+ <p>
+ A <code>uint16</code> array pointer to (at least) 2*512*478 bytes buffer where Snes9x puts the rendered SNES screen. However, if your port will not support hires mode (<code>Settings.SupportHiRes = false</code>), then a 2*256*239 bytes buffer is allowed. You should allocate the space by yourself. As well you can change the <code>GFX.Screen</code> value after <code>S9xDeinitUpdate</code> function is called so that double-buffering will be easy.
+ </p>
+ <h3><code>uint32 GFX.Pitch</code></h3>
+ <p>
+ Bytes per line (not pixels per line) of the <code>GFX.Screen</code> buffer. Typically set it to 1024. When the SNES screen is 256 pixels width and <code>Settings.OpenGLEnable</code> is <code>false</code>, last half 512 bytes per line are unused. When <code>Settings.OpenGLEnable</code> is <code>true</code>, <code>GFX.Pitch</code> is ignored.
+ </p>
+ <h3>Settings structure</h3>
+ <p>
+ There are various switches in the <code>Settings</code> structure. See <code>snes9x.h</code> for details. At least the settings below are required for good emulation.
+ </p>
+ <p><code>
+ memset(&amp;Settings, 0, sizeof(Settings));<br>
+ Settings.MouseMaster = true;<br>
+ Settings.SuperScopeMaster = true;<br>
+ Settings.JustifierMaster = true;<br>
+ Settings.MultiPlayer5Master = true;<br>
+ Settings.FrameTimePAL = 20000;<br>
+ Settings.FrameTimeNTSC = 16667;<br>
+ Settings.SixteenBitSound = true;<br>
+ Settings.Stereo = true;<br>
+ Settings.SoundPlaybackRate = 32000;<br>
+ Settings.SoundInputRate = 32000;<br>
+ Settings.SupportHiRes = true;<br>
+ Settings.Transparency = true;<br>
+ Settings.AutoDisplayMessages = true;<br>
+ Settings.InitialInfoStringTimeout = 120;<br>
+ Settings.HDMATimingHack = 100;<br>
+ Settings.BlockInvalidVRAMAccessMaster = true;
+ </code></p>
+ <h3><code>Settings.SoundInputRate</code></h3>
+ <p>
+ Adjusts the sound rate through resampling. For every <code>Settings.SoundInputRate</code> samples generated by the SNES, <code>Settings.SoundPlaybackRate</code> samples will be produced.<br>
+ The sound generation rate on a SNES is directly proportional to the video output rate. Displays that synchronize with the vertical refresh but have a slightly lower refresh-rate than the emulated system can experience sound drop-outs. It may be beneficial to provide an option for users to configure <code>Settings.SoundInputRate</code> to suit their own systems. Setting <code>Settings.SoundInputRate</code> to a value that matches the actual output rate (i.e. 31977hz for 59.96hz) or lower will allow the users to eliminate crackling. A range of 31000hz to 33000hz should be inclusive enough for all displays. Use of this setting paired with the <code>S9xSyncSound</code> function can eliminate sound discontinuity.
+ </p>
+ <div style="text-align:right; margin-top:3em">
+ Updated most recently by: 2011/1/16 zones
+ </div>
+ </body>
+</html>
diff --git a/source/docs/portsofsnes9x.txt b/source/docs/portsofsnes9x.txt
new file mode 100644
index 0000000..d05365c
--- /dev/null
+++ b/source/docs/portsofsnes9x.txt
@@ -0,0 +1,118 @@
+These are all the known ports of Snes9X to other consoles/handhelds/etc as of
+2011/04/24. They are all supported and welcomed on the official Snes9X site.
+
+**If you know of anyone who is currently working on a port of Snes9X, or if you
+have some interest in making a port, please have them go to the Snes9X forums
+(http://www.snes9x.com/phpbb2/) and have them register an account there. After
+that, speak to Ryan and/or Jerremy so you can be let into the devs area and the
+git so you can have access to the most current code, collaborate with the other
+developers, make the port officialized, etc.**
+
+Ports and how to get them running are as follows:
+
+*PSP Version of Snes9X*
+Name: Snes9X Euphoria
+Latest version: R5 Beta
+Homepage/forum: http://www.retroemu.com/forum/
+Maintainer: Zack
+
+HOW TO GET IT RUNNING:
+*DISCLAIMER* You will have to do some Googling, including but not limited to:
+* Downgrading/upgrading your firmware
+* Checking if your PSP-2000 series can use Pandora's Battery
+* Checking if your PSP-3000 series can use the DaveeFTW Downgrader
+* Creating Pandora's Battery
+* Finding the hacks, HENs, CFWs, etc and how to use/install them
+
+1. Make sure your PSP is hackable in some way. This means:
+* PSP-1000 series and certain PSP-2000 series can use Pandora Battery
+* PSP-2000 series that can't use Pandora Battery, most PSP-3000 series, and PSP
+Gos are hackable via other means (DaveeFTW Downgrader, etc)
+
+2. Make sure your PSP has custom firmware or a HEN that's useable (you'll have
+to upgrade/downgrade the firmware as necessary). (Hint: I personally prefer
+5.50 GEN-D3 on the Pandora-able PSPs; 6.20 or 6.35 PRO-B4 or better on the
+non-Pandora-able PSPs.)
+
+3. When that’s done, be sure to put the Snes9X Euphoria folder in /PSP/GAME on
+your PSP’s memory stick (PSP-1000/2000/3000 series) or internal memory
+(PSP Go). Be sure to copy the ROMs into the roms folder, saves (*.srm, etc)
+into the saves folder, and cheats into the cheats folder.
+
+*Wii/Gamecube version of Snes9X*
+Name: Snes9X GX
+Latest Version: 4.2.7
+Homepage/forum: http://code.google.com/p/snes9x-gx
+Maintainer: Tantric
+
+HOW TO GET IT RUNNING:
+*DISCLAIMER* You will have to do some Googling, including but not limited to:
+* Finding the latest Homebrew Channel, Snes9X GX Channel, and/or IOS58
+installers and installing them
+* Finding a modchip for your GameCube and installing it
+
+Wii: You will need the latest Homebrew Channel installed on your Wii. After
+that, copy and paste the apps folder onto the root of your SD card; same goes
+for the snes9xgx folder. After that, copy over any ROMs you have to the
+\snes9xgx\roms folder, save files (*.srm, etc) to the \snes9xgx\saves folder,
+and cheats to the \snes9xgx\cheats folder.
+
+In addition, there appears to be a channel for Snes9X GX; you will need the
+Homebrew Channel installed and you MUST be on System Menu 4.3 so you can be on
+IOS58 (or use the IOS58 installer). After that, you should be able to run the
+installer from the Homebrew Channel, and you'll be good to go!
+
+Gamecube: You might need a modchip.
+
+*Android and iOS (Apple iPhone/iPod Touch) version of Snes9X*
+Name: Snes9X EX
+Latest Version: 1.3.23
+Homepage/forum: http://www.explusalpha.com/home/snes9x-ex
+Maintainer: Rakashazi (on the Snes9X forums)
+
+HOW TO GET IT RUNNING:
+*DISCLAIMER* You will have to do some Googling, including but not limited to:
+* iOS (iPhone/iPod Touch) ONLY!!!: Jailbreaking your firmware
+
+Android: It appears you can just download from the Android app-store thingy and
+run it from there :) Be sure to copy over your ROMs, saves, etc though.
+
+iOS: You’ll have to jailbreak your firmware and install the Cydia app
+installer. Then you’ll have to install the BigBoss repository within Cydia and
+search for Snes9X EX; you may also want to search for the sshd and all needed
+stuff for that, as it’s the only way you can put the ROMs, saves, etc onto your
+iPhone/iPod Touch. After that you should be able to download and run from there
+:)
+
+*PS3 version of Snes9X*
+Name: Snes9X PS3
+Latest Version: 4.4.9
+Homepage/forum: https://code.google.com/p/snes9x-ps3/ (although for some
+reason, you may have to Google for the latest version)
+Maintainer: Squarepusher
+
+HOW TO GET IT RUNNING:
+*DISCLAIMER* You will have to do some Googling, including but not limited to:
+* Finding a HEN/Jailbreaker/CFW/etc onto your PS3 and installing it
+* (if necessary) Downgrading/Upgrading your PS3's firmware
+
+You’ll have to install a HEN/Jailbreaker/CFW/etc on your PS3 (you might have to
+upgrade or downgrade your PS3’s firmware as needed). After that, it should be
+as simple as copy the emulator, ROMs, saves, etc over to the PS3 and it should
+work :)
+
+*X-Box Version of Snes9X*
+Name: Snes9xbox
+Latest Version: V2 (V3 should be out soon)
+Homepage/forum: http://forums.xbox-scene.com/index.php?showforum=96
+
+HOW TO GET IT RUNNING:
+*DISCLAIMER* You will need to do some Googling, including but not limited to:
+* Finding a softmod (hack) or a modchip and installing/using it
+* Finding a replacement dashboard such as XBMC
+
+Really, it's not hard. Read the readme, and use a softmod or modchip and a
+replacement dashboard. After that's installed, it should be as simple as
+copying over the emulator, ROMs, saves, etc to the X-Box and it should work.
+
+Updated most recently by: 2011/4/24 adventure_of_link \ No newline at end of file
diff --git a/source/docs/snapshots.txt b/source/docs/snapshots.txt
new file mode 100644
index 0000000..ef0d1fd
--- /dev/null
+++ b/source/docs/snapshots.txt
@@ -0,0 +1,84 @@
+***** Important notice ********************************************************
+ This document describes the snapshot file format for Snes9x 1.52 and later,
+ not compatible with 1.51.
+*******************************************************************************
+
+ Snes9x snapshot file format: (may be gzip-compressed)
+
+ Begins with fixed length signature, consisting of a string, ':', a 4-digit
+ decimal version, and a '\n'.
+
+#!s9xsnp:0006 <-- '\n' after the 6
+
+ Then we have various blocks. The block format is: 3-character block name,
+ ':', 6-digit length, ':', then the data. Blocks are written in a defined
+ order. Structs are written packed with their members in a defined order, in
+ big-endian order where applicable.
+
+NAM:000019:Chrono Trigger.zip
+
+ Currently defined blocks (in order) are:
+
+ Essential parts:
+ NAM - ROM filename, from Memory.ROMFilename. 0-terminated string.
+ CPU - struct SCPUState, CPU internal state variables.
+ REG - struct SRegisters, emulated CPU registers.
+ PPU - struct SPPU, PPU internal variables. Note that IPPU is never saved.
+ DMA - struct SDMA, DMA/HDMA state variables.
+ VRA - Memory.VRAM, 0x10000 bytes.
+ RAM - Memory.RAM, 0x20000 bytes (WRAM).
+ SRA - Memory.SRAM, 0x20000 bytes.
+ FIL - Memory.FillRAM, 0x8000 bytes (register backing store).
+ SND - All of sound emulated registers and state valiables.
+ CTL - struct SControlSnapshot, controller emulation.
+ TIM - struct STimings, variables about timings between emulated events.
+
+ Optional parts:
+ SFX - struct FxRegs_s, Super FX.
+ SA1 - struct SSA1, SA1 internal state variables.
+ SAR - struct SSA1Registers, SA1 emulated registers.
+ DP1 - struct SDSP1, DSP-1.
+ DP2 - struct SDSP2, DSP-2.
+ DP4 - struct SDSP4, DSP-4.
+ CX4 - Memory.C4RAM, 0x2000 bytes.
+ ST0 - struct SST010, ST-010.
+ OBC - struct SOBC1, OBC1 internal state variables.
+ OBM - Memory.OBC1RAM, 0x2000 byts.
+ S71 - struct SSPC7110Snapshot, SPC7110.
+ SRT - struct SSRTCSnapshot, S-RTC internal state variables.
+ CLK - struct SRTCData, S-RTC emulated registers.
+ BSX - struct SBSX, BS-X.
+ SHO - rendered SNES screen.
+ MOV - struct SnapshotMovieInfo.
+ MID - Some block of data the movie subsystem.
+
+==================
+
+Without changing the snapshot version number:
+---------------------------------------------
+
+Blocks may be safely added at the END of the file, as anything after the last
+block is ignored. Blocks may not be moved or removed.
+
+Blocks may not decrease in size. Say you decrease from 10 bytes to 5. Then
+later you increase back to 8. The only way you could safely do this is if
+bytes 5-7 still mean the same thing they meant when the block was 10 bytes
+long.
+
+Blocks may increase in size as you wish, as long as you can handle old
+savestates with the old shorter size.
+
+Struct members may not change in interpretation. New struct members may be
+added (at the END!) only if you can cope with them being binary-0 in older
+savestates. Struct members may not be removed or changed in size/type.
+
+With changing the snapshot version number:
+------------------------------------------
+
+Blocks may be added, moved, or removed at will.
+
+Blocks may decrease in size.
+
+Struct members may be added, moved, or deleted, and their
+interpretations/types may be changed. Use the 'debuted_in' and 'deleted_in'
+fields to indicate when the new member debuted or the old member went away.
diff --git a/source/docs/snes9x-license.txt b/source/docs/snes9x-license.txt
new file mode 100644
index 0000000..19d5fd6
--- /dev/null
+++ b/source/docs/snes9x-license.txt
@@ -0,0 +1,174 @@
+ Snes9x - Portable Super Nintendo Entertainment System (TM) emulator.
+
+ (c) Copyright 1996 - 2002 Gary Henderson (gary.henderson@ntlworld.com),
+ Jerremy Koot (jkoot@snes9x.com)
+
+ (c) Copyright 2002 - 2004 Matthew Kendora
+
+ (c) Copyright 2002 - 2005 Peter Bortas (peter@bortas.org)
+
+ (c) Copyright 2004 - 2005 Joel Yliluoma (http://iki.fi/bisqwit/)
+
+ (c) Copyright 2001 - 2006 John Weidman (jweidman@slip.net)
+
+ (c) Copyright 2002 - 2006 funkyass (funkyass@spam.shaw.ca),
+ Kris Bleakley (codeviolation@hotmail.com)
+
+ (c) Copyright 2002 - 2010 Brad Jorsch (anomie@users.sourceforge.net),
+ Nach (n-a-c-h@users.sourceforge.net),
+
+ (c) Copyright 2002 - 2011 zones (kasumitokoduck@yahoo.com)
+
+ (c) Copyright 2006 - 2007 nitsuja
+
+ (c) Copyright 2009 - 2011 BearOso,
+ OV2
+
+
+ BS-X C emulator code
+ (c) Copyright 2005 - 2006 Dreamer Nom,
+ zones
+
+ C4 x86 assembler and some C emulation code
+ (c) Copyright 2000 - 2003 _Demo_ (_demo_@zsnes.com),
+ Nach,
+ zsKnight (zsknight@zsnes.com)
+
+ C4 C++ code
+ (c) Copyright 2003 - 2006 Brad Jorsch,
+ Nach
+
+ DSP-1 emulator code
+ (c) Copyright 1998 - 2006 _Demo_,
+ Andreas Naive (andreasnaive@gmail.com),
+ Gary Henderson,
+ Ivar (ivar@snes9x.com),
+ John Weidman,
+ Kris Bleakley,
+ Matthew Kendora,
+ Nach,
+ neviksti (neviksti@hotmail.com)
+
+ DSP-2 emulator code
+ (c) Copyright 2003 John Weidman,
+ Kris Bleakley,
+ Lord Nightmare (lord_nightmare@users.sourceforge.net),
+ Matthew Kendora,
+ neviksti
+
+ DSP-3 emulator code
+ (c) Copyright 2003 - 2006 John Weidman,
+ Kris Bleakley,
+ Lancer,
+ z80 gaiden
+
+ DSP-4 emulator code
+ (c) Copyright 2004 - 2006 Dreamer Nom,
+ John Weidman,
+ Kris Bleakley,
+ Nach,
+ z80 gaiden
+
+ OBC1 emulator code
+ (c) Copyright 2001 - 2004 zsKnight,
+ pagefault (pagefault@zsnes.com),
+ Kris Bleakley
+ Ported from x86 assembler to C by sanmaiwashi
+
+ SPC7110 and RTC C++ emulator code used in 1.39-1.51
+ (c) Copyright 2002 Matthew Kendora with research by
+ zsKnight,
+ John Weidman,
+ Dark Force
+
+ SPC7110 and RTC C++ emulator code used in 1.52+
+ (c) Copyright 2009 byuu,
+ neviksti
+
+ S-DD1 C emulator code
+ (c) Copyright 2003 Brad Jorsch with research by
+ Andreas Naive,
+ John Weidman
+
+ S-RTC C emulator code
+ (c) Copyright 2001 - 2006 byuu,
+ John Weidman
+
+ ST010 C++ emulator code
+ (c) Copyright 2003 Feather,
+ John Weidman,
+ Kris Bleakley,
+ Matthew Kendora
+
+ Super FX x86 assembler emulator code
+ (c) Copyright 1998 - 2003 _Demo_,
+ pagefault,
+ zsKnight
+
+ Super FX C emulator code
+ (c) Copyright 1997 - 1999 Ivar,
+ Gary Henderson,
+ John Weidman
+
+ Sound emulator code used in 1.5-1.51
+ (c) Copyright 1998 - 2003 Brad Martin
+ (c) Copyright 1998 - 2006 Charles Bilyue'
+
+ Sound emulator code used in 1.52+
+ (c) Copyright 2004 - 2007 Shay Green (gblargg@gmail.com)
+
+ SH assembler code partly based on x86 assembler code
+ (c) Copyright 2002 - 2004 Marcus Comstedt (marcus@mc.pp.se)
+
+ 2xSaI filter
+ (c) Copyright 1999 - 2001 Derek Liauw Kie Fa
+
+ HQ2x, HQ3x, HQ4x filters
+ (c) Copyright 2003 Maxim Stepin (maxim@hiend3d.com)
+
+ NTSC filter
+ (c) Copyright 2006 - 2007 Shay Green
+
+ GTK+ GUI code
+ (c) Copyright 2004 - 2011 BearOso
+
+ Win32 GUI code
+ (c) Copyright 2003 - 2006 blip,
+ funkyass,
+ Matthew Kendora,
+ Nach,
+ nitsuja
+ (c) Copyright 2009 - 2011 OV2
+
+ Mac OS GUI code
+ (c) Copyright 1998 - 2001 John Stiles
+ (c) Copyright 2001 - 2011 zones
+
+
+ Specific ports contains the works of other authors. See headers in
+ individual files.
+
+
+ Snes9x homepage: http://www.snes9x.com/
+
+ Permission to use, copy, modify and/or distribute Snes9x in both binary
+ and source form, for non-commercial purposes, is hereby granted without
+ fee, providing that this license information and copyright notice appear
+ with all copies and any derived work.
+
+ This software is provided 'as-is', without any express or implied
+ warranty. In no event shall the authors be held liable for any damages
+ arising from the use of this software or it's derivatives.
+
+ Snes9x is freeware for PERSONAL USE only. Commercial users should
+ seek permission of the copyright holders first. Commercial use includes,
+ but is not limited to, charging money for Snes9x or software derived from
+ Snes9x, including Snes9x or derivatives in commercial game bundles, and/or
+ using Snes9x as a promotion for your commercial product.
+
+ The copyright holders request that bug fixes and improvements to the code
+ should be forwarded to them so everyone can benefit from the modifications
+ in future versions.
+
+ Super NES and Super Nintendo Entertainment System are trademarks of
+ Nintendo Co., Limited and its subsidiary companies.
diff --git a/source/docs/snes9x.conf.default b/source/docs/snes9x.conf.default
new file mode 100644
index 0000000..4f36d25
--- /dev/null
+++ b/source/docs/snes9x.conf.default
@@ -0,0 +1,238 @@
+#-----------------------------------------
+# snes9x.conf : Snes9x Configuration file
+#-----------------------------------------
+
+[ROM]
+# Filename =
+LoROM = FALSE
+HiROM = FALSE
+PAL = FALSE
+NTSC = FALSE
+# Header = TRUE/FALSE to ForceHeader or ForceNoHeader
+# Interleaved = TRUE/FALSE to ForceInterleaved or ForceNoInterleaved
+Interleaved2 = FALSE
+InterleaveGD24 = FALSE
+Cheat = FALSE
+Patch = TRUE
+
+[Sound]
+Sync = FALSE
+16BitSound = TRUE
+Stereo = TRUE
+ReverseStereo = FALSE
+Rate = 32000
+InputRate = 32000
+Mute = FALSE
+
+[Display]
+HiRes = TRUE
+Transparency = TRUE
+GraphicWindows = TRUE
+DisplayFrameRate = FALSE
+DisplayWatchedAddresses = FALSE
+DisplayInput = FALSE
+DisplayFrameCount = FALSE
+MessagesInImage = TRUE
+MessageDisplayTime = 120
+
+[Settings]
+BSXBootup = FALSE
+# FrameTime =
+FrameSkip = Auto
+TurboMode = FALSE
+TurboFrameSkip = 15
+MovieTruncateAtEnd = FALSE
+MovieNotifyIgnored = FALSE
+WrongMovieStateProtection = TRUE
+StretchScreenshots = 1
+SnapshotScreenshots = TRUE
+DontSaveOopsSnapshot = FALSE
+AutoSaveDelay = 0
+
+[Controls]
+MouseMaster = TRUE
+SuperscopeMaster = TRUE
+JustifierMaster = TRUE
+MP5Master = TRUE
+AllowLeftRight = FALSE
+Port1 = pad1
+Port2 = none
+Mouse1Crosshair = 1 White/Black
+Mouse2Crosshair = 1 White/Black
+SuperscopeCrosshair = 2 White/Black
+Justifier1Crosshair = 4 Blue/Black
+Justifier2Crosshair = 4 MagicPink/Black
+
+[Hack]
+EnableGameSpecificHacks = TRUE
+AllowInvalidVRAMAccess = FALSE
+SpeedHacks = FALSE
+HDMATiming = 100
+
+[Netplay]
+Enable = FALSE
+Port = 6096
+Server = ""
+
+[DEBUG]
+Debugger = FALSE
+Trace = FALSE
+
+[Unix]
+# BaseDir = ~/.snes9x
+# SnapshotFilename =
+# PlayMovieFilename =
+# RecordMovieFilename =
+EnableGamePad = TRUE
+PadDevice1 = (null)
+PadDevice2 = (null)
+PadDevice3 = (null)
+PadDevice4 = (null)
+PadDevice5 = (null)
+PadDevice6 = (null)
+PadDevice7 = (null)
+PadDevice8 = (null)
+ThreadSound = FALSE
+SoundBufferSize = 100
+SoundFragmentSize = 2048
+# SoundDevice =
+ClearAllControls = FALSE
+
+[Unix/X11]
+SetKeyRepeat = TRUE
+VideoMode = 1
+
+[Unix/X11 Controls]
+J00:Axis1 = Joypad1 Axis Up/Down T=50%
+J00:Axis0 = Joypad1 Axis Left/Right T=50%
+J00:B1 = Joypad1 A
+J00:B2 = Joypad1 B
+J00:B0 = Joypad1 X
+J00:B3 = Joypad1 Y
+J00:B6 = Joypad1 L
+J00:B7 = Joypad1 R
+J00:B8 = Joypad1 Select
+J00:B11 = Joypad1 Start
+K00:u = Joypad1 Up
+K00:Up = Joypad1 Up
+K00:j = Joypad1 Down
+K00:n = Joypad1 Down
+K00:Down = Joypad1 Down
+K00:h = Joypad1 Left
+K00:Left = Joypad1 Left
+K00:k = Joypad1 Right
+K00:Right = Joypad1 Right
+K00:d = Joypad1 A
+K00:S+d = Joypad1 ToggleTurbo A
+K00:C+d = Joypad1 ToggleSticky A
+K00:c = Joypad1 B
+K00:S+c = Joypad1 ToggleTurbo B
+K00:C+c = Joypad1 ToggleSticky B
+K00:s = Joypad1 X
+K00:S+s = Joypad1 ToggleTurbo X
+K00:C+s = Joypad1 ToggleSticky X
+K00:x = Joypad1 Y
+K00:S+x = Joypad1 ToggleTurbo Y
+K00:C+x = Joypad1 ToggleSticky Y
+K00:a = Joypad1 L
+K00:v = Joypad1 L
+K00:S+a = Joypad1 ToggleTurbo L
+K00:S+v = Joypad1 ToggleTurbo L
+K00:C+a = Joypad1 ToggleSticky L
+K00:C+v = Joypad1 ToggleSticky L
+K00:z = Joypad1 R
+K00:S+z = Joypad1 ToggleTurbo R
+K00:C+z = Joypad1 ToggleSticky R
+K00:space = Joypad1 Select
+K00:Return = Joypad1 Start
+K00:KP_Up = Joypad2 Up
+K00:KP_Down = Joypad2 Down
+K00:KP_Left = Joypad2 Left
+K00:KP_Right = Joypad2 Right
+K00:Prior = Joypad2 A
+K00:Next = Joypad2 B
+K00:Home = Joypad2 X
+K00:End = Joypad2 Y
+K00:Insert = Joypad2 L
+K00:Delete = Joypad2 R
+K00:KP_Add = Joypad2 Select
+K00:KP_Enter = Joypad2 Start
+K00:Escape = ExitEmu
+K00:Pause = Pause
+K00:Scroll_Lock = Pause
+K00:CS+Escape = Reset
+K00:S+Escape = SoftReset
+K00:F12 = SaveFreezeFile
+K00:A+F3 = SaveFreezeFile
+K00:C+F3 = SaveFreezeFile
+K00:F11 = LoadFreezeFile
+K00:A+F2 = LoadFreezeFile
+K00:C+F2 = LoadFreezeFile
+K00:S+F1 = QuickSave000
+K00:S+F2 = QuickSave001
+K00:S+F3 = QuickSave002
+K00:S+F4 = QuickSave003
+K00:S+F5 = QuickSave004
+K00:S+F6 = QuickSave005
+K00:S+F7 = QuickSave006
+K00:S+F8 = QuickSave007
+K00:S+F9 = QuickSave008
+K00:F1 = QuickLoad000
+K00:F2 = QuickLoad001
+K00:F3 = QuickLoad002
+K00:F4 = QuickLoad003
+K00:F5 = QuickLoad004
+K00:F6 = QuickLoad005
+K00:F7 = QuickLoad006
+K00:F8 = QuickLoad007
+K00:F9 = QuickLoad008
+K00:F10 = LoadOopsFile
+K00:A+F1 = SaveSPC
+K00:C+F1 = SaveSPC
+K00:Print = Screenshot
+K00:S+1 = BeginRecordingMovie
+K00:S+2 = EndRecordingMovie
+K00:S+3 = LoadMovie
+K00:Tab = EmuTurbo
+K00:S+Tab = ToggleEmuTurbo
+K00:equal = IncFrameRate
+K00:minus = DecFrameRate
+K00:S+equal = IncFrameTime
+K00:S+minus = DecFrameTime
+K00:A+equal = IncEmuTurbo
+K00:A+minus = DecEmuTurbo
+K00:C+equal = IncTurboSpeed
+K00:C+minus = DecTurboSpeed
+K00:6 = SwapJoypads
+K00:A+F4 = SoundChannel0
+K00:C+F4 = SoundChannel0
+K00:A+F5 = SoundChannel1
+K00:C+F5 = SoundChannel1
+K00:A+F6 = SoundChannel2
+K00:C+F6 = SoundChannel2
+K00:A+F7 = SoundChannel3
+K00:C+F7 = SoundChannel3
+K00:A+F8 = SoundChannel4
+K00:C+F8 = SoundChannel4
+K00:A+F9 = SoundChannel5
+K00:C+F9 = SoundChannel5
+K00:A+F10 = SoundChannel6
+K00:C+F10 = SoundChannel6
+K00:A+F11 = SoundChannel7
+K00:C+F11 = SoundChannel7
+K00:A+F12 = SoundChannelsOn
+K00:C+F12 = SoundChannelsOn
+K00:1 = ToggleBG0
+K00:2 = ToggleBG1
+K00:3 = ToggleBG2
+K00:4 = ToggleBG3
+K00:5 = ToggleSprites
+K00:9 = ToggleTransparency
+K00:BackSpace = ClipWindows
+K00:A+Escape = Debugger
+M00:Pointer = Pointer Mouse1+Superscope+Justifier1
+M00:B0 = {Mouse1 L,Superscope Fire,Justifier1 Trigger}
+M00:B2 = {Mouse1 R,Superscope Cursor,Justifier1 Start}
+M00:B1 = {Justifier1 AimOffscreen Trigger,Superscope AimOffscreen}
+K00:grave = Superscope ToggleTurbo
+K00:slash = Superscope Pause