Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
28816ec3f0758597a5e5608faf44b41471dbb8cd
[simgrid.git] / src / gras / Msg / msg_interface.h
1 /* $Id$ */
2
3 /* messaging - high level communication (send/receive messages)             */
4
5 /* module's public interface exported within GRAS, but not to end user.     */
6
7 /* Copyright (c) 2003, 2004 Martin Quinson. All rights reserved.            */
8
9 /* This program is free software; you can redistribute it and/or modify it
10  * under the terms of the license (GNU LGPL) which comes with this package. */
11
12 #ifndef GRAS_MSG_INTERFACE_H
13 #define GRAS_MSG_INTERFACE_H
14
15 #include "gras/transport.h"
16
17 /*
18  * Data of this module specific to each process 
19  * (used by sg_process.c to check some usual errors at the end of the simulation)
20  * FIXME: it could be cleaned up ?
21  */
22 typedef struct {
23   /*queue of msgs storing the ones got while msg_wait'ing for something else */
24   xbt_dynar_t msg_queue; /* elm type: gras_msg_t */
25
26   /* registered callbacks for each message */
27   xbt_dynar_t cbl_list; /* elm type: gras_cblist_t */
28
29 } s_gras_msg_procdata_t,*gras_msg_procdata_t;
30
31
32 xbt_error_t gras_msg_send_namev(gras_socket_t  sock, 
33                                  const char    *namev, 
34                                  void          *payload);
35
36 #define GRAS_PROTOCOL_VERSION '\0';
37
38
39 #endif  /* GRAS_MSG_INTERFACE_H */