Free (GPLv2) TCP/IP stack developed by TASS Belgium

Dependents:   lpc1768-picotcp-demo ZeroMQ_PicoTCP_Publisher_demo TCPSocket_HelloWorld_PicoTCP Pico_TCP_UDP_Test ... more

PicoTCP. Copyright (c) 2013 TASS Belgium NV.

Released under the GNU General Public License, version 2.

Different licensing models may exist, at the sole discretion of the Copyright holders.

Official homepage: http://www.picotcp.com

Bug tracker: https://github.com/tass-belgium/picotcp/issues

Development steps:

  • initial integration with mbed RTOS
  • generic mbed Ethernet driver
  • high performance NXP LPC1768 specific Ethernet driver
  • Multi-threading support for mbed RTOS
  • Berkeley sockets and integration with the New Socket API
  • Fork of the apps running on top of the New Socket API
  • Scheduling optimizations
  • Debugging/benchmarking/testing

Demo application (measuring TCP sender performance):

Import programlpc1768-picotcp-demo

A PicoTCP demo app testing the ethernet throughput on the lpc1768 mbed board.

Socket/Socket.h

Committer:
tass
Date:
2013-07-11
Revision:
39:8d4d653d94bd
Parent:
37:bdf736327c71
Child:
142:35da43068894

File content as of revision 39:8d4d653d94bd:

/* 
 *
 * PicoTCP Socket interface for mbed.
 * Copyright (C) 2013 TASS Belgium NV
 * 
 * Released under GPL v2
 *
 * Other licensing models might apply at the sole discretion of the copyright holders.
 *
 *
 * This software is based on the mbed.org EthernetInterface implementation:
 * 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.
 */

#ifndef SOCKET_H_
#define SOCKET_H_

#ifdef __cplusplus
extern "C" {
#endif
    #include "pico_dns_client.h"
#ifdef __cplusplus
}
#endif

#include "wrapper.h"
#include "proxy_endpoint.h"

class TimeInterval;

/** Socket file descriptor and select wrapper
  */
class Socket {
public:
    /** Socket
     */
    Socket();
    
    /** Set blocking or non-blocking mode of the socket and a timeout on
        blocking socket operations
    \param blocking  true for blocking mode, false for non-blocking mode.
    \param timeout   timeout in ms [Default: (1500)ms].
    */
    void set_blocking(bool blocking, unsigned int timeout=1500);
    
    /** Set socket options
    \param level     stack level - parameter is ignored (kept for compatibility)
    \param optname   option ID - please check pico_socket.h
    \param optval    option value
    \param socklen_t length of the option value
    \return 0 on success, -1 on failure
    */
    int set_option(int level, int optname, const void *optval, socklen_t optlen);
    
    /** Get socket options
        \param level     stack level - parameter is ignored (kept for compatibility)
        \param optname   option ID - please check pico_socket.h or lower in the page
        \param optval    buffer pointer where to write the option value
        \param socklen_t length of the option value
        \return 0 on success, -1 on failure
        */
    int get_option(int level, int optname, void *optval, socklen_t *optlen);
    
    /** Close the socket file descriptor
     */
    int close();
    
    ~Socket();
    
protected:
    struct stack_endpoint *_ep;
    int init_socket(int type);
    
    int wait_readable(TimeInterval& timeout);
    int wait_writable(TimeInterval& timeout);

    int is_readable(void);
    int is_writable(void);
    
    bool _blocking;
    unsigned int _timeout;
    
private:
    int select(struct timeval *timeout, bool read, bool write);
};

/** Time interval class used to specify timeouts
 */
class TimeInterval {
    friend class Socket;

public:
    /** Time Interval
     \param ms time interval expressed in milliseconds
      */
    TimeInterval(unsigned int ms);
    
private:
    struct timeval _time;
    struct stack_endpoint * _ep;
};

inline struct hostent *gethostbyname(const char *name) { return picotcp_gethostbyname(name); }
/* DNS 
inline int gethostbyname_r(const char *name, struct hostent *ret, char *buf, size_t buflen, struct hostent **result, int *h_errnop) {
  return picotcp_gethostbyname_r(name, ret, buf, buflen, result, h_errnop);
}*/
#endif /* SOCKET_H_ */