X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/f787351e3355ab558d4f491bc52bef2012eaa3e8..5178c3d78c741bc724a439f407d441300355c40d:/src/gras/Transport/transport_private.h diff --git a/src/gras/Transport/transport_private.h b/src/gras/Transport/transport_private.h index 9cc653d3af..65284420e9 100644 --- a/src/gras/Transport/transport_private.h +++ b/src/gras/Transport/transport_private.h @@ -27,17 +27,21 @@ extern int gras_trp_libdata_id; /* our libdata identifier */ -/* The function that select returned the last time we asked. We need this because the TCP read - are greedy and try to get as much data in their buffer as possible (to avoid subsequent syscalls). +/* The function that select returned the last time we asked. We need this + because the TCP read are greedy and try to get as much data in their + buffer as possible (to avoid subsequent syscalls). (measurement sockets are not buffered and thus not concerned). - So, we can get more than one message in one shoot. And when this happens, we have to handle - the same socket again afterward without select()ing at all. + So, we can get more than one message in one shoot. And when this happens, + we have to handle the same socket again afterward without select()ing at + all. - Then, this data is not a static of the TCP driver because we want to zero it when - it gets closed by the user. If not, we use an already freed pointer, which is bad. + Then, this data is not a static of the TCP driver because we want to + zero it when it gets closed by the user. If not, we use an already freed + pointer, which is bad. - It gets tricky since gras_socket_close is part of the common API, not only the RL one. */ + It gets tricky since gras_socket_close is part of the common API, not + only the RL one. */ extern gras_socket_t _gras_lastly_selected_socket; /** @@ -56,12 +60,17 @@ typedef struct s_gras_socket { int meas :1; /* true if this is an experiment socket instead of messaging */ int recv_ok :1; /* true if it is valid to recv() on the socket (false if it is a file) */ int valid :1; /* false if a select returned that the peer quitted, forcing us to "close" the socket */ - int moredata :1; /* TCP socket use a buffer and read operation get as much data as possible. - It is possible that several messages are received in one shoot, and select won't catch them afterward again. - This boolean indicates that this is the case, so that we don't call select in that case. - Note that measurement sockets are not concerned since they use the TCP interface directly, with no buffer. */ - - unsigned long int buf_size; /* what to say to the OS. field here to remember it when accepting */ + int moredata :1; /* TCP socket use a buffer and read operation get as much + data as possible. It is possible that several messages + are received in one shoot, and select won't catch them + afterward again. + This boolean indicates that this is the case, so that we + don't call select in that case. Note that measurement + sockets are not concerned since they use the TCP + interface directly, with no buffer. */ + + unsigned long int buf_size; /* what to say to the OS. + Field here to remember it when accepting */ int sd; int port; /* port on this side */ @@ -75,18 +84,18 @@ typedef struct s_gras_socket { gras_trp_bufdata_t *bufdata; }s_gras_socket_t; -XBT_PUBLIC void gras_trp_socket_new(int incomming, +void gras_trp_socket_new(int incomming, gras_socket_t *dst); /* The drivers */ typedef void (*gras_trp_setup_t)(gras_trp_plugin_t dst); -XBT_PUBLIC void gras_trp_tcp_setup(gras_trp_plugin_t plug); -XBT_PUBLIC void gras_trp_iov_setup(gras_trp_plugin_t plug); -XBT_PUBLIC void gras_trp_file_setup(gras_trp_plugin_t plug); -XBT_PUBLIC void gras_trp_sg_setup(gras_trp_plugin_t plug); +void gras_trp_tcp_setup(gras_trp_plugin_t plug); +void gras_trp_iov_setup(gras_trp_plugin_t plug); +void gras_trp_file_setup(gras_trp_plugin_t plug); +void gras_trp_sg_setup(gras_trp_plugin_t plug); -/* +/* FIXME: this should be solved by SIMIX I'm tired of that shit. the select in SG has to create a socket to expeditor manually do deal with the weirdness of the hostdata, themselves here to deal @@ -104,6 +113,6 @@ XBT_PUBLIC void gras_trp_sg_setup(gras_trp_plugin_t plug); */ -XBT_PUBLIC gras_socket_t gras_trp_buf_init_sock(gras_socket_t sock); +gras_socket_t gras_trp_buf_init_sock(gras_socket_t sock); #endif /* GRAS_TRP_PRIVATE_H */