2002-04-22 01:45:08 +00:00
|
|
|
<html>
|
2004-07-14 05:30:28 +00:00
|
|
|
<head>
|
2002-04-22 01:45:08 +00:00
|
|
|
<title>Stella - A multi-platform Atari 2600 VCS emulator</title>
|
2004-07-14 05:30:28 +00:00
|
|
|
<meta name="AppleTitle" content="docs">
|
|
|
|
</head>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<body bgcolor="#FFFFFF">
|
|
|
|
|
|
|
|
<center><b><font size="7">Stella</font></b></center>
|
|
|
|
<br><br>
|
|
|
|
<center><h2><b>A multi-platform Atari 2600 VCS emulator</b></h2></center>
|
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<center><h4><b>Release 2.5</b></h4></center>
|
2004-05-24 19:03:19 +00:00
|
|
|
<br><br>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<center><h2><b>User's Guide</b></h2></center>
|
2004-05-24 19:03:19 +00:00
|
|
|
<br><br>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<ol>
|
|
|
|
<li><a href="#Introduction">Introduction</a></li>
|
|
|
|
<li><a href="#Requirements">What You Will Need</a></li>
|
|
|
|
<li><a href="#Installation">Installation</a></li>
|
|
|
|
<li><a href="#Games">Games</a></li>
|
|
|
|
<li><a href="#Starting">Starting A Game</a></li>
|
2005-05-28 23:57:10 +00:00
|
|
|
<li><a href="#Options">Changing Options</a></li>
|
2002-04-22 01:45:08 +00:00
|
|
|
<li><a href="#Keyboard">Keyboard Layout</a></li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li><a href="#Remapping">Event Remapping</a></li>
|
2008-03-26 00:52:05 +00:00
|
|
|
<li><a href="#ROMInfo">Viewing ROM Info</a></li>
|
|
|
|
<li><a href="#ROMAudit">ROM Audit Mode</a></li>
|
2007-07-27 13:49:16 +00:00
|
|
|
<li><a href="#Adaptor">Stelladaptor Support</a></li>
|
2005-05-28 23:57:10 +00:00
|
|
|
<li><a href="#Debugger">Integrated Debugger</a></li>
|
2007-07-27 13:49:16 +00:00
|
|
|
<li><a href="#Settings">Settings File</a></li>
|
|
|
|
<li><a href="#Cheats">Cheatcode Manager</a></li>
|
2002-04-22 01:45:08 +00:00
|
|
|
<li><a href="#Properties">Game Properties</a></li>
|
2006-12-13 00:05:46 +00:00
|
|
|
<li><a href="#Palette">Palette Support</a></li>
|
2002-04-22 01:45:08 +00:00
|
|
|
<li><a href="#Acknowledgments">Acknowledgments</a></li>
|
|
|
|
<li><a href="#License">License and Disclaimer</a></li>
|
|
|
|
</ol>
|
|
|
|
|
2004-05-24 19:03:19 +00:00
|
|
|
<br><br><br>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<center><b>February 1999 - March 2008</b></center>
|
2002-04-22 01:45:08 +00:00
|
|
|
<center><b>The Stella Team</b></center>
|
|
|
|
<center><b><a href="http://stella.sourceforge.net">Stella Homepage</a></b></center>
|
|
|
|
|
|
|
|
<br><br><br>
|
|
|
|
|
|
|
|
<br><br>
|
|
|
|
<h1><b>A Brief History of the Atari 2600</b></h1>
|
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p><a><img src="graphics/console.png" ALIGN=RIGHT></a>
|
|
|
|
In the early 1970's, video arcade games gained commercial success for the
|
|
|
|
first time. The American public was introduced to Pong, Tank, and other
|
|
|
|
interactive video games which populated amusement parks, bars, and arcades.
|
|
|
|
The games were successful enough to create interest for home versions, so in
|
|
|
|
1975 Atari released Home Pong and it was a smash hit. Other companies such as
|
|
|
|
Magnavox and Coleco followed suit and released their own dedicated console
|
|
|
|
games. Then in 1976, Fairchild Camera and Instrument introduced the Channel F
|
|
|
|
system, the first cartridge based home video game system. The industry
|
|
|
|
recognized that cartridge systems were the future of video gaming, and began
|
|
|
|
development in that direction. In January 1977, RCA released the Studio II,
|
|
|
|
another cartridge based system, although it only projected in black and white
|
|
|
|
and seemed to be focused on educational titles. Then, in October 1977, Atari
|
|
|
|
released the Atari VCS (Video Computer System) with an initial offering of nine
|
|
|
|
games. This system, later renamed the Atari 2600, took the industry by storm
|
|
|
|
and dominated the marketplace for years to come.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p><a><img src="graphics/chucky_cheese.png" ALIGN=LEFT></a>
|
|
|
|
Because of oversupply, the Christmas season of 1977 was very rough on the
|
|
|
|
video game industry, and the Atari 2600 was the only system that managed to
|
|
|
|
emerge unscathed. Atari enjoyed strong sales in 1978 and a fantastic holiday
|
|
|
|
season, as Atari released more games such as Outlaw, Spacewar, and Breakout.
|
|
|
|
Internally however, Atari was at odds. Nolan Bushnell, the inventor of pong and
|
|
|
|
founder of Atari, wound up leaving the company and purchased Pizza Time Theater,
|
|
|
|
which later became the successful Chuck E. Cheese! In 1979 Atari continued
|
|
|
|
their trend and released 12 more games which met with continued success.
|
|
|
|
However, Atari was now facing some stiffer competition from the Mattel
|
|
|
|
Intellivision and the Magnavox Odyssey2.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p><a><img src="graphics/space_invaders.png" ALIGN=RIGHT></a>
|
|
|
|
Atari needed a mega-hit in 1980 in order to squash the competition, and they
|
|
|
|
found it in the home version of a game from Japan called Space Invaders. It was
|
|
|
|
so popular that people were buying the Atari 2600 just so they could play Space
|
|
|
|
Invaders at home. Following that, Atari released Adventure, which was the first
|
|
|
|
video game to contain an Easter Egg - placing an object in a certain area
|
|
|
|
revealed the programmer's name, Warren Robinett. 1980 was important for another
|
|
|
|
reason - the creation of the first ever third party software producer, Activision.
|
|
|
|
The company was formed by four Atari employees who were unsatisfied with the
|
|
|
|
working conditions at the company. They released four games initially: Dragster,
|
|
|
|
Fishing Derby, Checkers and Boxing. The games were very well received by the
|
|
|
|
public, and revealed that the Atari 2600 was capable of better games than
|
|
|
|
Atari themselves had been producing. Atari tried to prevent Activision from
|
|
|
|
selling games, but they failed and Activision grossed $70 million that year.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
By 1981, the video game industry was basically a horse race between the 2600
|
|
|
|
and the Intellivision. While the Intellivision was technologically superior in
|
|
|
|
some respects, the 2600 continued to lead in sales. Atari released the home
|
|
|
|
version of Asteroids, which was a huge success. Inspired by the success of
|
|
|
|
Activision, another software development group called Imagic was formed. They
|
|
|
|
would not release any games until 1982 however. Another company, Games by Apollo,
|
|
|
|
was formed in Texas and released several games that year.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Coleco entered the market in 1982 with the release of the graphically
|
|
|
|
superior Colecovision. To combat this new system, Atari produced the 5200,
|
|
|
|
a technologically comparable system. The 2600 dropped $100 in price in order
|
|
|
|
to remain competitive. Then a company called Arcadia released a peripheral
|
|
|
|
called the Supercharger which played games in an audio cassette medium. This
|
|
|
|
allowed for multiple loads and expanded the 2600's capabilities.
|
|
|
|
<p><a><img src="graphics/pacman.png" ALIGN=LEFT></a>
|
|
|
|
Atari released Pac-Man and E.T. that year, two incredibly hyped games which
|
|
|
|
were critical flops.
|
|
|
|
Although Pac-Man sold many copies, it was considered to be a poor
|
|
|
|
translation of the arcade hit. However, there were many fantastic games
|
|
|
|
produced for the 2600 during this period, and it was still selling strong.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Ever since the inception of Activision, Atari had been fighting to keep third
|
|
|
|
parties from producing cartridges which they felt were stealing profits from
|
|
|
|
them. Finally the issue was settled when Atari agreed to allow third party
|
|
|
|
manufacturing in exchange for a royalty. Suddenly software companies began
|
|
|
|
popping up all over, and 1982 saw releases from companies like Venturevision,
|
|
|
|
Spectravision, Telesys, CBS, 20th Century Fox, US Games, M Network, Tigervision,
|
|
|
|
Data Age, Imagic and Coleco. There was even a company that released a line of
|
|
|
|
X-Rated games for the 2600 called Mystique. The year was financially successful
|
|
|
|
for Atari, however there seemed to be a glut of software. Although there were
|
|
|
|
many quality titles still produced, there was an increasing number of rushed
|
|
|
|
games as manufacturers attempted to cash in on the craze.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
More companies jumped on the band wagon in 1983. Zimag, Ultravision, Amiga,
|
|
|
|
and others were also producing games and peripherals. It seemed as if there was
|
|
|
|
just too much product to meet the demand, and as it turned out there was. By
|
|
|
|
the end of the year, companies began folding. US Games, Data Age, Games by
|
|
|
|
Apollo, Telesys and others all closed their doors from poor sales. A video
|
|
|
|
game crash was occurring, and all companies were taking it on the chin.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
1984 was a much more subdued year for the Atari 2600, and the price of the
|
|
|
|
system had now dropped to $40-$50. Many were saying that the video game
|
|
|
|
industry was dead. However, Atari surprised everyone by announcing the release
|
|
|
|
of the 7800, and also promising more 2600 games with improved graphics and
|
|
|
|
sound. Unfortunately, neither of these things happened in 1984 because Atari
|
|
|
|
sold their home video game division to Jack Tramiel who believed that home
|
|
|
|
computers would replace video game systems. No further mention of the 2600 or
|
|
|
|
7800 was made that year, and it appeared that they might be dead.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
1985 was another very quiet year for Atari and video games in general, and only
|
|
|
|
a few games were released for the 2600. Activision produced Cosmic Commuter and
|
|
|
|
Ghostbusters, but with little fanfare or marketing, these games did not sell
|
|
|
|
well. However, because of the huge game library and cheap price, Atari still
|
|
|
|
sold over a million 2600 consoles in 1985.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
There were very few plans for home video game systems by any company in 1986,
|
|
|
|
since the market appeared to be dead. Then, to most people's surprise, Nintendo
|
|
|
|
brought the NES to America and it was a smash hit, proving that video games
|
|
|
|
still had a place in the US. Atari decided that maybe it would be a good idea
|
|
|
|
to release the 7800 units it had in storage, and produce some more 2600 games.
|
|
|
|
The 7800 was released with only 3 games initially available, although it was
|
|
|
|
compatible with the 2600 library. They also redesigned the 2600 as the 2600 Jr.,
|
|
|
|
a machine with the same abilities, but a new look and marketing campaign. It
|
|
|
|
was sold for less than $50.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p><a><img src="graphics/jr_pacman.png" ALIGN=RIGHT></a>
|
|
|
|
Video games were once again selling phenomenally in 1987. Atari released
|
|
|
|
several new titles, including Jr. Pac-Man, and also licensed a number of games
|
|
|
|
from other companies such as Donkey Kong and Q*Bert. These new titles sold for
|
|
|
|
$10-$15. Interestingly, a number of titles began appearing again from third
|
|
|
|
part companies such as Epyx, Froggo, and Exus. It seemed that the 2600 was not
|
|
|
|
dead yet!
|
|
|
|
<p><a><img src="graphics/secret_quest.png" ALIGN=LEFT></a>
|
|
|
|
In 1988, Atari rehired Nolan Bushnell and announced a number of new
|
|
|
|
titles, including Secret Quest, a game written by Mr. Bushnell himself. Atari
|
|
|
|
continued to manufacture these games even until 1989. However, it was apparent
|
|
|
|
that the 2600, after its introduction over a decade ago, was finally at the end
|
|
|
|
of its run. Although it was still produced and marketed outside of the US, the
|
|
|
|
Atari 2600 finished its run in America. No other console has had such a long
|
|
|
|
history or sold as many systems in the U.S.
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Today, the 2600 still has a large number of fans who remember the countless
|
|
|
|
games played over the years, and the years to come. There are even games being
|
|
|
|
produced by hobbyists, some of them quite professionally, being released on
|
|
|
|
newly burnt cartridges with labels and manuals. And the recent trend in
|
|
|
|
retrogaming has brought many more video game fans to rediscover the 2600, and
|
|
|
|
it continues to live on 22 years after its release!
|
|
|
|
</p>
|
|
|
|
|
|
|
|
<p><i>Alexander Bilstein<br>February 1999</i></p>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2002-04-22 01:45:08 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
|
|
|
<a name="Introduction">1. Introduction</a></h1>
|
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
Stella is a freely distributed multi-platform Atari 2600 VCS emulator; originally
|
|
|
|
developed for Linux by Bradford W. Mott. Stella allows you to enjoy all of
|
|
|
|
your favorite 2600 games once again by emulating the 2600's hardware with
|
|
|
|
software. Stella is written in C++, which allows it to be ported to other
|
|
|
|
operating systems and architectures. Since its original release Stella has
|
|
|
|
been ported to AcornOS, AmigaOS, DOS, FreeBSD, Linux, MacOS, OpenStep, OS/2,
|
2005-01-04 02:29:31 +00:00
|
|
|
Sega Dreamcast, Unix, and Windows.
|
2002-04-22 01:45:08 +00:00
|
|
|
</p>
|
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<h2><b>New in Release 2.5</b></h2>
|
2002-11-03 22:22:32 +00:00
|
|
|
|
|
|
|
<ul>
|
2008-03-26 00:52:05 +00:00
|
|
|
<li>Added RomInfo widget to the ROM launcher, which shows properties
|
|
|
|
information and a snapshot of the currently selected ROM. Updated the UI
|
|
|
|
and added '-romviewer' commandline argument to activate this setting.
|
|
|
|
Note that the ROM launcher will have to be sized at least 640x480 for this
|
|
|
|
to be used. Also note that the snapshots must be in 1x mode with a
|
|
|
|
maximum size of 320x260. This will be expanded on in a future release.</li>
|
2006-12-18 16:44:40 +00:00
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<li>Added ROM audit functionality, whereby ROMs can be physically renamed
|
|
|
|
according to their properties' name.</li>
|
2006-12-13 00:05:46 +00:00
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<li>Added bankswitching support for 0840, SB, X07 and 4A50. A special thanks
|
|
|
|
to Eckhard Stolberg for much help in this area.</li>
|
|
|
|
|
|
|
|
<li>Removed "non-browse" functionality from the ROM launcher; it now always
|
|
|
|
uses browse/filesystem mode. The previous 'pretty' names can now be
|
|
|
|
seen by renaming all your ROMs with the new ROM audit feature.</li>
|
|
|
|
|
|
|
|
<li>Huge overhaul of controller handling and Stelladaptor support, making it
|
|
|
|
much easier to add new controller types in a future release.</li>
|
|
|
|
|
|
|
|
<li>Fixed paddle issues in Night Driver; paddle emulation speed should be
|
|
|
|
much better.</li>
|
|
|
|
|
|
|
|
<li>Fixed several 6507 emulation bugs related to BCD handling.</li>
|
|
|
|
|
|
|
|
<li>Updated ROM properties based on info from RomHunter.</li>
|
|
|
|
|
|
|
|
<li>ROM properties can now be edited from the ROM launcher; you no longer
|
|
|
|
have to start a ROM to do so.</li>
|
|
|
|
|
|
|
|
<li>Added support for configurable font to ROM launcher (currently only
|
|
|
|
'small' and 'large'). Updated the UI and added -launcherfont' commandline
|
|
|
|
argument to change this setting.</li>
|
|
|
|
|
|
|
|
<li>Added SECAM, NTSC50, PAL60 and SECAM60 to the list of formats that can
|
|
|
|
be used. Also, switching between these modes with 'Ctrl-f' now switches
|
|
|
|
the palette only; the number of scanlines won't change.</li>
|
|
|
|
|
|
|
|
<li>Fixed crash when switching between software and OpenGL mode with a
|
|
|
|
Stelladaptor plugged in.</li>
|
|
|
|
|
|
|
|
<li>Added '-tiafloat' commandline argument, which determines whether or not
|
|
|
|
the TIA pins are in a 'floating' state. This is useful for testing on
|
|
|
|
certain CMOS EPROM chips where the unused TIA pins on a read are not
|
|
|
|
floating but pulled high.</li>
|
|
|
|
|
|
|
|
<li>Fixed issue in debugger where once a .sym file was loaded, it was used
|
|
|
|
in all ROMs loaded after that.</li>
|
|
|
|
|
|
|
|
<li>Fixed issue in debugger where equate names weren't showing up in the RAM
|
|
|
|
and CPU widgets. Note that this still isn't perfect, and needs support
|
|
|
|
from DASM for proper functionality.</li>
|
|
|
|
|
|
|
|
<li>Updated state file format, creating smaller files (and in preparation
|
|
|
|
for state rewinding in a future release). Old state saves will no longer
|
|
|
|
work.</li>
|
|
|
|
|
|
|
|
<li>Added '-bs' commandline argument, which is an alias for '-type' (which
|
|
|
|
is still present).</li>
|
|
|
|
|
|
|
|
<li>Removed -pXspeed' commandline arguments, and replaced them with a
|
|
|
|
single '-pspeed'.</li>
|
|
|
|
|
|
|
|
<li>Removed '-paddle' commandline argument. The paddle currently emulated
|
|
|
|
by the mouse can still be changed with Ctrl-0..3 or within the UI, but
|
|
|
|
the setting is no longer saved.</li>
|
|
|
|
|
|
|
|
<li>Reworked UI for specifying that the console ports have been swapped,
|
|
|
|
hopefully making it easier to understand.</li>
|
|
|
|
|
|
|
|
<li>Added 'Ctrl-c' & 'Ctrl-v' to EditTextWidgets, allowing to copy and paste
|
|
|
|
the text widget contents. More work in this area is coming in a future
|
|
|
|
release.</li>
|
|
|
|
|
|
|
|
<li>Added 'Ctrl-leftarrow' and 'Ctrl-rightarrow' to EditTextWidgets, to move
|
|
|
|
to the first character of previous and next words (respectively).</li>
|
|
|
|
|
|
|
|
<li>For the Win32 port: fixed OpenGL crashes in Vista. Graphical updates
|
|
|
|
are still slower in Vista compared to XP, though.</li>
|
|
|
|
|
|
|
|
<li>For the Win32 port: default folder for Stella config files is now
|
|
|
|
'My Documents\Stella'; this can be disabled if necessary. This should
|
|
|
|
fix issues with losing settings when launching Stella from an IDE,
|
|
|
|
and the creation of stella.ini and 'state' directories in many
|
|
|
|
different places.</li>
|
|
|
|
|
|
|
|
<li>For the Win32 port: several fixes to the Visual Studio project files,
|
|
|
|
allowing building in debug or release mode, for both i386 and x86_64.
|
|
|
|
The project files have been upgraded to Visual Studio 2008, and Stella
|
|
|
|
can now be built and distributed without the VS runtime libraries.</li>
|
|
|
|
|
|
|
|
<li>Updated configure script for cross-compiling Win32 version in Linux.</li>
|
2002-04-22 01:45:08 +00:00
|
|
|
</ul>
|
2004-06-26 21:31:28 +00:00
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<p>
|
|
|
|
<h2><b>Features</b></h2>
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
<li>High speed emulation using optimized C++ code</li>
|
2005-09-13 18:27:42 +00:00
|
|
|
<li>Supports high quality sound emulation using code derived from Ron Fries'
|
|
|
|
TIA Sound Emulation library, including stereo sound support</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li>Emulates the Atari 2600 Joystick Controllers using your computer's keyboard
|
|
|
|
or joysticks</li>
|
|
|
|
<li>Emulates the Atari 2600 Keyboard Controllers using your computer's keyboard</li>
|
2008-03-26 00:52:05 +00:00
|
|
|
<li>Emulates one Atari 2600 Paddle Controller using your computer's mouse, keyboard
|
|
|
|
or joysticks</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li>Emulates the Atari 2600 Driving Controllers using your computer's keyboard
|
|
|
|
or joysticks</li>
|
|
|
|
<li>Emulates the CBS Booster-Grip Controller using your computer's keyboard or
|
|
|
|
joysticks</li>
|
2008-03-26 00:52:05 +00:00
|
|
|
<li>Support for real Atari 2600 controllers using the
|
|
|
|
<a href="http://www.pixelspast.com/products">Stelladaptor</a></li>
|
|
|
|
<li>Supports almost all known bankswitching schemes (let us know if there's one we missed)</li>
|
|
|
|
<li>Supports cartridge autodetection for almost all bankswitching schemes</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li>Supports Supercharger single-load and multi-load games</li>
|
|
|
|
<li>Supports property file for setting the properties associated with games</li>
|
2008-03-26 00:52:05 +00:00
|
|
|
<li>Supports the NTSC, PAL, PAL and SECAM television standards in 50Hz and 60Hz mode</li>
|
|
|
|
<li>Supports autodetection of display format for 50Hz vs. 60Hz modes</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li>Supports several "undocumented features" of the TIA graphics chip used by
|
|
|
|
some games</li>
|
|
|
|
<li>TIA emulation supports full collision checking</li>
|
2002-04-22 01:45:08 +00:00
|
|
|
</ul>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2002-04-22 01:45:08 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
|
|
|
<a name="Requirements">2. What You Will Need</a></h1>
|
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>The following sections outline the basic system requirements for running
|
|
|
|
Stella under various operating systems.
|
|
|
|
</p>
|
|
|
|
|
2006-12-08 16:49:42 +00:00
|
|
|
<p>Note that for this version of Stella, you are <b>not required</b> to have a
|
|
|
|
stella.pro file. ROM properties are built in, and defaults will be used
|
|
|
|
whenever necessary.</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<p>
|
2004-07-12 02:24:25 +00:00
|
|
|
<h2><b>General (required for all versions of Stella)</b></h2>
|
|
|
|
<ul>
|
|
|
|
<li>Enough RAM for the OS + 16MB RAM for the emulation; 32MB highly recommended</li>
|
|
|
|
<li>15 bit color minimum; 16 bit color graphics card highly recommended</li>
|
2007-08-17 16:12:50 +00:00
|
|
|
<li>SDL version 1.2.10 or greater, latest version highly recommended</li>
|
2006-12-08 16:49:42 +00:00
|
|
|
<li>Latest version of the zlib library</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li>Joysticks or gamepads are highly recommended</li>
|
|
|
|
<li>Mouse or Stelladaptor with real paddles required for paddle emulation</li>
|
2007-07-27 13:49:16 +00:00
|
|
|
<li>Some ROM images (See <a href="http://www.atariage.com">AtariAge</a> for more information)</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
</ul>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2004-07-12 02:24:25 +00:00
|
|
|
<p>
|
|
|
|
<h2><b>Linux/UNIX</b></h2>
|
2004-05-24 19:03:19 +00:00
|
|
|
<p>The Linux version of Stella is designed to work on a Linux Workstation with
|
|
|
|
the following:</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
<ul>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li>Linux Kernel 2.4.x, Linux Kernel 2.6.x is highly recommended</li>
|
|
|
|
<li>GNU C++ compiler version 2.95 and the make utility are required for compiling
|
2005-09-13 18:27:42 +00:00
|
|
|
the Stella source code; GNU C++ compiler version 3.2.x/4.x or later is highly
|
2004-07-12 02:24:25 +00:00
|
|
|
recommended</li>
|
2008-03-26 00:52:05 +00:00
|
|
|
<li>i386, x86_64 or PowerPC class machine, in either 32 or 64-bit mode</li>
|
|
|
|
<li>Other architectures (MIPS, PPC64, etc) have been confirmed to work as well</li>
|
2002-04-22 01:45:08 +00:00
|
|
|
</ul>
|
|
|
|
|
|
|
|
<p>
|
2004-05-24 19:03:19 +00:00
|
|
|
<h2><b>Macintosh</b></h2>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2004-09-14 19:10:29 +00:00
|
|
|
<p>The Mac version of Stella is designed to work on a Power Macintosh with
|
2004-07-14 05:30:28 +00:00
|
|
|
the following:</p>
|
|
|
|
<ul>
|
2006-12-08 16:49:42 +00:00
|
|
|
<li>Mac OSX 10.2 or Above</li>
|
2006-04-05 16:06:59 +00:00
|
|
|
<li>500 MHz G4 PPC/Intel processor or above (Stella <b>may</b> work with a G3
|
2005-01-04 02:29:31 +00:00
|
|
|
processor, but this is still a work-in-progress)</li>
|
2005-09-13 18:27:42 +00:00
|
|
|
<li>OpenGL capable video card. Software rendering mode is still available,
|
|
|
|
but as of OSX 10.4 is substandard compared to OpenGL.</li>
|
2004-07-14 05:30:28 +00:00
|
|
|
</ul>
|
2004-05-24 19:03:19 +00:00
|
|
|
|
|
|
|
<p>
|
|
|
|
<h2><b>Windows</b></h2>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<p>The Windows version of Stella is designed to work on Windows 98/ME/2000/XP/Vista
|
|
|
|
with the following:</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<ul>
|
2008-03-26 00:52:05 +00:00
|
|
|
<li>Visual C++ 7/8 or MinGW compiler is required to compile the Stella
|
2005-05-28 23:57:10 +00:00
|
|
|
source code</li>
|
2004-08-12 23:36:15 +00:00
|
|
|
<li>Pentium class machine required; OpenGL accelerated video card highly
|
|
|
|
recommended</li>
|
2002-04-22 01:45:08 +00:00
|
|
|
</ul>
|
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<p>
|
|
|
|
<h2><b>Other</b></h2>
|
|
|
|
|
|
|
|
<p>Stella is extremely portable, and in its lifetime has been ported to almost every
|
|
|
|
platform known. It is 32/64 bit clean in Linux/Unix and Windows (Win32/Win64), and
|
|
|
|
is expected to be compatible with 64-bit OSX as well. The Stella team is interested
|
|
|
|
in hearing about any problems you may encounter with diverse operating systems and
|
|
|
|
CPU types.</p>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2002-04-22 01:45:08 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
|
|
|
<a name="Installation">3. Installation</a></h1>
|
|
|
|
<hr>
|
2004-07-12 02:24:25 +00:00
|
|
|
<p>Stella is distributed in both source and binary form. Once you have a Stella
|
|
|
|
distribution you should follow the instructions for your operating system given
|
|
|
|
below.</p>
|
|
|
|
|
|
|
|
<p>If you have a supported joystick and driver installed and SDL can access the device,
|
|
|
|
you can play games using joysticks.</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<p>Currently, sound is supported using SDL. As long as SDL can detect your sound card,
|
2004-07-12 02:24:25 +00:00
|
|
|
Stella will be able to produce sound.</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<p>
|
2004-05-24 19:03:19 +00:00
|
|
|
<h2><b>Linux/UNIX</b></h2>
|
2003-11-30 03:36:51 +00:00
|
|
|
<ul>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li><b>Compressed tarball</b> (stella-<i>release</i>-src.tar.gz)</li>
|
|
|
|
<ol>
|
|
|
|
<li>Extract files from the distribution:
|
|
|
|
<pre> tar zxvf stella-release-src.tar.gz</pre></li>
|
2005-09-13 18:27:42 +00:00
|
|
|
<li>Change directories to the stella-<i>release</i> directory</li>
|
|
|
|
|
|
|
|
<li>Configure the build with the following command:
|
|
|
|
<pre> ./configure (--help for list of options)</pre></li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li>Build the executable with the following command:
|
2005-09-13 18:27:42 +00:00
|
|
|
<pre> make</pre></li>
|
|
|
|
<li>Install the executable with the following command:
|
|
|
|
<pre> make install</pre></li>
|
2004-07-12 02:24:25 +00:00
|
|
|
</ol>
|
2007-08-27 13:58:42 +00:00
|
|
|
<li><b>Binary DEB</b> (stella-<i>release</i>-1_arch.deb)</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<ol>
|
2007-08-27 13:58:42 +00:00
|
|
|
<li>Install the binary DEB with the following command:
|
|
|
|
<pre> dpkg -i stella-<i>release</i>-1_arch.deb</pre></li>
|
2004-07-12 02:24:25 +00:00
|
|
|
</ol>
|
2004-07-13 01:09:50 +00:00
|
|
|
<li><b>Binary RPM</b> (stella-<i>release</i>-1.ix86.rpm)</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<ol>
|
|
|
|
<li>Install the binary RPM with the following command:
|
2004-07-15 19:37:10 +00:00
|
|
|
<pre> rpm -Uvh stella-<i>release</i>-1.ix86.rpm</pre></li>
|
2004-07-12 02:24:25 +00:00
|
|
|
</ol>
|
2003-11-30 03:36:51 +00:00
|
|
|
</ul>
|
|
|
|
|
2004-05-24 19:03:19 +00:00
|
|
|
<p>
|
|
|
|
<h2><b>Macintosh</b></h2>
|
2004-07-14 05:30:28 +00:00
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<p>To install the Mac binary, simply download the DMG disk
|
2005-10-14 13:50:00 +00:00
|
|
|
image. Mount the disk image, then copy the StellaOSX<i>release</i> folder to
|
2004-07-14 05:30:28 +00:00
|
|
|
your hard drive.<br>
|
|
|
|
</p>
|
2004-05-24 19:03:19 +00:00
|
|
|
|
|
|
|
<p>
|
|
|
|
<h2><b>Windows</b></h2>
|
2004-07-12 02:24:25 +00:00
|
|
|
<ul>
|
|
|
|
<li><b>Compressed tarball</b> (stella-<i>release</i>-src.tar.gz)</li>
|
|
|
|
<ol>
|
|
|
|
<li>Extract files from the distribution using <b>Winzip</b>,
|
|
|
|
<b>Total Commander</b>, or some other archiving program that supports
|
|
|
|
gzipped tar files</li>
|
2005-09-13 18:27:42 +00:00
|
|
|
<li>If compiling the Stella executable using MinGW, use the same commands
|
|
|
|
as specified under <i>Linux/UNIX - Compressed tarball</i></li>
|
2004-07-12 02:24:25 +00:00
|
|
|
<li>If compiling using Visual C++ 7:</li>
|
|
|
|
<ul>
|
2005-09-13 18:27:42 +00:00
|
|
|
<li>Open the <b>stella-<i>release</i>/src/win32/Stella.sln</b>
|
2004-07-12 02:24:25 +00:00
|
|
|
file using Visual C++ 7</li>
|
2005-05-28 23:57:10 +00:00
|
|
|
<li>Build the 'Stella' solution</li>
|
2007-07-27 13:49:16 +00:00
|
|
|
<li>Copy the <b>Stella.exe</b> file to some directory</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
</ul>
|
|
|
|
</ol>
|
|
|
|
<li><b>Binary ZIP file</b> (stella-<i>release</i>-win32.zip)</li>
|
|
|
|
<ol>
|
|
|
|
<li>Unzip the binary ZIP file using <b>Winzip</b> or <b>Total Commander</b>
|
|
|
|
and copy that directory somewhere</li>
|
|
|
|
</ol>
|
2005-10-24 18:18:30 +00:00
|
|
|
<li><b>Binary EXE installer</b> (stella-<i>release</i>-win32.exe)</li>
|
|
|
|
<ol>
|
2006-01-20 02:38:47 +00:00
|
|
|
<li>Double-click on the installer and follow the onscreen instructions</li>
|
2005-10-24 18:18:30 +00:00
|
|
|
</ol>
|
2004-07-12 02:24:25 +00:00
|
|
|
</ul>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2002-04-22 01:45:08 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
|
|
|
<a name="Games">4. Games</a></h1>
|
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>Stella allows you to play games using ROM images of cartridges and cassettes.</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
<h2><b>Cartridges</b></h2>
|
|
|
|
|
|
|
|
<p>Most games for the Atari 2600 came on cartridges. A cartridge usually
|
|
|
|
consists of a single Read Only Memory (ROM) chip which contains the data and
|
|
|
|
code for the game. Plugging a cartridge into the Atari 2600 allows the 2600's
|
|
|
|
microprocessor to access the program stored on the cartridge.</p>
|
|
|
|
|
|
|
|
<p>In a similar way you must "plug" a copy of a cartridge into Stella when you
|
|
|
|
want to play it. Having a ROM image, BIN file, of the cartridge allows you to
|
|
|
|
do this. A ROM image is a file, which contains the actual data and code read
|
|
|
|
from the cartridge. There are several ways to obtain a ROM image of a
|
|
|
|
cartridge:</p>
|
|
|
|
|
|
|
|
<ol>
|
|
|
|
<li>If you're handy with a soldering iron then you can design and build a
|
|
|
|
device that plugs into the printer port of a PC and read the data from the
|
|
|
|
cartridge</li>
|
|
|
|
|
|
|
|
<li>You can purchase the Atari 2600 Action Packs by Activision and use
|
|
|
|
their ROM images</li>
|
|
|
|
|
|
|
|
<li>You can search around the internet and find ROM images to download</li>
|
|
|
|
</ol>
|
|
|
|
|
|
|
|
<p><b>WARNING:</b> It is illegal to use ROM images of games that you do not
|
|
|
|
actually own since these games are still copyrighted.</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
<h2><b>Supercharger Cassettes</b></h2>
|
|
|
|
|
|
|
|
<p>Supercharger games were not stored on cartridges instead they were stored
|
|
|
|
on cassette tapes. The Supercharger, which plugged into the Atari 2600's
|
|
|
|
cartridge slot, loaded games into its 6K of Random Access Memory (RAM) using a
|
|
|
|
standard audio cassette player. The Supercharger also supported multi-loading,
|
|
|
|
which allowed games to be broken into several segments and loaded at different
|
|
|
|
times. This was useful for large games which had distinct parts such as role
|
|
|
|
playing games.</p>
|
|
|
|
|
|
|
|
<p>Most of the available Supercharger ROM images are stored in 8448 bytes files.
|
|
|
|
However, ROM images of multi-load games are sometimes stored in a set of 8448
|
|
|
|
byte files. The names of these files have a two character sequence number in
|
|
|
|
them which indicates what load they are. The sequence starts with zero, skips
|
|
|
|
a few numbers and then increments by one.</p>
|
|
|
|
|
|
|
|
<p>Stella supports multi-load games, however, the set of ROM images must be
|
|
|
|
combined into a single ROM image file. For example to create a multi-load ROM
|
|
|
|
image file for Survival Island you would do the following under Unix:
|
|
|
|
|
|
|
|
<pre> % cat survivl0.bin survivl6.bin survivl7.bin > survivl.bin</pre>
|
|
|
|
|
|
|
|
or to create it under DOS you would:
|
|
|
|
|
|
|
|
<pre> % copy /b survivl0.bin+survivl6.bin+survivl7.bin survivl.bin</pre>
|
|
|
|
|
|
|
|
<p>Once you have the multi-load ROM image file, survivl.bin in this case, you
|
|
|
|
can play the game using it.</p>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2002-04-22 01:45:08 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
|
|
|
<a name="Starting">5. Starting A Game</a></h1>
|
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>Once Stella is installed and you have some ROM images you're ready to start
|
2005-05-28 23:57:10 +00:00
|
|
|
playing.</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<p>
|
2005-05-28 23:57:10 +00:00
|
|
|
<h2><b>Integrated GUI</b></h2>
|
|
|
|
|
|
|
|
<p>As of Stella version 2.0, there is an integrated GUI for all ports. This means
|
|
|
|
that using the commandline is no longer required (but commandline support is still
|
|
|
|
included for those who want to use it).</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<p>If you start Stella and do not specify a ROM image, it will start in
|
|
|
|
'ROM Launcher' mode:<br><br>
|
|
|
|
<img src="graphics/launcher.png"></p>
|
2004-06-26 21:31:28 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<p>The ROM browser, snapshot, and external file settings may be changed by
|
2007-08-17 16:12:50 +00:00
|
|
|
clicking the 'Options / Config Files' button:<br><br>
|
2007-07-27 13:49:16 +00:00
|
|
|
<img src="graphics/launcher_options_files.png"></p>
|
2005-05-28 23:57:10 +00:00
|
|
|
|
2007-08-17 16:12:50 +00:00
|
|
|
<p>Selecting a new path for an item is done by clicking the appropriate button(s):<br><br>
|
2005-05-28 23:57:10 +00:00
|
|
|
<img src="graphics/rom_browser.png"></p>
|
|
|
|
|
2007-08-17 16:12:50 +00:00
|
|
|
<p>You can start emulation by selecting a ROM and pressing 'Enter' or
|
2008-03-26 00:52:05 +00:00
|
|
|
clicking 'Select', or double-clicking a ROM.</p>
|
2005-05-28 23:57:10 +00:00
|
|
|
|
|
|
|
<p>
|
|
|
|
<h2><b>Command Line</b></h2>
|
|
|
|
|
|
|
|
<p>Stella can also be used from the commandline (assuming your operating system
|
2007-07-27 13:49:16 +00:00
|
|
|
has a commandline). When using this mode and specifying a ROM, the ROM launcher
|
|
|
|
is disabled.</p>
|
2004-06-26 21:31:28 +00:00
|
|
|
|
|
|
|
<p>To run Stella from the commandline, use the following format:</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<pre> stella [options ...] ROM_FILENAME</pre>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2004-06-26 21:31:28 +00:00
|
|
|
<p><b>Options</b> ('0' or 'false' indicates false, '1' or 'true' indicates true,
|
|
|
|
others are self-explanatory):</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<table BORDER=2>
|
|
|
|
<tr>
|
|
|
|
<th>Argument</th>
|
|
|
|
<th>Description</th>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-11-30 03:36:51 +00:00
|
|
|
<td><pre>-video <soft|gl></pre></td>
|
2004-09-14 19:10:29 +00:00
|
|
|
<td>Use SDL software or OpenGL rendering mode.</td>
|
|
|
|
</tr>
|
|
|
|
|
2006-12-13 00:05:46 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-gl_lib <filename></pre></td>
|
|
|
|
<td>OpenGL mode only. Specify the OpenGL library to use (only use
|
|
|
|
this if you know what you're doing). For OSX, this should
|
|
|
|
probably be left blank.</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2003-11-30 03:36:51 +00:00
|
|
|
<td><pre>-gl_filter <nearest|linear></pre></td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>OpenGL mode only. Use GL_NEAREST or GL_LINEAR filtering.
|
|
|
|
GL_NEAREST results in a scaled, pixelated image, while
|
|
|
|
GL_LINEAR introduces blurring.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-11-30 03:36:51 +00:00
|
|
|
<td><pre>-gl_aspect <number></pre></td>
|
2007-08-21 17:58:26 +00:00
|
|
|
<td>OpenGL mode only. Specify the amount (as a percentage) to scale the
|
|
|
|
image width. Since many video modes do not use square pixels, you can
|
|
|
|
reduce width until the pixels appear square. Allowable values are
|
|
|
|
50 - 100; I find 85 - 90 gives the most authentic look.</td>
|
2003-11-30 03:36:51 +00:00
|
|
|
</tr>
|
2007-08-21 17:58:26 +00:00
|
|
|
|
2004-07-12 02:24:25 +00:00
|
|
|
<tr>
|
2007-07-27 13:49:16 +00:00
|
|
|
<td><pre>-gl_fsmax <never|always|ui|tia></pre></td>
|
|
|
|
<td>OpenGL mode only. Stretch fullscreen image while in the given mode.</td>
|
2004-07-12 02:24:25 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-01-20 02:38:47 +00:00
|
|
|
<tr>
|
2006-12-13 00:05:46 +00:00
|
|
|
<td><pre>-gl_vsync <0|1></pre></td>
|
|
|
|
<td>OpenGL mode only. Synchronize screen updates to the vertical blank
|
|
|
|
period. This can result in smoother updates, and eliminate tearing.</td>
|
|
|
|
</tr>
|
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-gl_texrect <0|1></pre></td>
|
|
|
|
<td>OpenGL mode only. Enable GL_TEXTURE_RECTANGLE extension. This causes
|
|
|
|
problems for some people using ATI video cards.</td>
|
|
|
|
</tr>
|
|
|
|
|
2006-12-13 00:05:46 +00:00
|
|
|
<tr>
|
2007-07-27 13:49:16 +00:00
|
|
|
<td><pre>-zoom_tia <scaler></pre></td>
|
|
|
|
<td>Use the specified zoom level while in TIA/emulation mode.</td>
|
2006-01-20 02:38:47 +00:00
|
|
|
</tr>
|
|
|
|
|
2003-11-30 03:36:51 +00:00
|
|
|
<tr>
|
2007-07-27 13:49:16 +00:00
|
|
|
<td><pre>-zoom_ui <scaler></pre></td>
|
|
|
|
<td>Use the specified scaler while in non-emulation mode (currently, the ROM
|
|
|
|
launcher and debugger).</td>
|
2004-06-26 21:31:28 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-fullscreen <0|1></pre></td>
|
|
|
|
<td>Play the game in fullscreen mode.</td>
|
2003-11-30 03:36:51 +00:00
|
|
|
</tr>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-fullres <WxH></pre></td>
|
|
|
|
<td>Use this resolution in fullscreen mode.</td>
|
|
|
|
</tr>
|
|
|
|
|
2005-09-13 18:27:42 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-center <0|1></pre></td>
|
|
|
|
<td>Centers game window (if possible).</td>
|
|
|
|
</tr>
|
|
|
|
|
2003-11-30 03:36:51 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-grabmouse <0|1></pre></td>
|
|
|
|
<td>Keeps the mouse in the game window.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-07-27 13:49:16 +00:00
|
|
|
<td><pre>-palette <standard|z26|user></pre></td>
|
|
|
|
<td>Set the palette to either normal Stella, the one used in the z26
|
|
|
|
emulator, or a user-defined palette.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2007-01-14 18:59:08 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-colorloss <1|0></pre></td>
|
|
|
|
<td>Enable/disable the PAL color-loss effect.</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-framerate <number></pre></td>
|
|
|
|
<td>Display the given number of frames per second. Normally, Stella
|
|
|
|
will determine framerate based on ROM format.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-09-13 18:27:42 +00:00
|
|
|
<td><pre>-sound <1|0></pre></td>
|
|
|
|
<td>Enable or disable sound generation.</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-fragsize <number></pre></td>
|
|
|
|
<td>Specify the sound fragment size to use. Linux/Mac seems to work
|
2008-03-26 00:52:05 +00:00
|
|
|
with 512, Windows may need 2048 (but newer versions work with
|
|
|
|
512 as well).</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-01-20 02:38:47 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-freq <number></pre></td>
|
|
|
|
<td>Set sound sample output frequency (0 - 48000).
|
|
|
|
Default is 31400.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-tiafreq <number></pre></td>
|
|
|
|
<td>Set sound sample generation frequency (0 - 48000).
|
|
|
|
Default is 31400.</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-volume <number></pre></td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Set the volume (0 - 100).</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-01-20 02:38:47 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-clipvol <1|0></pre></td>
|
|
|
|
<td>Enable volume clipping (eliminates popping).</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-cheat <code></pre></td>
|
|
|
|
<td>Use the specified cheatcode (see Cheat section for description).</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-showinfo <0|1></pre></td>
|
|
|
|
<td>Shows some game info while Stella is running.</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td><pre>-pspeed <number></pre></td>
|
|
|
|
<td>Speed of digital emulation for paddles (1-15).</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-01-20 02:38:47 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-sa1 <left|right></pre></td>
|
|
|
|
<td>Stelladaptor 1 emulates specified joystick port.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-sa2 <left|right></pre></td>
|
|
|
|
<td>Stelladaptor 2 emulates specified joystick port.</td>
|
|
|
|
</tr>
|
|
|
|
|
2005-10-09 21:55:53 +00:00
|
|
|
<tr>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td><pre>-romviewer <1|0></pre></td>
|
|
|
|
<td>Show/hide ROM info viewer in ROM launcher mode.</td>
|
2007-08-27 13:58:42 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-12-13 00:05:46 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-autoslot <1|0></pre></td>
|
|
|
|
<td>Automatically switch to the next available save state slot after
|
|
|
|
saving a ROM state file.</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-09-29 14:11:56 +00:00
|
|
|
<tr>
|
2003-11-30 03:36:51 +00:00
|
|
|
<td><pre>-ssdir <path></pre></td>
|
|
|
|
<td>The directory to save snapshot files to.</td>
|
2002-09-29 14:11:56 +00:00
|
|
|
</tr>
|
2003-11-30 03:36:51 +00:00
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-sssingle <0|1></pre></td>
|
|
|
|
<td>Generate single snapshot instead of many.</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-11-13 16:41:24 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-listrominfo</pre></td>
|
2006-12-13 00:05:46 +00:00
|
|
|
<td>Prints relevant contents of the Stella ROM database, one ROM per line,
|
|
|
|
and then exit Stella. This can be used for external frontends.</td>
|
2002-11-13 16:41:24 +00:00
|
|
|
</tr>
|
2002-11-10 20:46:58 +00:00
|
|
|
|
2007-01-14 18:59:08 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-rominfo <rom></pre></td>
|
|
|
|
<td>Display detailed information about the given ROM, and then exit
|
|
|
|
Stella.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-07-27 13:49:16 +00:00
|
|
|
<td><pre>-launcherres <WxH></pre></td>
|
|
|
|
<td>Set the size of the ROM launcher.</td>
|
2007-01-14 18:59:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-launcherfont <small|large></pre></td>
|
|
|
|
<td>Set the size of the font in the ROM launcher.</td>
|
|
|
|
</tr>
|
|
|
|
|
2007-01-14 18:59:08 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-uipalette <1|2></pre></td>
|
|
|
|
<td>Used the specified palette for UI elements. This isn't yet
|
|
|
|
complete.</td>
|
|
|
|
</tr>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<tr>
|
2007-08-17 16:12:50 +00:00
|
|
|
<td><pre>-mwheel <lines></pre></td>
|
|
|
|
<td>Set the number of lines a mousewheel will scroll in the UI.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-statedir <dir></pre></td>
|
2007-07-27 13:49:16 +00:00
|
|
|
<td>Set the directory in which to save state files.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-cheatfile <file></pre></td>
|
|
|
|
<td>Set the full pathname of the cheatfile database.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-palettefile <file></pre></td>
|
|
|
|
<td>Set the full pathname of the user-defined palette file.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-propsfile <file></pre></td>
|
|
|
|
<td>Set the full pathname of the ROM properties file.</td>
|
|
|
|
</tr>
|
|
|
|
|
2004-07-14 06:53:27 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-help</pre></td>
|
|
|
|
<td>Prints a help message describing these options, and then
|
|
|
|
exit Stella.</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
</table>
|
2004-07-14 06:53:27 +00:00
|
|
|
|
2006-12-15 16:43:12 +00:00
|
|
|
<p>The following are useful to developers. Only use them if you know what
|
|
|
|
you're doing! Note that in all cases, the values supplied to the arguments
|
|
|
|
are <b>not</b> case sensitive.</p>
|
2004-07-14 06:53:27 +00:00
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<table BORDER=2>
|
2005-02-18 05:37:15 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<th>Argument</th>
|
|
|
|
<th>Description</th>
|
2005-02-18 05:37:15 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-01-20 02:38:47 +00:00
|
|
|
<tr>
|
2007-08-17 16:12:50 +00:00
|
|
|
<td><pre>-debuggerres <WxH></pre></td>
|
|
|
|
<td>Set the size of the debugger window.</td>
|
2006-01-20 02:38:47 +00:00
|
|
|
</tr>
|
|
|
|
|
2005-09-13 18:27:42 +00:00
|
|
|
<tr>
|
2007-08-17 16:12:50 +00:00
|
|
|
<td><pre>-break <address></pre></td>
|
|
|
|
<td>Set a breakpoint at specified address.</td>
|
2005-09-13 18:27:42 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-debug</pre></td>
|
|
|
|
<td>Immediately jump to debugger mode when starting Stella.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-holdreset</pre></td>
|
|
|
|
<td>Start the emulator with the Game Reset switch held down.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-holdselect</pre></td>
|
|
|
|
<td>Start the emulator with the Game Select switch held down.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-holdbutton0</pre></td>
|
|
|
|
<td>Start the emulator with the left joystick button held down.</td>
|
|
|
|
</tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
|
2004-07-14 19:43:55 +00:00
|
|
|
<tr>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td><pre>-tiafloat <1|0></pre></td>
|
|
|
|
<td>Set unused TIA pins to be floating on a read/peek.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td><pre>-bs <type></pre></td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Set "Cartridge.Type" property. See the <i>Game Properties</i> section
|
|
|
|
for valid types.</td>
|
2004-07-14 19:43:55 +00:00
|
|
|
</tr>
|
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-type <type></pre></td>
|
|
|
|
<td>Same as using -bs.</td>
|
|
|
|
</tr>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-channels <Mono|Stereo></pre></td>
|
|
|
|
<td>Set "Cartridge.Sound" property.</td>
|
|
|
|
</tr>
|
|
|
|
|
2004-07-14 06:53:27 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-ld <A|B></pre></td>
|
|
|
|
<td>Set "Console.LeftDifficulty" property.</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-rd <A|B></pre></td>
|
|
|
|
<td>Set "Console.RightDifficulty" property.</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-10-15 17:40:39 +00:00
|
|
|
<td><pre>-tv <Color|BlackAndWhite></pre></td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Set "Console.TelevisionType" property.</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-12-18 16:44:40 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-sp <Yes|No></pre></td>
|
|
|
|
<td>Set "Console.SwapPorts" property.</td>
|
|
|
|
</tr>
|
|
|
|
|
2004-07-14 06:53:27 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-lc <type></pre></td>
|
|
|
|
<td>Set "Controller.Left" property, where type is one of Booster-Grip,
|
|
|
|
Driving, Keyboard, Paddles, or Joystick.</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-rc <type></pre></td>
|
|
|
|
<td>Set "Controller.Right" property, where type is one of Booster-Grip,
|
|
|
|
Driving, Keyboard, Paddles, or Joystick.</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-bc <type></pre></td>
|
|
|
|
<td>Sets both "Controller.Left" and "Controller.Right" properties, where
|
|
|
|
type is one of Booster-Grip, Driving, Keyboard, Paddles, or Joystick.</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-12-13 00:05:46 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-cp <Yes|No></pre></td>
|
|
|
|
<td>Set "Controller.SwapPaddles" property.</td>
|
|
|
|
</tr>
|
|
|
|
|
2004-07-14 06:53:27 +00:00
|
|
|
<tr>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td><pre>-format <format></pre></td>
|
|
|
|
<td>Set "Display.Format" property. See the <i>Game Properties</i> section
|
|
|
|
for valid formats.</td></td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-ystart <number></pre></td>
|
|
|
|
<td>Set "Display.YStart" property (0 - 64).</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-height <number></pre></td>
|
|
|
|
<td>Set "Display.Height" property (100 - 256).</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-01-20 02:38:47 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-pp <Yes|No></pre></td>
|
|
|
|
<td>Set "Display.Phosphor" property.</td>
|
|
|
|
</tr>
|
|
|
|
|
2006-12-13 00:05:46 +00:00
|
|
|
<tr>
|
|
|
|
<td><pre>-ppblend <number></pre></td>
|
|
|
|
<td>Set "Display.PPBlend" property, used for phosphor effect (0-100).
|
|
|
|
Default is 77.</td>
|
|
|
|
</tr>
|
|
|
|
|
2004-07-14 06:53:27 +00:00
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td><pre>-hmove <Yes|No></pre></td>
|
|
|
|
<td>Set "Emulation.HmoveBlanks" property.</td>
|
2004-07-14 06:53:27 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2005-05-28 23:57:10 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
|
|
|
<a name="Options">6. Changing Options</a></h1>
|
|
|
|
<hr>
|
2004-07-14 06:53:27 +00:00
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<p>As of version 2.0, all settings can be changed within the integrated Options
|
|
|
|
GUI while Stella is running. The options are documented elsewhere in this manual
|
2007-01-14 18:59:08 +00:00
|
|
|
and are generally self-explanatory. The Options menu can be accessed from
|
|
|
|
the ROM launcher by clicking the 'Options' button, or in-game by pressing the
|
|
|
|
'Tab' key.</p>
|
|
|
|
|
|
|
|
<p><b>Options Menu</b> dialog:<br><br>
|
|
|
|
<img src="graphics/options.png">
|
2008-03-26 00:52:05 +00:00
|
|
|
<br><br><br>
|
2004-07-14 06:53:27 +00:00
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<p><b>Video Settings</b> dialog:<br><br>
|
2005-05-28 23:57:10 +00:00
|
|
|
<img src="graphics/options_video.png">
|
2008-03-26 00:52:05 +00:00
|
|
|
<br><br><br>
|
2004-07-14 06:53:27 +00:00
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<p><b>Audio Settings</b> dialog:<br><br>
|
2005-05-28 23:57:10 +00:00
|
|
|
<img src="graphics/options_audio.png">
|
2008-03-26 00:52:05 +00:00
|
|
|
<br><br><br>
|
|
|
|
|
|
|
|
<p><b>Input Settings</b> dialog:<br><br>
|
|
|
|
<img src="graphics/options_input.png">
|
|
|
|
<p>This dialog is described in further detail in <b>Section 8 -
|
|
|
|
<a href="#Remapping">Event Remapping</a></b>.
|
|
|
|
<br><br><br>
|
|
|
|
|
|
|
|
<p><b>UI Settings</b> dialog:<br><br>
|
|
|
|
<img src="graphics/options_ui.png">
|
|
|
|
<p>All UI related items can be changed here. Such items include the width and
|
|
|
|
height of the ROM launcher and debugger windows, etc. Note that most of the items
|
|
|
|
here require Stella to be restarted to take effect. Specific information about
|
|
|
|
the ROM Info functionality is described in further detail in <b>Section 9 -
|
|
|
|
<a href="#ROMInfo">Viewing ROM Info</a></b>.
|
|
|
|
|
|
|
|
<br><br><br>
|
|
|
|
|
|
|
|
<p><b>Audit ROMs</b> dialog:<br><br>
|
|
|
|
<img src="graphics/options_romaudit.png">
|
|
|
|
<p>This dialog is described in further detail in <b>Section 10 -
|
|
|
|
<a href="#ROMAudit">ROM Audit Mode</a></b>.
|
|
|
|
<br><br><br>
|
2004-07-14 06:53:27 +00:00
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<p><b>Game Information</b> dialog:<br><br>
|
|
|
|
<img src="graphics/options_gameinfo.png">
|
2008-03-26 00:52:05 +00:00
|
|
|
<p>This dialog allows you to change all ROM properties as described in
|
|
|
|
<b>Section 15 - <a href="#Properties">Game Properties</a></b>.
|
|
|
|
<br><br><br>
|
2004-06-26 21:31:28 +00:00
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<p><b>Help</b> dialog:<br><br>
|
|
|
|
<img src="graphics/options_help.png">
|
2008-03-26 00:52:05 +00:00
|
|
|
<br><br><br>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<p><b>About</b> dialog:<br><br>
|
|
|
|
<img src="graphics/options_about.png">
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2004-06-26 21:31:28 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
2007-07-27 13:49:16 +00:00
|
|
|
<a name="Keyboard">7. Keyboard Layout</a></h1>
|
2002-04-22 01:45:08 +00:00
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>The Atari 2600 console controls and controllers are mapped to the computer's
|
2003-09-30 01:22:45 +00:00
|
|
|
keyboard as shown in the following tables.</p>
|
|
|
|
|
|
|
|
<p>As of Stella 1.4, most of these events can be remapped to other keys on your keyboard
|
2007-07-27 13:49:16 +00:00
|
|
|
or buttons on your joystick (see <b>Section 8 -
|
2004-07-12 02:24:25 +00:00
|
|
|
<a href="#Remapping">Event Remapping</a></b>). The tables below show the default
|
|
|
|
settings.</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<p><b>Console Controls (can be remapped)</b></p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=2 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2005-05-28 23:57:10 +00:00
|
|
|
<th>Key (Standard)</th>
|
|
|
|
<th>Key (OSX)</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Exit emulator</td>
|
2005-10-18 18:49:46 +00:00
|
|
|
<td>Control + q</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Cmd + q</td>
|
2004-06-26 21:31:28 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Exit game mode/enter launcher mode</td>
|
|
|
|
<td>Escape</td>
|
2004-06-26 21:31:28 +00:00
|
|
|
<td>Escape</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Enter/exit options mode</td>
|
|
|
|
<td>Tab</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Tab</td>
|
|
|
|
</tr>
|
|
|
|
|
2005-10-09 21:55:53 +00:00
|
|
|
<tr>
|
|
|
|
<td>Enter/exit command mode</td>
|
|
|
|
<td>Backslash (\)</td>
|
|
|
|
<td>Backslash (\)</td>
|
|
|
|
</tr>
|
|
|
|
|
2005-10-18 18:49:46 +00:00
|
|
|
<tr>
|
|
|
|
<td>Enter/exit debugger</td>
|
|
|
|
<td>Backquote (`)</td>
|
|
|
|
<td>Backquote (`)</td>
|
|
|
|
</tr>
|
|
|
|
|
2003-09-30 01:22:45 +00:00
|
|
|
<tr>
|
2002-04-22 01:45:08 +00:00
|
|
|
<td>Select Game</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F1</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F1</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Reset Game</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F2</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F2</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Color TV</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F3</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F3</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Black/White TV</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F4</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F4</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Left Player Difficulty B</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F5</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F5</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Left Player Difficulty A</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F6</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F6</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Right Player Difficulty B</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F7</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F7</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Right Player Difficulty A</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F8</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F8</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2002-11-10 20:46:58 +00:00
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Save state to current slot</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
<td>F9</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F9</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Change current state slot</td>
|
|
|
|
<td>F10</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F10</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Load state from current slot</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
<td>F11</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F11</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2003-11-30 03:36:51 +00:00
|
|
|
<td>Save PNG snapshot</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F12</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>F12</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
2002-11-10 20:46:58 +00:00
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Pause/resume emulation</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
<td>Pause</td>
|
2005-10-10 17:31:14 +00:00
|
|
|
<td>Pause</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
</tr>
|
2002-04-22 01:45:08 +00:00
|
|
|
</table>
|
|
|
|
|
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<p><b>Joystick / Booster-Grip Controller (can be remapped)</b></p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<table BORDER=2>
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<th>Left Joystick (Joy0)</th>
|
|
|
|
<th>Right Joystick (Joy1)</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=1 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2003-09-30 01:22:45 +00:00
|
|
|
<th>Key</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Joystick Up</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Up arrow</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Joystick Down</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Down arrow</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Joystick Left</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Left arrow</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Joystick Right</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Right arrow</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Fire Button</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Space</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Trigger Button</td>
|
|
|
|
<td>4</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Booster Button</td>
|
|
|
|
<td>5</td>
|
|
|
|
</tr>
|
2002-04-22 01:45:08 +00:00
|
|
|
</table>
|
|
|
|
</td>
|
|
|
|
|
|
|
|
<td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=1 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2003-09-30 01:22:45 +00:00
|
|
|
<th>Key</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Joystick Up</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Y</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Joystick Down</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>H</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Joystick Left</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>G</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Joystick Right</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>J</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Fire Button</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>F</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Trigger Button</td>
|
|
|
|
<td>6</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Booster Button</td>
|
|
|
|
<td>7</td>
|
|
|
|
</tr>
|
2002-04-22 01:45:08 +00:00
|
|
|
</table>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<p><b>Paddle Controller digital emulation (can be remapped independently of joystick controller)</b></p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<table BORDER=2>
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<th>Left Paddles</th>
|
|
|
|
<th>Right Paddles</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=1 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2003-09-30 01:22:45 +00:00
|
|
|
<th>Key</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 0 decrease</td>
|
|
|
|
<td>Same as 'Joy0 Left'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 0 increase</td>
|
|
|
|
<td>Same as 'Joy0 Right'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 0 Fire</td>
|
|
|
|
<td>Same as 'Joy0 Fire'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 1 decrease</td>
|
|
|
|
<td>Same as 'Joy0 Up'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 1 increase</td>
|
|
|
|
<td>Same as 'Joy0 Down'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 1 Fire</td>
|
|
|
|
<td>Same as 'Joy0 Booster'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</td>
|
|
|
|
|
|
|
|
<td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=1 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2003-09-30 01:22:45 +00:00
|
|
|
<th>Key</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 2 decrease</td>
|
|
|
|
<td>Same as 'Joy1 Left'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 2 increase</td>
|
|
|
|
<td>Same as 'Joy1 Right'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 2 Fire</td>
|
|
|
|
<td>Same as 'Joy1 Fire'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 3 decrease</td>
|
|
|
|
<td>Same as 'Joy1 Up'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 3 increase</td>
|
|
|
|
<td>Same as 'Joy1 Down'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Paddle 3 Fire</td>
|
|
|
|
<td>Same as 'Joy1 Booster'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<p><b>Driving Controller (cannot be remapped, always associated with joystick controller)</b></p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<table BORDER=2>
|
|
|
|
<tr>
|
|
|
|
<th>Left Driving</th>
|
|
|
|
<th>Right Driving</th>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=1 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2003-09-30 01:22:45 +00:00
|
|
|
<th>Key</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Left Direction</td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Same as 'Joy0 Left'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Right Direction</td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Same as 'Joy0 Right'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Fire Button</td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Same as 'Joy0 Fire'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</td>
|
|
|
|
|
|
|
|
<td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=1 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2003-09-30 01:22:45 +00:00
|
|
|
<th>Key</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Left Direction</td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Same as 'Joy1 Left'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Right Direction</td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Same as 'Joy1 Right'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Fire Button</td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Same as 'Joy1 Fire'</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<p><b>Keypad Controller (can be remapped)</b></p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<table BORDER=2>
|
|
|
|
<tr>
|
|
|
|
<th>Left Keypad</th>
|
|
|
|
<th>Right Keypad</th>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=1 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<th>Pad Button</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
<th>Key</th>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>1</td>
|
|
|
|
<td>1</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>2</td>
|
|
|
|
<td>2</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>3</td>
|
|
|
|
<td>3</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>4</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Q</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>5</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>W</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>6</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>E</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>7</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>A</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>8</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>S</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>9</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>D</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>.</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Z</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>0</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>X</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>#</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>C</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</td>
|
|
|
|
|
|
|
|
<td>
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=1 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2003-09-30 01:22:45 +00:00
|
|
|
<th>Pad Button</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
<th>Key</th>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>1</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>8</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>2</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>9</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>3</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>0</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>4</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>I</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>5</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>O</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>6</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>P</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>7</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>K</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>8</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>L</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>9</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>;</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>.</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>,</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>0</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>#</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>/</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<p><b>Developer Keys (cannot be remapped)</b></p>
|
2002-11-10 20:46:58 +00:00
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=2 cellpadding=5>
|
2002-11-10 20:46:58 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2005-05-28 23:57:10 +00:00
|
|
|
<th>Key (Standard)</th>
|
|
|
|
<th>Key (OSX)</th>
|
2002-11-10 20:46:58 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2006-12-18 16:44:40 +00:00
|
|
|
<td>Set "Display.YStart" to next <i>larger</i> value</td>
|
|
|
|
<td>Alt + PageUp</td>
|
|
|
|
<td>Shift-Cmd + PageUp</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2006-12-18 16:44:40 +00:00
|
|
|
<td>Set "Display.YStart" to next <i>smaller</i> value</td>
|
|
|
|
<td>Alt + PageDown</td>
|
|
|
|
<td>Shift-Cmd + PageDown</td>
|
2002-11-10 20:46:58 +00:00
|
|
|
</tr>
|
2007-01-14 18:59:08 +00:00
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Set "Display.Height" to next <i>larger</i> value</td>
|
|
|
|
<td>Control + PageUp</td>
|
|
|
|
<td>Cmd + PageUp</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Set "Display.Height" to next <i>smaller</i> value</td>
|
|
|
|
<td>Control + PageDown</td>
|
|
|
|
<td>Cmd + PageDown</td>
|
|
|
|
</tr>
|
2002-11-10 20:46:58 +00:00
|
|
|
</table>
|
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<p><b>Other Keys (cannot be remapped, except those marked with '*')</b></p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2007-10-09 23:56:57 +00:00
|
|
|
<table BORDER=2 cellpadding=5>
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<th>Function</th>
|
2005-05-28 23:57:10 +00:00
|
|
|
<th>Key (Standard)</th>
|
|
|
|
<th>Key (OSX)</th>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-07-27 13:49:16 +00:00
|
|
|
<td>Switch to next <i>larger</i> zoom level</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Alt + =</td>
|
2005-10-18 18:49:46 +00:00
|
|
|
<td>Cmd + =</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-07-27 13:49:16 +00:00
|
|
|
<td>Switch to next <i>smaller</i> zoom level</td>
|
2003-09-30 01:22:45 +00:00
|
|
|
<td>Alt + -</td>
|
2005-10-18 18:49:46 +00:00
|
|
|
<td>Cmd + -</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-01-04 02:38:45 +00:00
|
|
|
<td>Toggle fullscreen/windowed mode</td>
|
|
|
|
<td>Alt + Enter</td>
|
2005-09-13 18:27:42 +00:00
|
|
|
<td>Cmd + Enter</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2005-10-15 17:40:39 +00:00
|
|
|
<!--
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2005-01-04 02:38:45 +00:00
|
|
|
<td>Toggle OpenGL filtering modes</td>
|
|
|
|
<td>Alt + f</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Shift-Cmd + f</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
2005-10-15 17:40:39 +00:00
|
|
|
-->
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Decrease volume (*)</td>
|
|
|
|
<td>Alt + [</td>
|
|
|
|
<td>Shift-Cmd + [</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
2003-11-30 03:36:51 +00:00
|
|
|
|
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Increase volume (*)</td>
|
|
|
|
<td>Alt + ]</td>
|
|
|
|
<td>Shift-Cmd + ]</td>
|
2003-11-30 03:36:51 +00:00
|
|
|
</tr>
|
2004-07-12 02:24:25 +00:00
|
|
|
|
|
|
|
<tr>
|
2005-01-04 02:38:45 +00:00
|
|
|
<td>Grab mouse (keep mouse in game window)</td>
|
|
|
|
<td>Control + g</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Cmd + g</td>
|
2004-07-12 02:24:25 +00:00
|
|
|
</tr>
|
|
|
|
|
2005-01-04 02:29:31 +00:00
|
|
|
<tr>
|
2007-10-09 23:56:57 +00:00
|
|
|
<td>Toggle display palette (<i>NTSC/PAL/SECAM</i>)</td>
|
2005-01-04 02:38:45 +00:00
|
|
|
<td>Control + f</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Cmd + f</td>
|
2005-01-04 02:29:31 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Save current properties to a new properties file</td>
|
2005-01-04 02:38:45 +00:00
|
|
|
<td>Control + s</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Cmd + s</td>
|
|
|
|
</tr>
|
|
|
|
|
2005-01-04 02:29:31 +00:00
|
|
|
<tr>
|
|
|
|
<td>Set mouse to emulate paddle 0</td>
|
|
|
|
<td>Control + 0</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Cmd + 0</td>
|
2005-01-04 02:29:31 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Set mouse to emulate paddle 1</td>
|
|
|
|
<td>Control + 1</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Cmd + 1</td>
|
2005-01-04 02:29:31 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Set mouse to emulate paddle 2</td>
|
|
|
|
<td>Control + 2</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Cmd + 2</td>
|
2005-01-04 02:29:31 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Set mouse to emulate paddle 3</td>
|
|
|
|
<td>Control + 3</td>
|
2005-05-28 23:57:10 +00:00
|
|
|
<td>Cmd + 3</td>
|
2005-01-04 02:29:31 +00:00
|
|
|
</tr>
|
2005-10-10 17:31:14 +00:00
|
|
|
|
2005-10-15 17:40:39 +00:00
|
|
|
<tr>
|
|
|
|
<td>Reload current ROM</td>
|
|
|
|
<td>Control + r</td>
|
|
|
|
<td>Cmd + r</td>
|
|
|
|
</tr>
|
|
|
|
|
2005-10-10 17:31:14 +00:00
|
|
|
<tr>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Emulate 'frying' effect (*)</td>
|
2005-10-10 17:31:14 +00:00
|
|
|
<td>Backspace</td>
|
|
|
|
<td>Backspace</td>
|
|
|
|
</tr>
|
2006-01-20 02:38:47 +00:00
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Toggle 'phosphor' effect</td>
|
|
|
|
<td>Alt + p</td>
|
|
|
|
<td>Shift-Cmd + p</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Toggle palette</td>
|
|
|
|
<td>Control + p</td>
|
|
|
|
<td>Cmd + p</td>
|
|
|
|
</tr>
|
2007-01-14 18:59:08 +00:00
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>Toggle PAL color-loss effect</td>
|
|
|
|
<td>Control + l</td>
|
|
|
|
<td>Cmd + l</td>
|
|
|
|
</tr>
|
2002-04-22 01:45:08 +00:00
|
|
|
</table>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2002-04-22 01:45:08 +00:00
|
|
|
<br><br><br>
|
|
|
|
<p><h1>
|
2007-07-27 13:49:16 +00:00
|
|
|
<a name="Remapping">8. Event Remapping</a></h1>
|
2004-07-12 02:24:25 +00:00
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>This version of Stella has event remapping. Almost every event in the emulator
|
2006-12-18 16:44:40 +00:00
|
|
|
can be remapped to another key on the keyboard or to buttons on up to eight
|
2007-07-27 13:49:16 +00:00
|
|
|
joysticks/gamepads (see <b>Section 7 - <a href="#Keyboard">Keyboard Layout</a></b>
|
2007-10-09 23:56:57 +00:00
|
|
|
for those events which can/cannot be remapped).</p>
|
2004-07-12 02:24:25 +00:00
|
|
|
|
2006-12-18 16:44:40 +00:00
|
|
|
<p>Note that there are currently two separate event modes in Stella; emulation
|
|
|
|
mode and user-interface (UI) mode. Each mode has separate mappings, so (for example)
|
|
|
|
while in emulation mode, the left arrow could mean 'joystick 0 left', while in UI
|
2007-10-09 23:56:57 +00:00
|
|
|
mode it could mean 'move cursor left'. Emulation mode occurs whenever you're
|
2006-12-18 16:44:40 +00:00
|
|
|
actually playing a game. UI mode occurs whenever a user interface is present
|
|
|
|
(ROM launcher, debugger, settings menu, etc). Because of these different modes,
|
|
|
|
there are two separate mapping areas.
|
|
|
|
|
2004-07-12 02:24:25 +00:00
|
|
|
<p>To remap an event:
|
|
|
|
<ol>
|
2007-01-14 18:59:08 +00:00
|
|
|
<li>Enter options menu and click the 'Input Settings' button.</li>
|
2006-12-18 16:44:40 +00:00
|
|
|
<li>If you wish to remap emulation events, click the 'Emul. Events' tab.
|
|
|
|
Otherwise, click the 'UI Events' tab for user interface events.</li>
|
2005-05-28 23:57:10 +00:00
|
|
|
<li>Select event you want to remap and click the 'Map' button.</li>
|
|
|
|
<li>Press a key or a joystick button, and that key/button will be bound
|
2006-01-20 02:38:47 +00:00
|
|
|
to the selected event. If nothing seems to happen, either Stella
|
|
|
|
can't see the input device, or the selected event doesn't support being
|
|
|
|
remapped to the input device.</li>
|
2005-05-28 23:57:10 +00:00
|
|
|
<li>Erase a mapping by clicking 'Erase', or cancel a remap in progress
|
|
|
|
by clicking 'Cancel'.</li>
|
|
|
|
<li>Reset default mappings by clicking 'Defaults'.</li>
|
2004-07-12 02:24:25 +00:00
|
|
|
</ol>
|
|
|
|
|
2005-05-28 23:57:10 +00:00
|
|
|
<p>The following screenshots illustrate the event remapping process:<br><br>
|
|
|
|
<img src="graphics/eventmapping.png">
|
|
|
|
<img src="graphics/eventmapping_remap.png">
|
|
|
|
|
2006-12-18 16:44:40 +00:00
|
|
|
<p>Virtual devices can be configured under the 'Virtual Devs' tab, shown below:<br><br>
|
|
|
|
<img src="graphics/eventmapping_virtualdevs.png"></p>
|
|
|
|
|
|
|
|
<p>Stelladaptor devices can be configured to either the left or right virtual
|
|
|
|
ports. See the section 'Stelladaptor Support' for more information.</p>
|
|
|
|
|
|
|
|
<p>Paddle settings are also configured here. The mouse can emulate either paddle
|
2008-03-26 00:52:05 +00:00
|
|
|
0, 1, 2, or 3. Note that some paddle games don't default to paddle 0. In those
|
|
|
|
cases, the ROM properties will automatically set the mouse to emulate the paddle
|
|
|
|
used by Player 0. So, for example, a ROM that defaults to paddle 1 (Demons to Diamonds)
|
|
|
|
will set 'Mouse is paddle' to 1, and a ROM that defaults to paddle 3 (Tac-Scan) will
|
|
|
|
set 'Mouse is paddle' to 3.</p>
|
|
|
|
|
|
|
|
<p>Paddle speed is used when emulating a paddle using a digital device
|
2006-12-18 16:44:40 +00:00
|
|
|
(keyboard, digital joystick, etc). Because of the on/off nature of digital
|
|
|
|
devices, there are no smooth analog values as would be present on a real
|
|
|
|
paddle. When using digital devices, the paddle is moved a certain amount
|
2008-03-26 00:52:05 +00:00
|
|
|
each frame. This speed setting specifies how much movement will occur.</p>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
|
|
|
<br><br><br>
|
|
|
|
<p><h1>
|
|
|
|
<a name="ROMInfo">9. Viewing ROM Info</a></h1>
|
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
</p>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
|
|
|
<br><br><br>
|
|
|
|
<p><h1>
|
|
|
|
<a name="ROMAudit">10. ROM Audit Mode</a></h1>
|
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
</p>
|
2006-12-18 16:44:40 +00:00
|
|
|
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
2008-03-26 00:52:05 +00:00
|
|
|
<a name="Adaptor">11. Stelladaptor Support</a></h1>
|
2007-07-27 13:49:16 +00:00
|
|
|
<hr>
|
2006-12-18 16:44:40 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<p>Stella supports real Atari 2600 joysticks, paddles and driving controllers
|
|
|
|
using the <a href="http://www.pixelspast.com/products">Stelladaptor</a> device.</p>
|
|
|
|
|
|
|
|
<p>Stella can use up to <b>two</b> Stelladaptors; any extra ones are ignored.
|
|
|
|
Stelladaptor devices will be automatically detected and configured. Devices
|
|
|
|
can be plugged/unplugged while the emulation is running; Stella will detect the
|
|
|
|
change and act accordingly.</p>
|
|
|
|
|
|
|
|
<p>The detection and configuration is as follows:
|
|
|
|
|
|
|
|
<ul>
|
|
|
|
<li>The first Stelladaptor found will act as the <b>left game port</b>
|
|
|
|
on a real Atari. Depending on the device, Stella will detect it as
|
|
|
|
either the left joystick, paddles 0 & 1, or the left driving controller.</li>
|
|
|
|
|
|
|
|
<li>The second Stelladaptor found will act as the <b>right game port</b>
|
|
|
|
on a real Atari. Depending on the device, Stella will detect it as
|
|
|
|
either the right joystick, paddles 2 & 3, or the right driving controller.</li>
|
|
|
|
|
|
|
|
<li>Any other Stelladaptors will be ignored.</li>
|
|
|
|
|
|
|
|
<li>The assignment ordering of Stelladaptor to port can be redefined with
|
|
|
|
'sa1' and 'sa2' (see description in 'Starting a Game').</li>
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
|
|
|
<br>
|
2005-05-28 23:57:10 +00:00
|
|
|
<p><h1>
|
2008-03-26 00:52:05 +00:00
|
|
|
<a name="Debugger">12. Integrated Debugger</a></h1>
|
2007-07-27 13:49:16 +00:00
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>Have a look at <a href="debugger.html">this page</a> for integrated debugger
|
|
|
|
documentation.
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
2008-03-26 00:52:05 +00:00
|
|
|
<a name="Settings">13. Settings File</a></h1>
|
2007-07-27 13:49:16 +00:00
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>Stella will remember when you change a setting either at the command line
|
|
|
|
or while the emulation is running, and use the settings the next time
|
|
|
|
you start the emulator. The settings are saved in a text file which can
|
|
|
|
be edited outside of Stella. This file can contain your default options,
|
|
|
|
and eliminates the need to specify them on the command line. Any
|
|
|
|
options specified on the command line will override those in the settings file.</p>
|
|
|
|
|
|
|
|
<p>The syntax for the settings file is very straightforward. Any line starting with
|
|
|
|
a ';' character is considered a comment and is ignored. Other lines must be of
|
|
|
|
the form: <b>command = value</b>, where <i>command</i> is the same as that
|
|
|
|
specified on the command line (without the '-' character), and <i>value</i>
|
|
|
|
is dependent on the command.</p>
|
|
|
|
|
|
|
|
<p>For example, the following table illustrates how command line and settings entries
|
|
|
|
are similar:</p>
|
|
|
|
|
|
|
|
<table BORDER=2>
|
|
|
|
<tr>
|
|
|
|
<th>Command Line</th>
|
|
|
|
<th>Settings File</th>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>-video gl</td>
|
|
|
|
<td>video = gl</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>-volume 75</td>
|
|
|
|
<td>volume = 75</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td>-showinfo 1</td>
|
|
|
|
<td>showinfo = 1 (or showinfo = true)</td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
|
|
|
<p>The settings file has a special name/location depending on which version of Stella
|
|
|
|
you use, which is currently not configurable:</p>
|
|
|
|
|
|
|
|
<p><table cellpadding="5" border="1">
|
|
|
|
<tr>
|
|
|
|
<td><b>Linux/Unix</b></td>
|
|
|
|
<td><i>$HOME/.stella/stellarc</i></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>Macintosh</b></td>
|
|
|
|
<td>Not applicable; settings are saved in <i>$HOME/Library/Preferences/StellaOSX.plist</i></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>Windows</b></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td><i>%MY_DOCUMENTS%\Stella\stella.ini</i> <b>OR</b><br>
|
|
|
|
<i>%CURRENT_DIR%\stella.ini</i> (if a file named 'disable_profiles.txt' exists in the application directory)</td>
|
2007-07-27 13:49:16 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
2008-03-26 00:52:05 +00:00
|
|
|
<a name="Cheats">14. Cheatcode Manager</a></h1>
|
2006-01-20 02:38:47 +00:00
|
|
|
<hr>
|
|
|
|
|
2006-01-20 15:13:37 +00:00
|
|
|
<p>Stella 2.0 contains support for Bob Colbert's Cheetah cheat codes, as
|
|
|
|
well as an extended Stella-specific type of cheat code that works on
|
|
|
|
bankswitched ROMs.</p>
|
2006-01-20 02:38:47 +00:00
|
|
|
|
2006-01-20 15:13:37 +00:00
|
|
|
<p>To add/remove/edit a cheat code, enter the 'Cheat Code' dialog:<br><br>
|
|
|
|
<img src="graphics/cheat.png">
|
2006-01-20 02:38:47 +00:00
|
|
|
|
2006-01-20 15:13:37 +00:00
|
|
|
<p>Currently, there are three types of cheatcodes available, all of which
|
|
|
|
must be entered in hexidecimal format:
|
|
|
|
<ul>
|
|
|
|
<li><p>Per-frame RAM cheats:<br>
|
|
|
|
Evaluated each frame, and apply to RAM only. Format as follows:
|
|
|
|
<pre>
|
|
|
|
4-digit code: c041
|
|
|
|
c0 = address
|
|
|
|
41 = data
|
|
|
|
</pre>
|
|
|
|
</li>
|
|
|
|
|
|
|
|
<li>Cheetah codes, which are explained in detail on
|
|
|
|
<a href="http://members.cox.net/rcolbert/">Bob Colbert's web page</a>,
|
|
|
|
along with a list of codes for various games. Cheetah codes
|
|
|
|
don't support bankswitched ROMs, so they only work for 2K or 4K ROMs.
|
|
|
|
Format as follows:
|
|
|
|
<pre>
|
|
|
|
6-digit (cheetah) code: aaaddc
|
|
|
|
aaa = address - $f000
|
|
|
|
dd = data
|
|
|
|
c = count - 1
|
|
|
|
</pre>
|
|
|
|
</li>
|
|
|
|
|
|
|
|
<li>Stella extended cheats are similar to Cheetah codes, except that
|
|
|
|
they can be 7 or 8 digits long, with the extra digits used for the
|
|
|
|
bank number:
|
|
|
|
<pre>
|
|
|
|
7-digit (stella) code: baaaddc
|
|
|
|
b = bank (0 to $f)
|
|
|
|
aaa = address - $f000
|
|
|
|
dd = data
|
|
|
|
c = count - 1
|
|
|
|
|
|
|
|
8-digit (stella) code: bbaaaddc
|
|
|
|
bb = bank (0 to $ff)
|
|
|
|
aaa = address - $f000
|
|
|
|
dd = data
|
|
|
|
c = count - 1
|
|
|
|
</pre>
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
|
|
|
|
<p>There's also the concept of <i>one shot</i> codes. These codes work
|
|
|
|
exactly the same as above, except they aren't saved. They are evaluated
|
|
|
|
once and immediately discarded.
|
|
|
|
|
|
|
|
<p>Here are a few cheat codes we've found:</p>
|
|
|
|
<pre>
|
|
|
|
Pitfall (standard Cheetah codes):
|
|
|
|
5b0ea1 - infinite lives
|
|
|
|
723ea1 - infinite time
|
|
|
|
aa5??0 - set starting level, ?? = 01 to ff (d0 is kinda neat)
|
|
|
|
|
|
|
|
Battlezone (Stella extended codes):
|
|
|
|
1236ea1 - infinite lives
|
|
|
|
|
|
|
|
Ms Pac-Man (Stella extended codes):
|
|
|
|
108fea1 - infinite lives
|
|
|
|
</pre>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<p>The name of the cheat database file is configurable through the
|
|
|
|
'<i>-cheatfile</i>' commandline argument and within the application itself
|
|
|
|
(see <b>Section 5 - <a href="#Starting">Starting a Game</a></b>). If the
|
|
|
|
path for this file hasn't been set, the default filename will depend on the
|
|
|
|
version of Stella, as follows:</p>
|
2005-09-13 18:27:42 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<p><table cellpadding="5" border="1">
|
|
|
|
<tr>
|
|
|
|
<td><b>Linux/Unix</b></td>
|
|
|
|
<td><i>$HOME/.stella/stella.cht</i></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>Macintosh</b></td>
|
|
|
|
<td><i>$HOME/.stella/stella.cht</i></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>Windows</b></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td><i>%MY_DOCUMENTS%\Stella\stella.cht</i> <b>OR</b><br>
|
|
|
|
<i>%CURRENT_DIR%\stella.cht</i> (if a file named 'disable_profiles.txt' exists in the application directory)</td>
|
2007-07-27 13:49:16 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
<p>Stella will require a restart for changes to this file to take effect.</p>
|
2005-05-28 23:57:10 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
|
|
|
<br><br>
|
2004-07-12 02:24:25 +00:00
|
|
|
<p><h1>
|
2008-03-26 00:52:05 +00:00
|
|
|
<a name="Properties">15. Game Properties</a></h1>
|
2002-04-22 01:45:08 +00:00
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>Stella uses game properties to specify the "best" emulator settings for a
|
2006-04-05 16:06:59 +00:00
|
|
|
game. As of version 2.2 of Stella, a default database of properties are
|
|
|
|
built-in, but you may modify these through the use of a <b>stella.pro</b> file.
|
2006-12-13 00:05:46 +00:00
|
|
|
This per-user file will contain all properties modified by the user. So this
|
|
|
|
means that when you upgrade Stella, your personal properties settings are
|
|
|
|
preserved.</p>
|
2005-09-13 18:27:42 +00:00
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<p>
|
|
|
|
<h2><b>Property File</b></h2>
|
|
|
|
|
|
|
|
<p>A property file consists of some number of blocks. Each block in the file
|
|
|
|
contains the properties for a single game. For example the general format of
|
|
|
|
a property file is:</p>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
<pre>
|
|
|
|
; Comments
|
2007-07-27 13:49:16 +00:00
|
|
|
"Cartridge.MD5" "Value"
|
|
|
|
"Property" "Value"
|
2002-04-22 01:45:08 +00:00
|
|
|
""
|
|
|
|
|
|
|
|
; Comments
|
2007-07-27 13:49:16 +00:00
|
|
|
"Cartridge.MD5" "Value"
|
|
|
|
"Property" "Value"
|
2002-04-22 01:45:08 +00:00
|
|
|
""
|
|
|
|
|
|
|
|
. . .
|
|
|
|
|
|
|
|
; Comments
|
2007-07-27 13:49:16 +00:00
|
|
|
"Cartridge.MD5" "Value"
|
|
|
|
"Property" "Value"
|
2002-04-22 01:45:08 +00:00
|
|
|
""</pre>
|
|
|
|
|
|
|
|
<p>Every block in the property file must have a unique value for the
|
2007-07-27 13:49:16 +00:00
|
|
|
<i>Cartridge.MD5</i> property.</p>
|
2002-04-22 01:45:08 +00:00
|
|
|
|
|
|
|
<p>
|
|
|
|
<h2><b>Properties</b></h2>
|
|
|
|
|
|
|
|
<p>Each block in a property file consists of a set of properties for a single
|
|
|
|
game. Stella supports the properties described below:</p>
|
|
|
|
|
|
|
|
<table CELLSPACING="10">
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Cartridge.MD5:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the MD5 checksum of the ROM image as a
|
2002-04-22 01:45:08 +00:00
|
|
|
string of hexadecimal digits. Stella uses this property while
|
|
|
|
attempting to match a game with its block of properties. If the
|
|
|
|
value of the property matches the MD5 checksum of the ROM image then
|
|
|
|
Stella uses that block of properties for the game. You can use the
|
|
|
|
GNU md5sum program, which is included with most Linux distributions,
|
|
|
|
to calculate the MD5 checksum of a ROM image.</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Cartridge.Manufacturer:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the game's manufacturer.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Cartridge.ModelNo:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the manufacturer's model number for the game.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Cartridge.Name:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the actual name of the game.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Cartridge.Note:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Contains any special notes about playing the game.</td>
|
2006-04-05 16:06:59 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Cartridge.Rarity:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates how rare a cartridge is, based on the scale described on AtariAge.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2005-09-13 18:27:42 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Cartridge.Sound:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates if the game should use 1 or 2 channels for sound output.
|
|
|
|
All original Atari 2600 machines supported 1 channel only,
|
2005-09-13 18:27:42 +00:00
|
|
|
but some homebrew games have been written to take advantage of stereo
|
2008-03-26 00:52:05 +00:00
|
|
|
sound. The value must be <b>Mono</b> or <b>Stereo</b>.</td>
|
2005-09-13 18:27:42 +00:00
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Cartridge.Type:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the bank-switching type for the game.
|
|
|
|
The value of this property must be either <b>Auto-detect</b> or one of the following
|
|
|
|
(for more information about bank-switching see Kevin Horton's 2600 bankswitching
|
|
|
|
document or the documentation in each cartridges source code file):
|
|
|
|
<table cellpadding="2" border="1">
|
|
|
|
<tr><th> Type </th><th>Description</th></tr>
|
|
|
|
<tr><td>0840 </td><td>8K ECONObanking </td></tr>
|
|
|
|
<tr><td>2K </td><td>2K Atari </td></tr>
|
|
|
|
<tr><td>3E </td><td>32K Tigervision </td></tr>
|
|
|
|
<tr><td>3F </td><td>512K Tigervision </td></tr>
|
|
|
|
<tr><td>4A50 </td><td>64K 4A50 + ram </td></tr>
|
|
|
|
<tr><td>4K </td><td>4K Atari </td></tr>
|
|
|
|
<tr><td>AR </td><td>Supercharger </td></tr>
|
|
|
|
<tr><td>CV </td><td>Commavid extra ram </td></tr>
|
|
|
|
<tr><td>DPC </td><td>Pitfall II </td></tr>
|
|
|
|
<tr><td>E0 </td><td>8K Parker Bros </td></tr>
|
|
|
|
<tr><td>E7 </td><td>16K M-network </td></tr>
|
|
|
|
<tr><td>F4 </td><td>32K Atari </td></tr>
|
|
|
|
<tr><td>F4SC </td><td>32K Atari + ram </td></tr>
|
|
|
|
<tr><td>F6 </td><td>16K Atari </td></tr>
|
|
|
|
<tr><td>F6SC </td><td>16K Atari + ram </td></tr>
|
|
|
|
<tr><td>F8 </td><td>8K Atari </td></tr>
|
|
|
|
<tr><td>F8SC </td><td>8K Atari + ram </td></tr>
|
|
|
|
<tr><td>FASC </td><td>CBS RAM Plus </td></tr>
|
|
|
|
<tr><td>FE </td><td>8K Decathlon </td></tr>
|
|
|
|
<tr><td>MB </td><td>Dynacom Megaboy </td></tr>
|
|
|
|
<tr><td>MC </td><td>C. Wilkson Megacart </td></tr>
|
|
|
|
<tr><td>SB </td><td>128-256k SUPERbanking </td></tr>
|
|
|
|
<tr><td>UA </td><td>8K UA Ltd. </td></tr>
|
|
|
|
<tr><td>X07 </td><td>64K AtariAge </td></tr>
|
|
|
|
</table></td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Console.LeftDifficulty:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the default difficulty setting for the left
|
|
|
|
player. The value must be <b>A</b> or <b>B</b>.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Console.RightDifficulty:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the default difficulty setting for the
|
|
|
|
right player. The value must be <b>A</b> or <b>B</b>.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-12-13 00:05:46 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Console.TelevisionType:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the default television setting for the
|
|
|
|
game. The value must be <b>Color</b> or <b>BlankAndWhite</b>.</td>
|
2006-12-13 00:05:46 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-01-20 02:38:47 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Console.SwapPorts:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates that the left and right ports should be
|
2006-01-20 02:38:47 +00:00
|
|
|
swapped internally. This is used for ROMs like 'Raiders' where the
|
2007-01-14 18:59:08 +00:00
|
|
|
Player 0 joystick is plugged into the right joystick port.
|
2008-03-26 00:52:05 +00:00
|
|
|
The value must be <b>Yes</b> or <b>No</b>.</td>
|
2006-01-20 02:38:47 +00:00
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Controller.Left:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates what type of controller the left player
|
|
|
|
uses. The value must be <b>Booster-Grip</b>, <b>Driving</b>,
|
|
|
|
<b>Keyboard</b>, <b>Paddles</b>, or <b>Joystick</b>.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Controller.Right:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates what type of controller the right player
|
|
|
|
uses. The value must be <b>Booster-Grip</b>, <b>Driving</b>,
|
|
|
|
<b>Keyboard</b>, <b>Paddles</b>, or <b>Joystick</b>.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-12-13 00:05:46 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Controller.SwapPaddles:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates that the left and right paddles in
|
2006-12-13 00:05:46 +00:00
|
|
|
a particular port should be swapped. This is used for ROMs like
|
|
|
|
'Demons to Diamonds' where the default paddle is paddle 1, not
|
|
|
|
paddle 0. Other ROMs such as 'Tac-Scan' default to paddle 3,
|
|
|
|
which can be set using both 'Controller.SwapPaddles' and
|
2008-03-26 00:52:05 +00:00
|
|
|
'Console.SwapPorts'. The value must be <b>Yes</b> or <b>No</b>.</td>
|
2006-12-13 00:05:46 +00:00
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Display.Format:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the television format the game was designed for. The value
|
|
|
|
must be <b>Auto-detect</b>, <b>NTSC</b>, <b>PAL</b>, <b>SECAM</b>, <b>NTSC50</b>,
|
|
|
|
<b>PAL60</b> or <b>SECAM60</b>.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Display.YStart:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the scan-line to start displaying at.
|
|
|
|
The value must be <i>n</i> such that 0 <= <i>n</i> <= 64.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
2007-01-14 18:59:08 +00:00
|
|
|
<td VALIGN="TOP"><i>Display.Height:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the number of scan-lines to display.
|
|
|
|
The value must be <i>n</i> such that 100 <= <i>n</i> <= 256.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-01-20 02:38:47 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Display.Phosphor:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates whether the phosphor effect should be emulated or not.
|
|
|
|
The value must be <b>Yes</b> or <b>No</b>.</td>
|
2006-01-20 02:38:47 +00:00
|
|
|
</tr>
|
|
|
|
|
2006-12-13 00:05:46 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP"><i>Display.PPBlend:</i></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td>Indicates the amount of blending which will occur while using the
|
|
|
|
phosphor effect. The value must be <i>n</i> such that 0 <= <i>n</i>
|
|
|
|
<= 100. The default value is 77.</td>
|
2006-12-13 00:05:46 +00:00
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td VALIGN="TOP"><i>Emulation.HmoveBlanks: (*)</i></td>
|
|
|
|
<td>Indicates whether the TIA HMOVE blank bug should be emulated or not.
|
|
|
|
The value must be <b>Yes</b> or <b>No</b>.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
2006-12-18 16:44:40 +00:00
|
|
|
<p><b>Note:</b> Items marked as '*' are deprecated, and will probably be
|
2007-01-14 18:59:08 +00:00
|
|
|
removed in a future release.</p>
|
2006-12-18 16:44:40 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<p>The name of the properties file is configurable through the
|
|
|
|
'<i>-propsfile</i>' commandline argument and within the application itself
|
|
|
|
(see <b>Section 5 - <a href="#Starting">Starting a Game</a></b>). If the
|
|
|
|
path for this file hasn't been set, the default filename will depend on the
|
|
|
|
version of Stella, as follows:</p>
|
2004-06-26 21:31:28 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<p><table cellpadding="5" border="1">
|
|
|
|
<tr>
|
|
|
|
<td><b>Linux/Unix</b></td>
|
|
|
|
<td><i>$HOME/.stella/stella.pro</i></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>Macintosh</b></td>
|
|
|
|
<td><i>$HOME/.stella/stella.pro</i></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>Windows</b></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td><i>%MY_DOCUMENTS%\Stella\stella.pro</i> <b>OR</b><br>
|
|
|
|
<i>%CURRENT_DIR%\stella.pro</i> (if a file named 'disable_profiles.txt' exists in the application directory)</td>
|
2007-07-27 13:49:16 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
<p>Stella will require a restart for changes to this file to take effect.</p>
|
2006-01-20 02:38:47 +00:00
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2002-04-22 01:45:08 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
2008-03-26 00:52:05 +00:00
|
|
|
<a name="Palette">16. Palette Support</a></h1>
|
2006-12-13 00:05:46 +00:00
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>An Atari 2600 palette consists of 128 colours, which are different
|
2008-03-26 00:52:05 +00:00
|
|
|
for the three major television standards (NTSC, PAL, SECAM).
|
2007-07-27 13:49:16 +00:00
|
|
|
Stella supports two built-in palettes and one user-defined palette for each format.
|
2006-12-13 00:05:46 +00:00
|
|
|
These are set using the '-palette' option, and are described as follows:</p>
|
|
|
|
<p><table cellpadding="5" border="1">
|
|
|
|
<tr>
|
|
|
|
<td><b>standard</b></td>
|
|
|
|
<td>The default palette from Stella 1.4 onwards.</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>z26</b></td>
|
|
|
|
<td>The palette from the z26 emulator.</td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>user</b></td>
|
|
|
|
<td>An external palette file, supplied by the user.</td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
|
|
|
|
<p>Support for a user-defined palette is a new feature for Stella 2.3, and
|
|
|
|
is further described as follows:
|
|
|
|
<ul>
|
2007-07-27 13:49:16 +00:00
|
|
|
<li>The palette file must be at least 792 bytes long. Colours are stored
|
2006-12-13 00:05:46 +00:00
|
|
|
in 24-bit RGB, with the first byte for red, the second for green, the
|
|
|
|
third for blue, for a total of 3 bytes per colour.</li>
|
|
|
|
<li>The first 384 bytes of the file (128 * 3) will be used for the NTSC
|
2008-03-26 00:52:05 +00:00
|
|
|
palette. The next 384 bytes (128 * 3) will be for the PAL palette.
|
2007-07-27 13:49:16 +00:00
|
|
|
The next 24 bytes (8 * 3) will be for the SECAM palette, which
|
|
|
|
consists of eight distinct colours. Any extra data in the file
|
|
|
|
will be ignored.</li>
|
2006-12-13 00:05:46 +00:00
|
|
|
<li>The PAL colour-loss effect is calculated within Stella. You do not
|
|
|
|
need to specify those colours in the palette file.
|
|
|
|
</ul>
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<p>The name of the palette file is configurable through the
|
|
|
|
'<i>-palettefile</i>' commandline argument and within the application itself
|
|
|
|
(see <b>Section 5 - <a href="#Starting">Starting a Game</a></b>). If the
|
|
|
|
path for this file hasn't been set, the default filename will depend on the
|
|
|
|
version of Stella, as follows:</p>
|
|
|
|
|
|
|
|
<p><table cellpadding="5" border="1">
|
|
|
|
<tr>
|
|
|
|
<td><b>Linux/Unix</b></td>
|
|
|
|
<td><i>$HOME/.stella/stella.pal</i></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>Macintosh</b></td>
|
|
|
|
<td><i>$HOME/.stella/stella.pal</i></td>
|
|
|
|
</tr>
|
|
|
|
<tr>
|
|
|
|
<td><b>Windows</b></td>
|
2008-03-26 00:52:05 +00:00
|
|
|
<td><i>%MY_DOCUMENTS%\Stella\stella.pal</i> <b>OR</b><br>
|
|
|
|
<i>%CURRENT_DIR%\stella.pal</i> (if a file named 'disable_profiles.txt' exists in the application directory)</td>
|
2007-07-27 13:49:16 +00:00
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
<p>Note that to actually use the external palette, the palette file must
|
2008-03-26 00:52:05 +00:00
|
|
|
exist and be valid, <b>and</b> the palette option should be set to <i>user</i>.
|
2007-07-27 13:49:16 +00:00
|
|
|
The current ROM will have to be reloaded for changes to this file to take
|
|
|
|
effect.</p>
|
2006-12-13 00:05:46 +00:00
|
|
|
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2006-12-13 00:05:46 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
2008-03-26 00:52:05 +00:00
|
|
|
<a name="Acknowledgments">17. Acknowledgments</a></h1>
|
2002-04-22 01:45:08 +00:00
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>Bradford W. Mott started developing Stella during the fall of 1995 and since
|
|
|
|
then a number of people from around the world have contributed to the project.
|
|
|
|
Some people have provided technical help while others have offered suggestions
|
|
|
|
and praise. The Stella Team is grateful for all the help and support it has
|
|
|
|
received over the years. The following is an incomplete list of the people who have
|
|
|
|
played a part in bringing Stella to you:</p>
|
|
|
|
|
|
|
|
<table CELLSPACING="15">
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Stephen Anthony</td>
|
|
|
|
<td>Ported Stella 1.1 to SDL. Added extra command line options to X11/SDL
|
|
|
|
versions. Added INI file support, faster startup, snapshot support,
|
2002-11-03 22:22:32 +00:00
|
|
|
and pause functionality to core. Converted Stella 1.1 manual to HTML.
|
2004-06-26 21:31:28 +00:00
|
|
|
Ported codebase to SDL for Windows/MacOSX. Added OpenGL support and
|
|
|
|
Stelladaptor support. Current maintainer for the Linux and Windows versions.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">David Aspell</td>
|
|
|
|
<td>Ported release 0.7 of Stella to Java</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Christopher Bennett</td>
|
|
|
|
<td>Helped discover a Superchanger emulation bug in release 1.0 of Stella</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Alexander Bilstein</td>
|
|
|
|
<td>Provided "A Brief History of the Atari 2600" for this manual</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Dan Boris</td>
|
|
|
|
<td>Provided technical information on the Supercharger</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Piero Cavina</td>
|
|
|
|
<td>Allowed "Oystron" to be included in the Stella distribution</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Bob Colbert</td>
|
|
|
|
<td>Allowed "Okie Dokie" to be included in the Stella distribution</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Joe D'Andrea</td>
|
|
|
|
<td>Author of the IRIX port of Stella until release 1.2</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Renato Ferreira</td>
|
|
|
|
<td>Provided code to support private colormaps under Unix</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Ron Fries</td>
|
|
|
|
<td>Author of the awesome TIA Sound library</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Aaron Giles</td>
|
|
|
|
<td>Author of the Power Macintosh version of Stella until release 1.1</td>
|
|
|
|
</tr>
|
|
|
|
|
2004-06-26 21:31:28 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Mark Grebe</td>
|
|
|
|
<td>Author of the Macintosh OSX version of Stella starting with the
|
|
|
|
1.4 release. Helped with Stelladaptor support.</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Mark Hahn</td>
|
|
|
|
<td>Allowed "Elk Attack" to be included in the Stella distribution and
|
|
|
|
provided help with the TIA HMOVE blank bug</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Kevin Horton</td>
|
|
|
|
<td>Author of the definitive Atari 2600 bank-switching document</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Thomas Jentzsch</td>
|
|
|
|
<td>Provided updated NTSC palette and many ideas</td>
|
|
|
|
</tr>
|
|
|
|
|
2005-10-09 22:08:31 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Kostas Nakos</td>
|
|
|
|
<td>Author/maintainer of the WinCE version of Stella starting with the
|
|
|
|
2.0 release</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Erik Kovach</td>
|
|
|
|
<td>Author of the property file for release 0.7, 1.0, 1.1, and 1.2 of Stella</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Daniel Marks</td>
|
|
|
|
<td>Provided improved keyboard joystick support for Stella release 0.1</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">James Mcclain</td>
|
|
|
|
<td>Provided patches for the 1.2 release to get Stella to compile with GCC 3.0</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">David McEwen</td>
|
|
|
|
<td>Author of the Acorn version of Stella</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Jeff Miller</td>
|
|
|
|
<td>Author of the Windows version of Stella until release 1.2</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Dan Mowczan</td>
|
|
|
|
<td>Provided a Supercharger to help with Stella's development</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Jack Nutting</td>
|
|
|
|
<td>Author of the OpenStep version of Stella</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Manuel Polik</td>
|
|
|
|
<td>Author of the Windows version of Stella starting with the 1.2 release</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Jim Pragit</td>
|
|
|
|
<td>Author of the "Game Menu" emulator game shell</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">John Saeger</td>
|
|
|
|
<td>Participated in a helpful discussion on understanding the TIA's
|
|
|
|
RESPx multi-sprite trick</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Chris Salomon</td>
|
|
|
|
<td>Provided information and code to help implement Supercharger support</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Jason Scott</td>
|
|
|
|
<td>Organizer of the property file archive for early versions of
|
|
|
|
Stella; now he's helping with the web site</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">David Shaw</td>
|
|
|
|
<td>Provided make targets for the BSDI platform</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Raul Silva</td>
|
|
|
|
<td>Helped with design and graphics for an early version of the Stella
|
|
|
|
web site</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Chris Snell</td>
|
|
|
|
<td>Maintained a mirror of the Stella FTP site</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Darrell Spice Jr.</td>
|
|
|
|
<td>Author of the OS/2 version of Stella</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">John Stiles</td>
|
2004-06-26 21:31:28 +00:00
|
|
|
<td>Maintained the Macintosh version of Stella until release 1.2</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Eckhard Stolberg</td>
|
|
|
|
<td>Provided a description of the TIA bug that produces the star field
|
|
|
|
effect in Cosmic Ark, provided the PAL television palette, and
|
|
|
|
participated in a helpful discussion on understanding the TIA's RESPx
|
2008-03-26 00:52:05 +00:00
|
|
|
multi-sprite trick. Provided the Commavid, Megaboy, 4A50 and X07 support
|
|
|
|
for Stella as well as some improved Supercharger BIOS code.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Matthew Stroup</td>
|
|
|
|
<td>Author of the Amiga version of Stella</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Joel Sutton</td>
|
|
|
|
<td>Author of the FreeBSD version of Stella</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Greg Troutman</td>
|
|
|
|
<td>Allowed "This Planet Sucks" to be included in the Stella distribution</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Curt Vendel</td>
|
|
|
|
<td>Provided schematics of the TIA which are being used to improve the
|
|
|
|
TIA emulation.</td>
|
|
|
|
</tr>
|
|
|
|
|
2005-10-09 22:08:31 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">David Voswinkel</td>
|
|
|
|
<td>Maintainer of the PSP version of Stella starting with the 2.0 release</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Brian Watson</td>
|
|
|
|
<td>Helped with getting the illegal CPU instruction support working with Stella.
|
|
|
|
Brian also submitted a number of other changes, such as debugger support, which
|
2005-09-13 18:27:42 +00:00
|
|
|
have been finally integrated into the 2.0 release of Stella. Without
|
|
|
|
a doubt, there would be no debugger support in Stella if not for the
|
|
|
|
tireless work of Brian.</td>
|
2002-04-22 01:45:08 +00:00
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Keith Wilkins</td>
|
|
|
|
<td>Maintained the DOS version of Stella until release 0.7</td>
|
|
|
|
</tr>
|
|
|
|
|
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Jeff Wisnia</td>
|
|
|
|
<td>Provided technical data sheet for the 6532 RIOT chip</td>
|
|
|
|
</tr>
|
|
|
|
|
2008-03-26 00:52:05 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Albert Yarusso (aka Al from AtariAge)</td>
|
|
|
|
<td>Provided helpful feedback for the OSX port, and generously
|
|
|
|
donated an AtariVox device to help with development</td>
|
|
|
|
</tr>
|
|
|
|
|
2006-04-05 16:06:59 +00:00
|
|
|
<tr>
|
|
|
|
<td VALIGN="TOP">Alex Zaballa</td>
|
|
|
|
<td>Maintainer of the GP2X version of Stella starting with the 2.1 release</td>
|
|
|
|
</tr>
|
|
|
|
|
2002-04-22 01:45:08 +00:00
|
|
|
</table>
|
|
|
|
|
2007-07-27 13:49:16 +00:00
|
|
|
|
|
|
|
<!-- ///////////////////////////////////////////////////////////////////////// -->
|
2002-04-22 01:45:08 +00:00
|
|
|
<br><br>
|
|
|
|
<p><h1>
|
2008-03-26 00:52:05 +00:00
|
|
|
<a name="License">18. License and Disclaimer</a></h1>
|
2002-04-22 01:45:08 +00:00
|
|
|
<hr>
|
|
|
|
|
|
|
|
<p>
|
|
|
|
<H2>GNU GENERAL PUBLIC LICENSE</h2>
|
|
|
|
<P>
|
|
|
|
Version 2, June 1991
|
|
|
|
|
|
|
|
</P>
|
|
|
|
|
|
|
|
<PRE>
|
|
|
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
|
|
|
59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
|
|
|
|
|
|
|
|
Everyone is permitted to copy and distribute verbatim copies
|
|
|
|
of this license document, but changing it is not allowed.
|
|
|
|
</PRE>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<H2>Preamble</H2>
|
|
|
|
|
|
|
|
<P>
|
|
|
|
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 Library General Public License instead.) You can apply it to
|
|
|
|
your programs, too.
|
|
|
|
|
|
|
|
</P>
|
|
|
|
<P>
|
|
|
|
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.
|
|
|
|
|
|
|
|
</P>
|
|
|
|
<P>
|
|
|
|
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.
|
|
|
|
|
|
|
|
</P>
|
|
|
|
<P>
|
|
|
|
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.
|
|
|
|
|
|
|
|
</P>
|
|
|
|
<P>
|
|
|
|
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.
|
|
|
|
|
|
|
|
</P>
|
|
|
|
<P>
|
|
|
|
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.
|
|
|
|
|
|
|
|
</P>
|
|
|
|
<P>
|
|
|
|
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.
|
|
|
|
|
|
|
|
</P>
|
|
|
|
<P>
|
|
|
|
The precise terms and conditions for copying, distribution and
|
|
|
|
modification follow.
|
|
|
|
|
|
|
|
</P>
|
|
|
|
|
|
|
|
|
|
|
|
<H2>TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION</H2>
|
|
|
|
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>0.</STRONG>
|
|
|
|
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".
|
|
|
|
<P>
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>1.</STRONG>
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>2.</STRONG>
|
|
|
|
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:
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<UL>
|
|
|
|
|
|
|
|
<LI><STRONG>a)</STRONG>
|
|
|
|
You must cause the modified files to carry prominent notices
|
|
|
|
stating that you changed the files and the date of any change.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
<LI><STRONG>b)</STRONG>
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
<LI><STRONG>c)</STRONG>
|
|
|
|
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.)
|
|
|
|
</UL>
|
|
|
|
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>3.</STRONG>
|
|
|
|
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:
|
|
|
|
|
|
|
|
|
|
|
|
<!-- we use this doubled UL to get the sub-sections indented, -->
|
|
|
|
<!-- while making the bullets as unobvious as possible. -->
|
|
|
|
<UL>
|
|
|
|
|
|
|
|
<LI><STRONG>a)</STRONG>
|
|
|
|
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,
|
|
|
|
|
|
|
|
<P>
|
|
|
|
<LI><STRONG>b)</STRONG>
|
|
|
|
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,
|
|
|
|
|
|
|
|
<P>
|
|
|
|
<LI><STRONG>c)</STRONG>
|
|
|
|
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.)
|
|
|
|
</UL>
|
|
|
|
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>4.</STRONG>
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>5.</STRONG>
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>6.</STRONG>
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>7.</STRONG>
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
This section is intended to make thoroughly clear what is believed to
|
|
|
|
be a consequence of the rest of this License.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>8.</STRONG>
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>9.</STRONG>
|
|
|
|
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.
|
|
|
|
<P>
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
|
|
|
|
<STRONG>10.</STRONG>
|
|
|
|
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.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<P><STRONG>NO WARRANTY</STRONG></P>
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>11.</STRONG>
|
|
|
|
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.
|
|
|
|
|
|
|
|
<P>
|
|
|
|
|
|
|
|
<STRONG>12.</STRONG>
|
|
|
|
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.
|
|
|
|
|
|
|
|
</body>
|
|
|
|
</html>
|