2008-03-31 00:59:30 +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
|
|
|
|
//
|
2015-01-01 03:49:32 +00:00
|
|
|
// Copyright (c) 1995-2015 by Bradford W. Mott, Stephen Anthony
|
2010-04-10 21:37:23 +00:00
|
|
|
// and the Stella Team
|
2008-03-31 00:59:30 +00:00
|
|
|
//
|
2010-01-10 03:23:32 +00:00
|
|
|
// See the file "License.txt" for information on usage and redistribution of
|
2008-03-31 00:59:30 +00:00
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//
|
2009-05-13 13:55:40 +00:00
|
|
|
// $Id$
|
2008-03-31 00:59:30 +00:00
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef SERIALPORT_HXX
|
|
|
|
#define SERIALPORT_HXX
|
|
|
|
|
|
|
|
#include "bspf.hxx"
|
|
|
|
|
|
|
|
/**
|
|
|
|
This class provides an interface for a standard serial port.
|
2008-04-11 17:56:35 +00:00
|
|
|
For now, this is used when connecting a real AtariVox device,
|
|
|
|
and as such it always uses 19200, 8n1, no flow control.
|
2008-03-31 00:59:30 +00:00
|
|
|
|
|
|
|
@author Stephen Anthony
|
2009-05-13 13:55:40 +00:00
|
|
|
@version $Id$
|
2008-03-31 00:59:30 +00:00
|
|
|
*/
|
|
|
|
class SerialPort
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
SerialPort() { }
|
|
|
|
virtual ~SerialPort() { }
|
|
|
|
|
|
|
|
/**
|
|
|
|
Open the given serial port with the specified attributes.
|
|
|
|
|
|
|
|
@param device The name of the port
|
|
|
|
@return False on any errors, else true
|
|
|
|
*/
|
2008-04-11 17:56:35 +00:00
|
|
|
virtual bool openPort(const string& device) { return false; }
|
2008-03-31 00:59:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Read a byte from the serial port.
|
|
|
|
|
|
|
|
@param data Destination for the byte read from the port
|
|
|
|
@return True if a byte was read, else false
|
|
|
|
*/
|
2008-04-11 00:29:15 +00:00
|
|
|
virtual bool readByte(uInt8* data) { return false; }
|
2008-03-31 00:59:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Write a byte to the serial port.
|
|
|
|
|
|
|
|
@param data The byte to write to the port
|
|
|
|
@return True if a byte was written, else false
|
|
|
|
*/
|
2008-04-11 00:29:15 +00:00
|
|
|
virtual bool writeByte(const uInt8* data) { return false; }
|
2015-01-24 16:28:06 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
/**
|
|
|
|
Close a previously opened serial port.
|
|
|
|
*/
|
|
|
|
virtual void closePort() { }
|
2015-04-26 19:02:42 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
// Following constructors and assignment operators not supported
|
|
|
|
SerialPort(const SerialPort&) = delete;
|
|
|
|
SerialPort(SerialPort&&) = delete;
|
|
|
|
SerialPort& operator=(const SerialPort&) = delete;
|
|
|
|
SerialPort& operator=(SerialPort&&) = delete;
|
2008-03-31 00:59:30 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|