2006-06-09 02:45:11 +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
|
|
|
|
//
|
2008-02-06 13:45:24 +00:00
|
|
|
// Copyright (c) 1995-2008 by Bradford W. Mott and the Stella team
|
2006-06-09 02:45:11 +00:00
|
|
|
//
|
|
|
|
// See the file "license" for information on usage and redistribution of
|
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//
|
2008-04-11 17:56:35 +00:00
|
|
|
// $Id: AtariVox.hxx,v 1.11 2008-04-11 17:56:34 stephena Exp $
|
2006-06-09 02:45:11 +00:00
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef ATARIVOX_HXX
|
|
|
|
#define ATARIVOX_HXX
|
|
|
|
|
2008-03-31 00:59:30 +00:00
|
|
|
class SpeakJet;
|
|
|
|
|
2006-06-09 02:45:11 +00:00
|
|
|
#include "Control.hxx"
|
2008-03-31 00:59:30 +00:00
|
|
|
#include "SerialPort.hxx"
|
2006-06-09 02:45:11 +00:00
|
|
|
|
|
|
|
/**
|
2006-06-11 07:13:29 +00:00
|
|
|
Richard Hutchinson's AtariVox "controller": A speech synthesizer and
|
2006-06-09 02:45:11 +00:00
|
|
|
storage device.
|
|
|
|
|
2006-06-11 07:13:29 +00:00
|
|
|
This code owes a great debt to Alex Herbert's AtariVox documentation and
|
|
|
|
driver code.
|
|
|
|
|
2006-06-09 02:45:11 +00:00
|
|
|
@author B. Watson
|
2008-04-11 17:56:35 +00:00
|
|
|
@version $Id: AtariVox.hxx,v 1.11 2008-04-11 17:56:34 stephena Exp $
|
2006-06-09 02:45:11 +00:00
|
|
|
*/
|
|
|
|
class AtariVox : public Controller
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Create a new AtariVox controller plugged into the specified jack
|
|
|
|
|
2008-04-11 17:56:35 +00:00
|
|
|
@param jack The jack the controller is plugged into
|
|
|
|
@param event The event object to use for events
|
|
|
|
@param port The serial port object
|
|
|
|
@param device Name of the port used for reading and writing
|
2006-06-09 02:45:11 +00:00
|
|
|
*/
|
2008-04-11 17:56:35 +00:00
|
|
|
AtariVox(Jack jack, const Event& event, const SerialPort& port,
|
|
|
|
const string& device);
|
2006-06-09 02:45:11 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor
|
|
|
|
*/
|
|
|
|
virtual ~AtariVox();
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
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
|
|
|
|
*/
|
|
|
|
virtual void write(DigitalPin pin, bool value);
|
|
|
|
|
2008-03-29 19:15:57 +00:00
|
|
|
/**
|
|
|
|
Update the entire digital and analog pin state according to the
|
|
|
|
events currently set.
|
|
|
|
*/
|
|
|
|
virtual void update();
|
|
|
|
|
2008-04-11 17:56:35 +00:00
|
|
|
virtual string about() const;
|
|
|
|
|
2008-03-31 00:59:30 +00:00
|
|
|
#ifdef SPEAKJET_EMULATION
|
2006-06-11 22:43:55 +00:00
|
|
|
SpeakJet* getSpeakJet() { return mySpeakJet; }
|
2008-03-31 00:59:30 +00:00
|
|
|
#endif
|
2006-06-11 22:43:55 +00:00
|
|
|
|
2006-06-11 07:13:29 +00:00
|
|
|
private:
|
2007-02-22 02:15:46 +00:00
|
|
|
void clockDataIn(bool value);
|
|
|
|
void shiftIn(bool value);
|
2006-06-11 07:13:29 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
// How far off (in CPU cycles) can each write occur from when it's
|
|
|
|
// supposed to happen? Eventually, this will become a user-settable
|
2007-02-22 02:15:46 +00:00
|
|
|
// property... or it may turn out to be unnecessary.
|
2006-06-11 07:13:29 +00:00
|
|
|
enum { TIMING_SLOP = 0 };
|
|
|
|
|
2008-03-31 00:59:30 +00:00
|
|
|
// Instance of an real serial port on the system
|
|
|
|
// Assuming there's a real AtariVox attached, we can send SpeakJet
|
|
|
|
// bytes directly to it
|
|
|
|
SerialPort* mySerialPort;
|
|
|
|
|
|
|
|
#ifdef SPEAKJET_EMULATION
|
2007-02-22 02:15:46 +00:00
|
|
|
// Instance of SpeakJet which will actually do the talking for us.
|
|
|
|
SpeakJet *mySpeakJet;
|
2008-03-31 00:59:30 +00:00
|
|
|
#endif
|
2006-06-11 07:13:29 +00:00
|
|
|
|
2006-06-09 02:45:11 +00:00
|
|
|
// State of the output pins
|
|
|
|
uInt8 myPinState;
|
|
|
|
|
2007-02-22 02:15:46 +00:00
|
|
|
// How many bits have been shifted into the shift register?
|
|
|
|
uInt8 myShiftCount;
|
2006-06-11 07:13:29 +00:00
|
|
|
|
2007-02-22 02:15:46 +00:00
|
|
|
// Shift register. Data comes in serially:
|
|
|
|
// 1 start bit, always 0
|
|
|
|
// 8 data bits, LSB first
|
|
|
|
// 1 stop bit, always 1
|
|
|
|
uInt16 myShiftRegister;
|
2006-06-09 02:45:11 +00:00
|
|
|
|
2006-06-11 07:13:29 +00:00
|
|
|
// When did the last data write start, in CPU cycles?
|
2007-02-22 02:15:46 +00:00
|
|
|
// The real SpeakJet chip reads data at 19200 bits/sec. Alex's
|
|
|
|
// driver code sends data at 62 CPU cycles per bit, which is
|
|
|
|
// "close enough".
|
2006-06-11 07:13:29 +00:00
|
|
|
uInt32 myLastDataWriteCycle;
|
2008-04-11 17:56:35 +00:00
|
|
|
|
|
|
|
// Holds information concerning serial port usage
|
|
|
|
string myAboutString;
|
2006-06-09 02:45:11 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|