First step: AutoIP compiled in and working

Dependencies:   mbed

Committer:
darran
Date:
Fri Jun 18 09:11:35 2010 +0000
Revision:
0:55a05330f8cc

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
darran 0:55a05330f8cc 1
darran 0:55a05330f8cc 2 /*
darran 0:55a05330f8cc 3 Copyright (c) 2010 Donatien Garnier (donatiengar [at] gmail [dot] com)
darran 0:55a05330f8cc 4
darran 0:55a05330f8cc 5 Permission is hereby granted, free of charge, to any person obtaining a copy
darran 0:55a05330f8cc 6 of this software and associated documentation files (the "Software"), to deal
darran 0:55a05330f8cc 7 in the Software without restriction, including without limitation the rights
darran 0:55a05330f8cc 8 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
darran 0:55a05330f8cc 9 copies of the Software, and to permit persons to whom the Software is
darran 0:55a05330f8cc 10 furnished to do so, subject to the following conditions:
darran 0:55a05330f8cc 11
darran 0:55a05330f8cc 12 The above copyright notice and this permission notice shall be included in
darran 0:55a05330f8cc 13 all copies or substantial portions of the Software.
darran 0:55a05330f8cc 14
darran 0:55a05330f8cc 15 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
darran 0:55a05330f8cc 16 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
darran 0:55a05330f8cc 17 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
darran 0:55a05330f8cc 18 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
darran 0:55a05330f8cc 19 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
darran 0:55a05330f8cc 20 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
darran 0:55a05330f8cc 21 THE SOFTWARE.
darran 0:55a05330f8cc 22 */
darran 0:55a05330f8cc 23
darran 0:55a05330f8cc 24 #ifndef NETUDPSOCKET_H
darran 0:55a05330f8cc 25 #define NETUDPSOCKET_H
darran 0:55a05330f8cc 26
darran 0:55a05330f8cc 27 #include "net.h"
darran 0:55a05330f8cc 28 #include "host.h"
darran 0:55a05330f8cc 29
darran 0:55a05330f8cc 30 #include <queue>
darran 0:55a05330f8cc 31 using std::queue;
darran 0:55a05330f8cc 32
darran 0:55a05330f8cc 33 //Implements a Berkeley-like socket if
darran 0:55a05330f8cc 34 //Can be interfaced either to lwip or a Telit module
darran 0:55a05330f8cc 35
darran 0:55a05330f8cc 36 enum NetUdpSocketErr
darran 0:55a05330f8cc 37 {
darran 0:55a05330f8cc 38 __NETUDPSOCKET_MIN = -0xFFFF,
darran 0:55a05330f8cc 39 NETUDPSOCKET_SETUP, //NetUdpSocket not properly configured
darran 0:55a05330f8cc 40 NETUDPSOCKET_IF, //If has problems
darran 0:55a05330f8cc 41 NETUDPSOCKET_MEM, //Not enough mem
darran 0:55a05330f8cc 42 NETUDPSOCKET_INUSE, //If/Port is in use
darran 0:55a05330f8cc 43 //...
darran 0:55a05330f8cc 44 NETUDPSOCKET_OK = 0
darran 0:55a05330f8cc 45 };
darran 0:55a05330f8cc 46
darran 0:55a05330f8cc 47 enum NetUdpSocketEvent //Only one lonely event here... but who knows, maybe some day there'll be another one!
darran 0:55a05330f8cc 48 {
darran 0:55a05330f8cc 49 NETUDPSOCKET_READABLE, //Data in buf
darran 0:55a05330f8cc 50 };
darran 0:55a05330f8cc 51
darran 0:55a05330f8cc 52
darran 0:55a05330f8cc 53 class NetUdpSocket
darran 0:55a05330f8cc 54 {
darran 0:55a05330f8cc 55 public:
darran 0:55a05330f8cc 56 NetUdpSocket();
darran 0:55a05330f8cc 57 virtual ~NetUdpSocket(); //close()
darran 0:55a05330f8cc 58
darran 0:55a05330f8cc 59 virtual NetUdpSocketErr bind(const Host& me) = 0;
darran 0:55a05330f8cc 60
darran 0:55a05330f8cc 61 virtual int /*if < 0 : NetUdpSocketErr*/ sendto(const char* buf, int len, Host* pHost) = 0;
darran 0:55a05330f8cc 62 virtual int /*if < 0 : NetUdpSocketErr*/ recvfrom(char* buf, int len, Host* pHost) = 0;
darran 0:55a05330f8cc 63
darran 0:55a05330f8cc 64 /* TODO NTH : printf / scanf helpers that call send/recv */
darran 0:55a05330f8cc 65
darran 0:55a05330f8cc 66 virtual NetUdpSocketErr close() = 0;
darran 0:55a05330f8cc 67
darran 0:55a05330f8cc 68 virtual NetUdpSocketErr poll() = 0;
darran 0:55a05330f8cc 69
darran 0:55a05330f8cc 70 class CDummy;
darran 0:55a05330f8cc 71 //Callbacks
darran 0:55a05330f8cc 72 template<class T>
darran 0:55a05330f8cc 73 //Linker bug : Must be defined here :(
darran 0:55a05330f8cc 74 void setOnEvent( T* pItem, void (T::*pMethod)(NetUdpSocketEvent) )
darran 0:55a05330f8cc 75 {
darran 0:55a05330f8cc 76 m_pCbItem = (CDummy*) pItem;
darran 0:55a05330f8cc 77 m_pCbMeth = (void (CDummy::*)(NetUdpSocketEvent)) pMethod;
darran 0:55a05330f8cc 78 }
darran 0:55a05330f8cc 79
darran 0:55a05330f8cc 80 void resetOnEvent(); //Disable callback
darran 0:55a05330f8cc 81
darran 0:55a05330f8cc 82 protected:
darran 0:55a05330f8cc 83 void queueEvent(NetUdpSocketEvent e);
darran 0:55a05330f8cc 84 void discardEvents();
darran 0:55a05330f8cc 85 void flushEvents(); //to be called during polling
darran 0:55a05330f8cc 86
darran 0:55a05330f8cc 87 Host m_host;
darran 0:55a05330f8cc 88 Host m_client;
darran 0:55a05330f8cc 89
darran 0:55a05330f8cc 90 friend class Net;
darran 0:55a05330f8cc 91 int m_refs;
darran 0:55a05330f8cc 92
darran 0:55a05330f8cc 93 bool m_closed;
darran 0:55a05330f8cc 94 bool m_removed;
darran 0:55a05330f8cc 95
darran 0:55a05330f8cc 96 private:
darran 0:55a05330f8cc 97 //We do not want to execute user code in interrupt routines, so we queue events until the server is polled
darran 0:55a05330f8cc 98 //If we port this to a multithreaded OS, we could avoid this (however some functions here are not thread-safe, so beware ;) )
darran 0:55a05330f8cc 99 void onEvent(NetUdpSocketEvent e); //To be called on poll
darran 0:55a05330f8cc 100 CDummy* m_pCbItem;
darran 0:55a05330f8cc 101 void (CDummy::*m_pCbMeth)(NetUdpSocketEvent);
darran 0:55a05330f8cc 102 queue<NetUdpSocketEvent> m_events;
darran 0:55a05330f8cc 103
darran 0:55a05330f8cc 104 };
darran 0:55a05330f8cc 105
darran 0:55a05330f8cc 106 #endif