A library for talking to Multi-Tech's Cellular SocketModem Devices.

Dependents:   M2X_dev axeda_wrapper_dev MTS_M2x_Example1 MTS_Cellular_Connect_Example ... more

Committer:
jengbrecht
Date:
Fri Dec 27 15:55:35 2013 +0000
Revision:
83:9813f9b8ee68
Parent:
51:d22d3d87391f
Child:
86:186bbf974c7c
Changed MTSSerialFlowControl to inherit from MTSSerial

Who changed what in which revision?

UserRevisionLine numberNew contents of line
jengbrecht 0:563b70517320 1 #ifndef MTSSERIAL_H
jengbrecht 0:563b70517320 2 #define MTSSERIAL_H
jengbrecht 0:563b70517320 3
jengbrecht 0:563b70517320 4 #include "mbed.h"
jengbrecht 0:563b70517320 5 #include "MTSBufferedIO.h"
jengbrecht 0:563b70517320 6
jengbrecht 83:9813f9b8ee68 7 namespace mts
jengbrecht 83:9813f9b8ee68 8 {
jengbrecht 83:9813f9b8ee68 9
jengbrecht 36:bb6b293c7495 10 /** This class derives from MTSBufferedIO and provides a buffered wrapper to the
jengbrecht 45:40745c2036cf 11 * standard mbed Serial class. Since it depends only on the mbed Serial class for
jengbrecht 45:40745c2036cf 12 * accessing serial data, this class is inherently portable accross different mbed
jengbrecht 45:40745c2036cf 13 * platforms.
jengbrecht 36:bb6b293c7495 14 */
jengbrecht 0:563b70517320 15 class MTSSerial : public MTSBufferedIO
jengbrecht 0:563b70517320 16 {
jengbrecht 0:563b70517320 17 public:
jengbrecht 45:40745c2036cf 18 /** Creates a new MTSSerial object that can be used to talk to an mbed serial port
jengbrecht 36:bb6b293c7495 19 * through internal SW buffers.
jengbrecht 36:bb6b293c7495 20 *
jengbrecht 45:40745c2036cf 21 * @param TXD the transmit data pin on the desired mbed Serial interface.
jengbrecht 45:40745c2036cf 22 * @param RXD the receive data pin on the desired mbed Serial interface.
jengbrecht 36:bb6b293c7495 23 * @param txBufferSize the size in bytes of the internal SW transmit buffer. The
jengbrecht 36:bb6b293c7495 24 * default is 64 bytes.
jengbrecht 36:bb6b293c7495 25 * @param rxBufferSize the size in bytes of the internal SW receive buffer. The
jengbrecht 36:bb6b293c7495 26 * default is 64 bytes.
jengbrecht 45:40745c2036cf 27 * @param name an optional name for the serial port. The default is "".
jengbrecht 36:bb6b293c7495 28 */
mfiore 10:2bd727a4b329 29 MTSSerial(PinName TXD, PinName RXD, int txBufferSize = 64, int rxBufferSize = 64, char* name = "");
jengbrecht 36:bb6b293c7495 30
jengbrecht 36:bb6b293c7495 31 /** Destructs an MTSSerial object and frees all related resources, including
jengbrecht 36:bb6b293c7495 32 * internal buffers.
jengbrecht 36:bb6b293c7495 33 */
jengbrecht 0:563b70517320 34 ~MTSSerial();
jengbrecht 45:40745c2036cf 35
jengbrecht 36:bb6b293c7495 36 /** This method is used to the set the baud rate of the serial port.
jengbrecht 45:40745c2036cf 37 *
jengbrecht 45:40745c2036cf 38 * @param baudrate the baudrate in bps as an int. The default is 9600 bps.
jengbrecht 36:bb6b293c7495 39 */
jengbrecht 0:563b70517320 40 void baud(int baudrate);
jengbrecht 0:563b70517320 41
jengbrecht 45:40745c2036cf 42 /** This method sets the transmission format used by the serial port.
jengbrecht 45:40745c2036cf 43 *
jengbrecht 45:40745c2036cf 44 * @param bits the number of bits in a word (5-8; default = 8)
jengbrecht 45:40745c2036cf 45 * @param parity the parity used (SerialBase::None, SerialBase::Odd, SerialBase::Even,
jengbrecht 45:40745c2036cf 46 * SerialBase::Forced1, SerialBase::Forced0; default = SerialBase::None)
jengbrecht 45:40745c2036cf 47 * @param stop the number of stop bits (1 or 2; default = 1)
jengbrecht 36:bb6b293c7495 48 */
mfiore 51:d22d3d87391f 49 void format(int bits=8, SerialBase::Parity parity=mbed::SerialBase::None, int stop_bits=1);
jengbrecht 0:563b70517320 50
jengbrecht 83:9813f9b8ee68 51 protected:
jengbrecht 83:9813f9b8ee68 52 Serial* serial; // Internal mbed Serial object
jengbrecht 83:9813f9b8ee68 53
jengbrecht 0:563b70517320 54 private:
jengbrecht 0:563b70517320 55 int writeSize; // Amount of data to write based on buffer size
mfiore 10:2bd727a4b329 56 char* if_name; // Name of the interface
jengbrecht 45:40745c2036cf 57
jengbrecht 45:40745c2036cf 58 virtual void handleWrite(); // Method for handling data to be written
jengbrecht 45:40745c2036cf 59 virtual void handleRead(); // Method for handling data to be read
jengbrecht 0:563b70517320 60 };
jengbrecht 0:563b70517320 61
mfiore 39:6e94520a3217 62 }
mfiore 39:6e94520a3217 63
jengbrecht 0:563b70517320 64 #endif /* MTSSERIAL_H */