#ifndef _rA_EVDP_H_ #define _rA_EVDP_H_ #include "../common/cbasetypes.h" typedef struct EVDP_DATA EVDP_DATA; //#idef EVDP_EPOLL #include <sys/epoll.h> struct EVDP_DATA{ struct epoll_event ev_data; bool ev_added; }; //#endif enum EVDP_EVENTFLAGS{ EVDP_EVENT_IN = 1, // Incomming data EVDP_EVENT_OUT = 2, // Connection accepts writing. EVDP_EVENT_HUP = 4 // Connection Closed. }; typedef struct EVDP_EVENT{ int32 events; // due to performance reasons, this should be the first member. int32 fd; // Connection Identifier } EVDP_EVENT; /** * Network Event Dispatcher Initialization / Finalization routines */ void evdp_init(); void evdp_final(); /** * Will Wait for events. * * @param *out_ev pointer to array in size at least of max_events. * @param max_events max no of events to report with this call (coalesc) * @param timeout_ticks max time to wait in ticks (milliseconds) * * @Note: * The function will block until an event has occured on one of the monitored connections * or the timeout of timeout_ticks has passed by. * Upon successfull call (changed connections) this function will write the connection * Identifier & event to the out_fds array. * * @return 0 -> Timeout, > 0 no of changed connections. */ int32 evdp_wait(EVDP_EVENT *out_fds, int32 max_events, int32 timeout_ticks); /** * Applys the given mask on the given connection. * * @param fd connection identifier * @param *ep event data pointer for the connection * @param mask new event mask we're monitoring for. */ //void evdp_apply(int32 fd, EVDP_DATA *ep, int32 mask); /** * Adds a connection (listner) to the event notification system. * * @param fd connection identifier * @param *ep event data pointer for the connection * * @note: * Listener type sockets are edge triggered, (see epoll manual for more information) * - This basicaly means that youll receive one event, adn you have to accept until accept returns an error (nothing to accept) * * MONITORS by default: IN * * @return success indicator. */ bool evdp_addlistener(int32 fd, EVDP_DATA *ep); /** * Adds a connection (client connectioN) to the event notification system * * @param fd connection identifier * @param *ep event data pointr for the connection * * @note: * * MONITORS by default: IN, HUP * * @return success indicator. */ bool evdp_addclient(int32 fd, EVDP_DATA *ep); /** * Adds a connection (pending / outgoing connection!) to the event notification system. * * @param fd connection identifier * @param *ep event data pointer for the conneciton. * * @note: * Outgoing connection type sockets are getting monitored for connection established * successfull * - if the connection has been established - we're generitng a writable notification .. (send) * this is typical for BSD / posix conform network stacks. * - Additinionally its edge triggered. * * @see evdp_outgoingconnection_established * * * @return success indicator */ bool evdp_addconnecting(int32 fd, EVDP_DATA *ep); /** * Adds an outgoing connection to the normal event notification system after it has been successfully established. * * @param fd connection identifier * @param *ep event data pointer for the conneciton. * @note * after this call, its handled like a normal "client" connection (incomming) * * @rturn success indicator */ bool evdp_outgoingconnection_established(int32 fd, EVDP_DATA *ep); /** * Marks a connection to be monitored for writable. * * @param fd connection identifier * @param *ep event data pointer for the connection * * @note: * the connection must be already added (as client or listener) * * * @return sucess indicator */ bool evdp_writable_add(int32 fd, EVDP_DATA *ep); /** * Removes the connection from writable notification monitoring * * @param fd connection identifier * @param *ep event data pointr for the connection * */ void evdp_writable_remove(int32 fd, EVDP_DATA *ep); /** * Removes an connectio from the event notification system. * * @param fd connection iditentfir * @param *ep event data pointer for th connection * * * @note: * this will also clear the given EVENT_DATA block * so the connection slot is in an "initial" blank status / ready to get reused. * */ void evdp_remove(int32 fd, EVDP_DATA *ep); #endif