This library is stripped down version of NetServices library. HTTP server and client function is NOT supported.

Dependents:   imu-daq-eth

Committer:
idinor
Date:
Wed Jul 20 11:45:39 2011 +0000
Revision:
0:dcf3c92487ca

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
idinor 0:dcf3c92487ca 1
idinor 0:dcf3c92487ca 2 /*
idinor 0:dcf3c92487ca 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
idinor 0:dcf3c92487ca 4
idinor 0:dcf3c92487ca 5 Permission is hereby granted, free of charge, to any person obtaining a copy
idinor 0:dcf3c92487ca 6 of this software and associated documentation files (the "Software"), to deal
idinor 0:dcf3c92487ca 7 in the Software without restriction, including without limitation the rights
idinor 0:dcf3c92487ca 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
idinor 0:dcf3c92487ca 9 copies of the Software, and to permit persons to whom the Software is
idinor 0:dcf3c92487ca 10 furnished to do so, subject to the following conditions:
idinor 0:dcf3c92487ca 11
idinor 0:dcf3c92487ca 12 The above copyright notice and this permission notice shall be included in
idinor 0:dcf3c92487ca 13 all copies or substantial portions of the Software.
idinor 0:dcf3c92487ca 14
idinor 0:dcf3c92487ca 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
idinor 0:dcf3c92487ca 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
idinor 0:dcf3c92487ca 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
idinor 0:dcf3c92487ca 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
idinor 0:dcf3c92487ca 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
idinor 0:dcf3c92487ca 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
idinor 0:dcf3c92487ca 21 THE SOFTWARE.
idinor 0:dcf3c92487ca 22 */
idinor 0:dcf3c92487ca 23
idinor 0:dcf3c92487ca 24 #ifndef SERIALBUF_H
idinor 0:dcf3c92487ca 25 #define SERIALBUF_H
idinor 0:dcf3c92487ca 26
idinor 0:dcf3c92487ca 27 #include "mbed.h"
idinor 0:dcf3c92487ca 28 #include "netCfg.h"
idinor 0:dcf3c92487ca 29 #if NET_USB_SERIAL
idinor 0:dcf3c92487ca 30 #include "drv/serial/usb/UsbSerial.h"
idinor 0:dcf3c92487ca 31 #endif
idinor 0:dcf3c92487ca 32
idinor 0:dcf3c92487ca 33 class SerialCircularBuf
idinor 0:dcf3c92487ca 34 {
idinor 0:dcf3c92487ca 35 public:
idinor 0:dcf3c92487ca 36 SerialCircularBuf(int len);
idinor 0:dcf3c92487ca 37 ~SerialCircularBuf();
idinor 0:dcf3c92487ca 38
idinor 0:dcf3c92487ca 39 int room();
idinor 0:dcf3c92487ca 40 int len();
idinor 0:dcf3c92487ca 41
idinor 0:dcf3c92487ca 42 void write(char c);
idinor 0:dcf3c92487ca 43 char read();
idinor 0:dcf3c92487ca 44
idinor 0:dcf3c92487ca 45 void setReadMode(bool readMode); //If true, keeps chars in buf when read, false by default
idinor 0:dcf3c92487ca 46 void flushRead(); //Delete chars that have been read & return chars len (only useful with readMode = true)
idinor 0:dcf3c92487ca 47 void resetRead(); //Go back to initial read position & return chars len (only useful with readMode = true)
idinor 0:dcf3c92487ca 48
idinor 0:dcf3c92487ca 49 private:
idinor 0:dcf3c92487ca 50 char* m_buf;
idinor 0:dcf3c92487ca 51 int m_len;
idinor 0:dcf3c92487ca 52
idinor 0:dcf3c92487ca 53 volatile char* m_pReadStart;
idinor 0:dcf3c92487ca 54 volatile char* m_pRead;
idinor 0:dcf3c92487ca 55 volatile char* m_pWrite;
idinor 0:dcf3c92487ca 56 volatile bool m_readMode;
idinor 0:dcf3c92487ca 57 };
idinor 0:dcf3c92487ca 58
idinor 0:dcf3c92487ca 59 class SerialBuf
idinor 0:dcf3c92487ca 60 {
idinor 0:dcf3c92487ca 61 public:
idinor 0:dcf3c92487ca 62 SerialBuf(int len); //Buffer length
idinor 0:dcf3c92487ca 63 virtual ~SerialBuf();
idinor 0:dcf3c92487ca 64
idinor 0:dcf3c92487ca 65 void attach(Serial* pSerial);
idinor 0:dcf3c92487ca 66 void detach();
idinor 0:dcf3c92487ca 67
idinor 0:dcf3c92487ca 68 #if NET_USB_SERIAL
idinor 0:dcf3c92487ca 69 void attach(UsbSerial* pUsbSerial);
idinor 0:dcf3c92487ca 70 #endif
idinor 0:dcf3c92487ca 71
idinor 0:dcf3c92487ca 72 //Really useful for debugging
idinor 0:dcf3c92487ca 73 char getc();
idinor 0:dcf3c92487ca 74 void putc(char c);
idinor 0:dcf3c92487ca 75 bool readable();
idinor 0:dcf3c92487ca 76 bool writeable();
idinor 0:dcf3c92487ca 77 /*protected:*/
idinor 0:dcf3c92487ca 78 void setReadMode(bool readMode); //If true, keeps chars in buf when read, false by default
idinor 0:dcf3c92487ca 79 void flushRead(); //Delete chars that have been read & return chars len (only useful with readMode = true)
idinor 0:dcf3c92487ca 80 void resetRead(); //Go back to initial read position & return chars len (only useful with readMode = true)
idinor 0:dcf3c92487ca 81
idinor 0:dcf3c92487ca 82 private:
idinor 0:dcf3c92487ca 83 void onRxInterrupt(); //Callback from m_pSerial
idinor 0:dcf3c92487ca 84 void onTxInterrupt(); //Callback from m_pSerial
idinor 0:dcf3c92487ca 85
idinor 0:dcf3c92487ca 86 SerialCircularBuf m_rxBuf;
idinor 0:dcf3c92487ca 87 SerialCircularBuf m_txBuf;
idinor 0:dcf3c92487ca 88
idinor 0:dcf3c92487ca 89 Serial* m_pSerial; //Not owned
idinor 0:dcf3c92487ca 90
idinor 0:dcf3c92487ca 91 #if NET_USB_SERIAL
idinor 0:dcf3c92487ca 92 //USB Serial Impl
idinor 0:dcf3c92487ca 93 UsbSerial* m_pUsbSerial; //Not owned
idinor 0:dcf3c92487ca 94 //Ticker m_usbTick;
idinor 0:dcf3c92487ca 95 #endif
idinor 0:dcf3c92487ca 96 };
idinor 0:dcf3c92487ca 97
idinor 0:dcf3c92487ca 98
idinor 0:dcf3c92487ca 99 #endif