Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
kill cruft
[simgrid.git] / src / gras / Msg / msg_interface.h
index f7605c6..7c726d9 100644 (file)
@@ -13,6 +13,7 @@
 #define GRAS_MSG_INTERFACE_H
 
 #include "gras/transport.h"
+#include "xbt/fifo.h"
 
 /*
  * Data of this module specific to each process 
@@ -25,19 +26,28 @@ typedef struct {
   char        *name;
   unsigned int name_len;
 
-  /*queue of msgs storing the ones got while msg_wait'ing for something else */
+  /* queue storing the msgs got while msg_wait'ing for something else. Reuse them ASAP. */
   xbt_dynar_t msg_queue; /* elm type: s_gras_msg_t */
 
+  /* queue storing the msgs without callback got when handling. Feed them to wait() */
+  xbt_dynar_t msg_waitqueue; /* elm type: s_gras_msg_t */
+
   /* registered callbacks for each message */
   xbt_dynar_t cbl_list; /* elm type: gras_cblist_t */
    
   /* registered timers */
   xbt_dynar_t timers; /* elm type: s_gras_timer_t */
+       
+       /* queue storing the msgs that have to received and the process synchronization made (wait the surf action done) */
+       xbt_fifo_t msg_to_receive_queue; /* elm type: s_gras_msg_t */
+       xbt_fifo_t msg_to_receive_queue_meas; /* elm type: s_gras_msg_t */
+       xbt_queue_t msg_received;
+
 
 } s_gras_msg_procdata_t,*gras_msg_procdata_t;
 
 
-XBT_PUBLIC void gras_msg_send_namev(gras_socket_t  sock, 
+void gras_msg_send_namev(gras_socket_t  sock, 
                         const char    *namev, 
                         void          *payload);