First step: AutoIP compiled in and working

Dependencies:   mbed

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

        

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 #include "net.h"
darran 0:55a05330f8cc 25
darran 0:55a05330f8cc 26 //#define __DEBUG
darran 0:55a05330f8cc 27 #include "dbg/dbg.h"
darran 0:55a05330f8cc 28
darran 0:55a05330f8cc 29 Net::Net() : m_defaultIf(NULL), m_lpIf(), m_lpNetTcpSocket(), m_lpNetUdpSocket()
darran 0:55a05330f8cc 30 {
darran 0:55a05330f8cc 31
darran 0:55a05330f8cc 32 }
darran 0:55a05330f8cc 33
darran 0:55a05330f8cc 34 Net::~Net()
darran 0:55a05330f8cc 35 {
darran 0:55a05330f8cc 36
darran 0:55a05330f8cc 37 }
darran 0:55a05330f8cc 38
darran 0:55a05330f8cc 39
darran 0:55a05330f8cc 40 void Net::poll()
darran 0:55a05330f8cc 41 {
darran 0:55a05330f8cc 42
darran 0:55a05330f8cc 43 //Poll Services
darran 0:55a05330f8cc 44 NetService::servicesPoll();
darran 0:55a05330f8cc 45
darran 0:55a05330f8cc 46 //Poll Interfaces
darran 0:55a05330f8cc 47 list<NetIf*>::iterator pIfIt;
darran 0:55a05330f8cc 48
darran 0:55a05330f8cc 49 for ( pIfIt = net().m_lpIf.begin() ; pIfIt != net().m_lpIf.end(); pIfIt++ )
darran 0:55a05330f8cc 50 {
darran 0:55a05330f8cc 51 (*pIfIt)->poll();
darran 0:55a05330f8cc 52 }
darran 0:55a05330f8cc 53
darran 0:55a05330f8cc 54 //Poll Tcp Sockets
darran 0:55a05330f8cc 55 list<NetTcpSocket*>::iterator pNetTcpSocketIt;
darran 0:55a05330f8cc 56
darran 0:55a05330f8cc 57 for ( pNetTcpSocketIt = net().m_lpNetTcpSocket.begin() ; pNetTcpSocketIt != net().m_lpNetTcpSocket.end(); )
darran 0:55a05330f8cc 58 {
darran 0:55a05330f8cc 59 (*pNetTcpSocketIt)->poll();
darran 0:55a05330f8cc 60
darran 0:55a05330f8cc 61 if( (*pNetTcpSocketIt)->m_closed && !((*pNetTcpSocketIt)->m_refs) )
darran 0:55a05330f8cc 62 {
darran 0:55a05330f8cc 63 (*pNetTcpSocketIt)->m_removed = true;
darran 0:55a05330f8cc 64 delete (*pNetTcpSocketIt);
darran 0:55a05330f8cc 65 (*pNetTcpSocketIt) = NULL;
darran 0:55a05330f8cc 66 pNetTcpSocketIt = net().m_lpNetTcpSocket.erase(pNetTcpSocketIt);
darran 0:55a05330f8cc 67 }
darran 0:55a05330f8cc 68 else
darran 0:55a05330f8cc 69 {
darran 0:55a05330f8cc 70 pNetTcpSocketIt++;
darran 0:55a05330f8cc 71 }
darran 0:55a05330f8cc 72 }
darran 0:55a05330f8cc 73
darran 0:55a05330f8cc 74 //Poll Udp Sockets
darran 0:55a05330f8cc 75 list<NetUdpSocket*>::iterator pNetUdpSocketIt;
darran 0:55a05330f8cc 76
darran 0:55a05330f8cc 77 for ( pNetUdpSocketIt = net().m_lpNetUdpSocket.begin() ; pNetUdpSocketIt != net().m_lpNetUdpSocket.end(); )
darran 0:55a05330f8cc 78 {
darran 0:55a05330f8cc 79 (*pNetUdpSocketIt)->poll();
darran 0:55a05330f8cc 80
darran 0:55a05330f8cc 81 if( (*pNetUdpSocketIt)->m_closed && !((*pNetUdpSocketIt)->m_refs) )
darran 0:55a05330f8cc 82 {
darran 0:55a05330f8cc 83 (*pNetUdpSocketIt)->m_removed = true;
darran 0:55a05330f8cc 84 delete (*pNetUdpSocketIt);
darran 0:55a05330f8cc 85 (*pNetUdpSocketIt) = NULL;
darran 0:55a05330f8cc 86 pNetUdpSocketIt = net().m_lpNetUdpSocket.erase(pNetUdpSocketIt);
darran 0:55a05330f8cc 87 }
darran 0:55a05330f8cc 88 else
darran 0:55a05330f8cc 89 {
darran 0:55a05330f8cc 90 pNetUdpSocketIt++;
darran 0:55a05330f8cc 91 }
darran 0:55a05330f8cc 92 }
darran 0:55a05330f8cc 93
darran 0:55a05330f8cc 94
darran 0:55a05330f8cc 95 }
darran 0:55a05330f8cc 96
darran 0:55a05330f8cc 97 NetTcpSocket* Net::tcpSocket(NetIf& netif) {
darran 0:55a05330f8cc 98 NetTcpSocket* pNetTcpSocket = netif.tcpSocket();
darran 0:55a05330f8cc 99 pNetTcpSocket->m_refs++;
darran 0:55a05330f8cc 100 return pNetTcpSocket;
darran 0:55a05330f8cc 101 }
darran 0:55a05330f8cc 102
darran 0:55a05330f8cc 103 NetTcpSocket* Net::tcpSocket() { //NetTcpSocket on default if
darran 0:55a05330f8cc 104 if ( net().m_defaultIf == NULL )
darran 0:55a05330f8cc 105 return NULL;
darran 0:55a05330f8cc 106 NetTcpSocket* pNetTcpSocket = net().m_defaultIf->tcpSocket();
darran 0:55a05330f8cc 107 pNetTcpSocket->m_refs++;
darran 0:55a05330f8cc 108 return pNetTcpSocket;
darran 0:55a05330f8cc 109 }
darran 0:55a05330f8cc 110
darran 0:55a05330f8cc 111 void Net::releaseTcpSocket(NetTcpSocket* pNetTcpSocket)
darran 0:55a05330f8cc 112 {
darran 0:55a05330f8cc 113 pNetTcpSocket->m_refs--;
darran 0:55a05330f8cc 114 if(!pNetTcpSocket->m_closed && !pNetTcpSocket->m_refs)
darran 0:55a05330f8cc 115 pNetTcpSocket->close();
darran 0:55a05330f8cc 116 }
darran 0:55a05330f8cc 117
darran 0:55a05330f8cc 118 NetUdpSocket* Net::udpSocket(NetIf& netif) {
darran 0:55a05330f8cc 119 NetUdpSocket* pNetUdpSocket = netif.udpSocket();
darran 0:55a05330f8cc 120 pNetUdpSocket->m_refs++;
darran 0:55a05330f8cc 121 return pNetUdpSocket;
darran 0:55a05330f8cc 122 }
darran 0:55a05330f8cc 123
darran 0:55a05330f8cc 124 NetUdpSocket* Net::udpSocket() { //NetTcpSocket on default if
darran 0:55a05330f8cc 125 if ( net().m_defaultIf == NULL )
darran 0:55a05330f8cc 126 return NULL;
darran 0:55a05330f8cc 127 NetUdpSocket* pNetUdpSocket = net().m_defaultIf->udpSocket();
darran 0:55a05330f8cc 128 pNetUdpSocket->m_refs++;
darran 0:55a05330f8cc 129 return pNetUdpSocket;
darran 0:55a05330f8cc 130 }
darran 0:55a05330f8cc 131
darran 0:55a05330f8cc 132 void Net::releaseUdpSocket(NetUdpSocket* pNetUdpSocket)
darran 0:55a05330f8cc 133 {
darran 0:55a05330f8cc 134 pNetUdpSocket->m_refs--;
darran 0:55a05330f8cc 135 if(!pNetUdpSocket->m_closed && !pNetUdpSocket->m_refs)
darran 0:55a05330f8cc 136 pNetUdpSocket->close();
darran 0:55a05330f8cc 137 }
darran 0:55a05330f8cc 138
darran 0:55a05330f8cc 139 NetDnsRequest* Net::dnsRequest(const char* hostname, NetIf& netif) {
darran 0:55a05330f8cc 140 return netif.dnsRequest(hostname);
darran 0:55a05330f8cc 141 }
darran 0:55a05330f8cc 142
darran 0:55a05330f8cc 143 NetDnsRequest* Net::dnsRequest(const char* hostname) { //Create a new NetDnsRequest object from default if
darran 0:55a05330f8cc 144 if ( net().m_defaultIf == NULL )
darran 0:55a05330f8cc 145 return NULL;
darran 0:55a05330f8cc 146 return net().m_defaultIf->dnsRequest(hostname);
darran 0:55a05330f8cc 147 }
darran 0:55a05330f8cc 148
darran 0:55a05330f8cc 149 NetDnsRequest* Net::dnsRequest(Host* pHost, NetIf& netif)
darran 0:55a05330f8cc 150 {
darran 0:55a05330f8cc 151 return netif.dnsRequest(pHost);
darran 0:55a05330f8cc 152 }
darran 0:55a05330f8cc 153
darran 0:55a05330f8cc 154 NetDnsRequest* Net::dnsRequest(Host* pHost) //Creats a new NetDnsRequest object from default if
darran 0:55a05330f8cc 155 {
darran 0:55a05330f8cc 156 if ( net().m_defaultIf == NULL )
darran 0:55a05330f8cc 157 return NULL;
darran 0:55a05330f8cc 158 return net().m_defaultIf->dnsRequest(pHost);
darran 0:55a05330f8cc 159 }
darran 0:55a05330f8cc 160
darran 0:55a05330f8cc 161 void Net::setDefaultIf(NetIf& netif) {
darran 0:55a05330f8cc 162 net().m_defaultIf = &netif;
darran 0:55a05330f8cc 163 }
darran 0:55a05330f8cc 164
darran 0:55a05330f8cc 165 void Net::setDefaultIf(NetIf* pIf)
darran 0:55a05330f8cc 166 {
darran 0:55a05330f8cc 167 net().m_defaultIf = pIf;
darran 0:55a05330f8cc 168 }
darran 0:55a05330f8cc 169
darran 0:55a05330f8cc 170 NetIf* Net::getDefaultIf() {
darran 0:55a05330f8cc 171 return net().m_defaultIf;
darran 0:55a05330f8cc 172 }
darran 0:55a05330f8cc 173
darran 0:55a05330f8cc 174 void Net::registerIf(NetIf* pIf)
darran 0:55a05330f8cc 175 {
darran 0:55a05330f8cc 176 net().m_lpIf.push_back(pIf);
darran 0:55a05330f8cc 177 }
darran 0:55a05330f8cc 178
darran 0:55a05330f8cc 179 void Net::unregisterIf(NetIf* pIf)
darran 0:55a05330f8cc 180 {
darran 0:55a05330f8cc 181 if( net().m_defaultIf == pIf )
darran 0:55a05330f8cc 182 net().m_defaultIf = NULL;
darran 0:55a05330f8cc 183 net().m_lpIf.remove(pIf);
darran 0:55a05330f8cc 184 }
darran 0:55a05330f8cc 185
darran 0:55a05330f8cc 186 void Net::registerNetTcpSocket(NetTcpSocket* pNetTcpSocket)
darran 0:55a05330f8cc 187 {
darran 0:55a05330f8cc 188 net().m_lpNetTcpSocket.push_back(pNetTcpSocket);
darran 0:55a05330f8cc 189 DBG("\r\nNetTcpSocket [ + %p ] %d\r\n", (void*)pNetTcpSocket, net().m_lpNetTcpSocket.size());
darran 0:55a05330f8cc 190 }
darran 0:55a05330f8cc 191
darran 0:55a05330f8cc 192 void Net::unregisterNetTcpSocket(NetTcpSocket* pNetTcpSocket)
darran 0:55a05330f8cc 193 {
darran 0:55a05330f8cc 194 DBG("\r\nNetTcpSocket [ - %p ] %d\r\n", (void*)pNetTcpSocket, net().m_lpNetTcpSocket.size() - 1);
darran 0:55a05330f8cc 195 if(!pNetTcpSocket->m_removed)
darran 0:55a05330f8cc 196 net().m_lpNetTcpSocket.remove(pNetTcpSocket);
darran 0:55a05330f8cc 197 }
darran 0:55a05330f8cc 198
darran 0:55a05330f8cc 199 void Net::registerNetUdpSocket(NetUdpSocket* pNetUdpSocket)
darran 0:55a05330f8cc 200 {
darran 0:55a05330f8cc 201 net().m_lpNetUdpSocket.push_back(pNetUdpSocket);
darran 0:55a05330f8cc 202 DBG("\r\nNetUdpSocket [ + %p ] %d\r\n", (void*)pNetUdpSocket, net().m_lpNetUdpSocket.size());
darran 0:55a05330f8cc 203 }
darran 0:55a05330f8cc 204
darran 0:55a05330f8cc 205 void Net::unregisterNetUdpSocket(NetUdpSocket* pNetUdpSocket)
darran 0:55a05330f8cc 206 {
darran 0:55a05330f8cc 207 DBG("\r\nNetUdpSocket [ - %p ] %d\r\n", (void*)pNetUdpSocket, net().m_lpNetUdpSocket.size() - 1);
darran 0:55a05330f8cc 208 if(!pNetUdpSocket->m_removed)
darran 0:55a05330f8cc 209 net().m_lpNetUdpSocket.remove(pNetUdpSocket);
darran 0:55a05330f8cc 210 }
darran 0:55a05330f8cc 211
darran 0:55a05330f8cc 212 Net& Net::net()
darran 0:55a05330f8cc 213 {
darran 0:55a05330f8cc 214 static Net* pInst = new Net(); //Called only once
darran 0:55a05330f8cc 215 return *pInst;
darran 0:55a05330f8cc 216 }