2008-04-29 15:49:34 +00:00
|
|
|
//============================================================================
|
|
|
|
//
|
2016-12-30 00:00:30 +00:00
|
|
|
// SSSS tt lll lll
|
|
|
|
// SS SS tt ll ll
|
|
|
|
// SS tttttt eeee ll ll aaaa
|
2008-04-29 15:49:34 +00:00
|
|
|
// 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
|
|
|
|
//
|
2016-12-30 00:00:30 +00:00
|
|
|
// Copyright (c) 1995-2017 by Bradford W. Mott, Stephen Anthony
|
2010-04-10 21:37:23 +00:00
|
|
|
// and the Stella Team
|
2008-04-29 15:49:34 +00:00
|
|
|
//
|
2010-01-10 03:23:32 +00:00
|
|
|
// See the file "License.txt" for information on usage and redistribution of
|
2008-04-29 15:49:34 +00:00
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef SAVEKEY_HXX
|
|
|
|
#define SAVEKEY_HXX
|
|
|
|
|
|
|
|
#include "Control.hxx"
|
2015-12-30 19:07:11 +00:00
|
|
|
#include "MT24LC256.hxx"
|
2008-04-29 15:49:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Richard Hutchinson's SaveKey "controller", consisting of a 32KB EEPROM
|
|
|
|
accessible using the I2C protocol.
|
|
|
|
|
|
|
|
This code owes a great debt to Alex Herbert's AtariVox documentation and
|
|
|
|
driver code.
|
|
|
|
|
|
|
|
@author Stephen Anthony
|
|
|
|
*/
|
|
|
|
class SaveKey : public Controller
|
|
|
|
{
|
2014-06-29 23:25:53 +00:00
|
|
|
friend class SaveKeyWidget;
|
|
|
|
|
2008-04-29 15:49:34 +00:00
|
|
|
public:
|
|
|
|
/**
|
2009-01-26 21:08:07 +00:00
|
|
|
Create a new SaveKey controller plugged into the specified jack
|
2008-04-29 15:49:34 +00:00
|
|
|
|
|
|
|
@param jack The jack the controller is plugged into
|
|
|
|
@param event The event object to use for events
|
|
|
|
@param system The system using this controller
|
|
|
|
@param eepromfile The file containing the EEPROM data
|
|
|
|
*/
|
|
|
|
SaveKey(Jack jack, const Event& event, const System& system,
|
|
|
|
const string& eepromfile);
|
2015-12-30 19:07:11 +00:00
|
|
|
virtual ~SaveKey() = default;
|
2008-04-29 15:49:34 +00:00
|
|
|
|
|
|
|
public:
|
2012-10-24 10:10:32 +00:00
|
|
|
using Controller::read;
|
|
|
|
|
2008-04-29 15:49:34 +00:00
|
|
|
/**
|
|
|
|
Read the value of the specified digital pin for this controller.
|
|
|
|
|
|
|
|
@param pin The pin of the controller jack to read
|
|
|
|
@return The state of the pin
|
|
|
|
*/
|
2015-07-10 18:59:03 +00:00
|
|
|
bool read(DigitalPin pin) override;
|
2008-04-29 15:49:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Write the given value to the specified digital pin for this
|
|
|
|
controller. Writing is only allowed to the pins associated
|
|
|
|
with the PIA. Therefore you cannot write to pin six.
|
|
|
|
|
|
|
|
@param pin The pin of the controller jack to write to
|
|
|
|
@param value The value to write to the pin
|
|
|
|
*/
|
2015-07-10 18:59:03 +00:00
|
|
|
void write(DigitalPin pin, bool value) override;
|
2008-04-29 15:49:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Update the entire digital and analog pin state according to the
|
|
|
|
events currently set.
|
|
|
|
*/
|
2015-07-10 18:59:03 +00:00
|
|
|
void update() override { }
|
2008-04-29 15:49:34 +00:00
|
|
|
|
2016-12-09 22:34:14 +00:00
|
|
|
/**
|
|
|
|
Notification method invoked by the system indicating that the
|
|
|
|
console is about to be destroyed. It may be necessary to override
|
|
|
|
this method for controllers that need cleanup before exiting.
|
|
|
|
*/
|
|
|
|
void close() override;
|
|
|
|
|
2008-05-19 02:53:58 +00:00
|
|
|
/**
|
|
|
|
Notification method invoked by the system right before the
|
2016-12-30 00:00:30 +00:00
|
|
|
system resets its cycle counter to zero. It may be necessary
|
2008-05-19 02:53:58 +00:00
|
|
|
to override this method for devices that remember cycle counts.
|
|
|
|
*/
|
2015-07-10 18:59:03 +00:00
|
|
|
void systemCyclesReset() override;
|
2008-05-19 02:53:58 +00:00
|
|
|
|
2008-04-29 15:49:34 +00:00
|
|
|
private:
|
|
|
|
// The EEPROM used in the SaveKey
|
2014-11-03 17:36:28 +00:00
|
|
|
unique_ptr<MT24LC256> myEEPROM;
|
2015-04-26 19:02:42 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
// Following constructors and assignment operators not supported
|
|
|
|
SaveKey() = delete;
|
|
|
|
SaveKey(const SaveKey&) = delete;
|
|
|
|
SaveKey(SaveKey&&) = delete;
|
|
|
|
SaveKey& operator=(const SaveKey&) = delete;
|
|
|
|
SaveKey& operator=(SaveKey&&) = delete;
|
2008-04-29 15:49:34 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|