.
Fork of WIZnet_Library by
Diff: WIZnetInterface/Socket/TCPSocketServer.cpp
- Revision:
- 3:48348a6eaa72
- Parent:
- 0:b72d22e10709
- Child:
- 7:c1f1122adf7b
- Child:
- 8:7c67a8922ec5
diff -r c2eb7a08d7e6 -r 48348a6eaa72 WIZnetInterface/Socket/TCPSocketServer.cpp --- a/WIZnetInterface/Socket/TCPSocketServer.cpp Mon Jul 14 23:52:10 2014 +0000 +++ b/WIZnetInterface/Socket/TCPSocketServer.cpp Mon Jul 21 05:35:40 2014 +0000 @@ -1,75 +1,94 @@ -/* Copyright (C) 2012 mbed.org, MIT License - * - * Permission is hereby granted, free of charge, to any person obtaining a copy of this software - * and associated documentation files (the "Software"), to deal in the Software without restriction, - * including without limitation the rights to use, copy, modify, merge, publish, distribute, - * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is - * furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in all copies or - * substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING - * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND - * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, - * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, - * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ - -#include "TCPSocketServer.h" - -TCPSocketServer::TCPSocketServer() {} - -// Server initialization -int TCPSocketServer::bind(int port) { - if (_sock_fd < 0) { - _sock_fd = eth->new_socket(); - if (_sock_fd < 0) { - return -1; - } - } - // set TCP protocol - eth->setProtocol(_sock_fd, TCP); - // set local port - eth->sreg<uint16_t>(_sock_fd, Sn_PORT, port); - // connect the network - eth->scmd(_sock_fd, OPEN); - return 0; -} - -int TCPSocketServer::listen(int backlog) { - if (_sock_fd < 0) { - return -1; - } - if (backlog != 1) { - return -1; - } - eth->scmd(_sock_fd, LISTEN); - return 0; -} - - -int TCPSocketServer::accept(TCPSocketConnection& connection) { - if (_sock_fd < 0) { - return -1; - } - Timer t; - t.reset(); - t.start(); - while(1) { - if (t.read_ms() > _timeout && _blocking == false) { - return -1; - } - if (eth->sreg<uint8_t>(_sock_fd, Sn_SR) == SOCK_ESTABLISHED) { - break; - } - } - uint32_t ip = eth->sreg<uint32_t>(_sock_fd, Sn_DIPR); - char host[16]; - snprintf(host, sizeof(host), "%d.%d.%d.%d", (ip>>24)&0xff, (ip>>16)&0xff, (ip>>8)&0xff, ip&0xff); - uint16_t port = eth->sreg<uint16_t>(_sock_fd, Sn_DPORT); - connection._sock_fd = _sock_fd; - connection.set_address(host, port); - return 0; -} +/* Copyright (C) 2012 mbed.org, MIT License + * + * Permission is hereby granted, free of charge, to any person obtaining a copy of this software + * and associated documentation files (the "Software"), to deal in the Software without restriction, + * including without limitation the rights to use, copy, modify, merge, publish, distribute, + * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in all copies or + * substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING + * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, + * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + */ + +#include "TCPSocketServer.h" + +TCPSocketServer::TCPSocketServer() {} + +// Server initialization +int TCPSocketServer::bind(int port) +{ + + if (_sock_fd < 0) { + _sock_fd = eth->new_socket(); + if (_sock_fd < 0) { + return -1; + } + } + // set the listen_port for next connection. + listen_port = port; + // set TCP protocol + eth->setProtocol(_sock_fd, TCP); + // set local port + eth->sreg<uint16_t>(_sock_fd, Sn_PORT, port); + // connect the network + eth->scmd(_sock_fd, OPEN); + return 0; +} +int TCPSocketServer::listen(int backlog) +{ + if (_sock_fd < 0) { + return -1; + } + if (backlog != 1) { + return -1; + } + eth->scmd(_sock_fd, LISTEN); + return 0; +} + + +int TCPSocketServer::accept(TCPSocketConnection& connection) +{ + if (_sock_fd < 0) { + return -1; + } + Timer t; + t.reset(); + t.start(); + while(1) { + if (t.read_ms() > _timeout && _blocking == false) { + return -1; + } + if (eth->sreg<uint8_t>(_sock_fd, Sn_SR) == SOCK_ESTABLISHED) { + break; + } + } + uint32_t ip = eth->sreg<uint32_t>(_sock_fd, Sn_DIPR); + char host[16]; + snprintf(host, sizeof(host), "%d.%d.%d.%d", (ip>>24)&0xff, (ip>>16)&0xff, (ip>>8)&0xff, ip&0xff); + uint16_t port = eth->sreg<uint16_t>(_sock_fd, Sn_DPORT); + // change this server socket to connection socket. + connection._sock_fd = _sock_fd; + connection.set_address(host, port); + + // and then, for the next connection, server socket should be assigned new one. + _sock_fd = -1; // want to assign new available _sock_fd. + if(bind(listen_port) < 0) { + error("No more socket for listening"); + } else { + //return -1; + if(listen(1) < 0) { + error("No more socket for listening"); + } + } + + return 0; +} +