2001-12-27 19:54:36 +00:00
|
|
|
//============================================================================
|
|
|
|
//
|
|
|
|
// SSSS tt lll lll
|
|
|
|
// SS SS tt ll ll
|
|
|
|
// SS tttttt eeee ll ll aaaa
|
|
|
|
// SSSS tt ee ee ll ll aa
|
|
|
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
|
|
|
// SS SS tt ee ll ll aa aa
|
|
|
|
// SSSS ttt eeeee llll llll aaaaa
|
|
|
|
//
|
2007-01-01 18:04:56 +00:00
|
|
|
// Copyright (c) 1995-2007 by Bradford W. Mott and the Stella team
|
2001-12-27 19:54:36 +00:00
|
|
|
//
|
|
|
|
// See the file "license" for information on usage and redistribution of
|
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//
|
2007-01-01 18:04:56 +00:00
|
|
|
// $Id: CartFE.hxx,v 1.7 2007-01-01 18:04:46 stephena Exp $
|
2001-12-27 19:54:36 +00:00
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef CARTRIDGEFE_HXX
|
|
|
|
#define CARTRIDGEFE_HXX
|
|
|
|
|
|
|
|
class CartridgeFE;
|
2002-05-13 19:17:32 +00:00
|
|
|
class Serializer;
|
|
|
|
class Deserializer;
|
2001-12-27 19:54:36 +00:00
|
|
|
|
|
|
|
#include "bspf.hxx"
|
|
|
|
#include "Cart.hxx"
|
|
|
|
|
|
|
|
/**
|
|
|
|
Bankswitching method used by Activison's Robot Tank and Decathlon.
|
|
|
|
|
|
|
|
Kevin Horton describes FE as follows:
|
|
|
|
|
|
|
|
Used only on two carts (Robot Tank and Decathlon). These
|
|
|
|
carts are very weird. It does not use accesses to the stack
|
|
|
|
like was previously thought. Instead, if you watch the called
|
|
|
|
addresses very carefully, you can see that they are either Dxxx
|
|
|
|
or Fxxx. This determines the bank to use. Just monitor A13 of
|
|
|
|
the processor and use it to determine your bank! :-) Of course
|
|
|
|
the 6507 in the 2600 does not have an A13, so the cart must have
|
|
|
|
an extra bit in the ROM matrix to tell when to switch banks.
|
|
|
|
There is *no* way to determine which bank you want to be in from
|
|
|
|
monitoring the bus.
|
|
|
|
|
|
|
|
@author Bradford W. Mott
|
2007-01-01 18:04:56 +00:00
|
|
|
@version $Id: CartFE.hxx,v 1.7 2007-01-01 18:04:46 stephena Exp $
|
2001-12-27 19:54:36 +00:00
|
|
|
*/
|
|
|
|
class CartridgeFE : public Cartridge
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Create a new cartridge using the specified image
|
|
|
|
|
|
|
|
@param image Pointer to the ROM image
|
|
|
|
*/
|
|
|
|
CartridgeFE(const uInt8* image);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor
|
|
|
|
*/
|
|
|
|
virtual ~CartridgeFE();
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Get a null terminated string which is the device's name (i.e. "M6532")
|
|
|
|
|
|
|
|
@return The name of the device
|
|
|
|
*/
|
|
|
|
virtual const char* name() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Reset device to its power-on state
|
|
|
|
*/
|
|
|
|
virtual void reset();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Install cartridge in the specified system. Invoked by the system
|
|
|
|
when the cartridge is attached to it.
|
|
|
|
|
|
|
|
@param system The system the device should install itself in
|
|
|
|
*/
|
|
|
|
virtual void install(System& system);
|
|
|
|
|
2002-05-13 19:17:32 +00:00
|
|
|
/**
|
|
|
|
Saves the current state of this device to the given Serializer.
|
|
|
|
|
|
|
|
@param out The serializer device to save to.
|
|
|
|
@return The result of the save. True on success, false on failure.
|
|
|
|
*/
|
|
|
|
virtual bool save(Serializer& out);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Loads the current state of this device from the given Deserializer.
|
|
|
|
|
|
|
|
@param in The deserializer device to load from.
|
|
|
|
@return The result of the load. True on success, false on failure.
|
|
|
|
*/
|
|
|
|
virtual bool load(Deserializer& in);
|
|
|
|
|
2005-07-30 16:58:22 +00:00
|
|
|
virtual uInt8* getImage(int& size);
|
|
|
|
|
2001-12-27 19:54:36 +00:00
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Get the byte at the specified address.
|
|
|
|
|
|
|
|
@return The byte at the specified address
|
|
|
|
*/
|
|
|
|
virtual uInt8 peek(uInt16 address);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Change the byte at the specified address to the given value
|
|
|
|
|
|
|
|
@param address The address where the value should be stored
|
|
|
|
@param value The value to be stored at the address
|
|
|
|
*/
|
|
|
|
virtual void poke(uInt16 address, uInt8 value);
|
|
|
|
|
2005-06-28 01:15:17 +00:00
|
|
|
bool patch(uInt16 address, uInt8 value);
|
|
|
|
|
2001-12-27 19:54:36 +00:00
|
|
|
private:
|
|
|
|
// The 8K ROM image of the cartridge
|
|
|
|
uInt8 myImage[8192];
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|