X-Git-Url: https://git.syn-net.org/debian/?p=anytun.git;a=blobdiff_plain;f=src%2FpacketSource.h;h=d5ee736c0a4a361ca86794c3f5c65a349392d21e;hp=626a25920de0c51b012deb53169c6687064fefc7;hb=ece844834d2cecc028ce81ca283f5d441088580e;hpb=bb834fe0ed7a38b724f49b944adb801634eb6194 diff --git a/src/packetSource.h b/src/packetSource.h index 626a259..d5ee736 100644 --- a/src/packetSource.h +++ b/src/packetSource.h @@ -34,12 +34,16 @@ #define ANYTUN_packetSource_h_INCLUDED #include +#include +#include +#include #include "datatypes.h" #include "threadUtils.hpp" // TODO: fix this when other packetSource types are introduced typedef boost::asio::ip::udp::endpoint PacketSourceEndpoint; +typedef boost::asio::ip::udp::resolver::iterator PacketSourceResolverIt; class PacketSource { @@ -61,17 +65,34 @@ public: typedef boost::asio::ip::udp proto; UDPPacketSource(std::string localaddr, std::string port); + ~UDPPacketSource(); u_int32_t recv(u_int8_t* buf, u_int32_t len, PacketSourceEndpoint& remote); void send(u_int8_t* buf, u_int32_t len, PacketSourceEndpoint remote); - void onResolve(const boost::asio::ip::udp::endpoint& e); + void onResolve(PacketSourceResolverIt& it); void onError(const std::runtime_error& e); private: - boost::asio::io_service io_service_; - proto::socket sock_; + + typedef struct { + u_int8_t* buf_; + u_int32_t len_; + proto::socket* sock_; + Semaphore* sem_; + } SocketsElement; + std::list sockets_; + + void recv_thread(std::list::iterator it); + typedef struct { + u_int32_t len_; + PacketSourceEndpoint remote_; + std::list::iterator it_; + } ThreadResult; + std::queue thread_result_queue_; + Mutex thread_result_mutex_; + Semaphore thread_result_sem_; }; #endif