--- /dev/null
+/* $Id$ */
+
+/* Copyright (c) 2002,2003,2004 Arnaud Legrand. All rights reserved. */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
+
+#ifndef MSG_DATATYPE_H
+#define MSG_DATATYPE_H
+
+/********************************* Host **************************************/
+
+struct s_m_host {
+ char *name; /* host name if any */
+ void *simdata; /* simulator data */
+ void *data; /* user data */
+};
+/** \brief Host datatype
+ \ingroup m_datatypes_management
+
+ A <em>location</em> (or <em>host</em>) is any possible place where
+ a process may run. Thus it is represented as a <em>physical
+ resource with computing capabilities</em>, some <em>mailboxes</em>
+ to enable running process to communicate with remote ones, and
+ some <em>private data</em> that can be only accessed by local
+ process.
+
+ \see m_host_management
+*/
+typedef struct s_m_host *m_host_t;
+
+/********************************* Link **************************************/
+struct s_m_link {
+ char *name; /* link name if any */
+ void *simdata; /* simulator data */
+ void *data; /* user data */
+};
+
+/** \brief Link datatype
+ \ingroup m_datatypes_management
+
+ A <em>link</em> is an agglomeration of communicating resources
+ representing a set of physical network links.
+
+ \see m_link_management
+*/
+typedef struct s_m_link *m_link_t;
+
+/********************************* Task **************************************/
+
+struct s_m_task {
+ char *name; /* host name if any */
+ void *simdata; /* simulator data */
+ void *data; /* user data */
+};
+/** \brief Task datatype
+ \ingroup m_datatypes_management
+
+ A <em>task</em> may then be defined by a <em>computing
+ amount</em>, a <em>message size</em> and some <em>private
+ data</em>.
+ \see m_task_management
+*/
+typedef struct s_m_task *m_task_t;
+
+/** \brief Default value for an uninitialized #m_task_t.
+ \ingroup m_datatypes_management
+*/
+#define MSG_TASK_UNINITIALIZED NULL
+/******************************* Process *************************************/
+
+struct s_m_process {
+ char *name; /* process name if any */
+ void *simdata; /* simulator data */
+ void *data; /* user data */
+};
+/** \brief Agent datatype
+ \ingroup m_datatypes_management
+ An agent may be defined as a <em>code</em>, with some <em>private
+ data</em>, executing in a <em>location</em>.
+ \see m_process_management
+*/
+typedef struct s_m_process *m_process_t;
+/** \brief Agent code datatype
+ \ingroup m_datatypes_management
+ The code of an agent is a m_process_code_t, i.e. a function with no arguments
+ returning no value.
+ \see m_process_management
+*/
+typedef int(*m_process_code_t)(int argc,char *argv[]) ;
+
+/********************************** Channel **********************************/
+/** \brief Channel datatype
+ \ingroup m_datatypes_management
+ A <em>channel</em> is a number and identifies a mailbox type (just as a
+ port number does).
+ \see m_channel_management
+*/
+typedef int m_channel_t;
+
+/****************************** Error handling *******************************/
+/** \brief Error handling
+*/typedef enum {
+ MSG_OK = 0, /**< Everything is right. Keep on going this way ! */
+ MSG_WARNING, /**< Mmmh! Something must be not perfectly clean. But I
+ may be a paranoid freak... ! */
+ MSG_TRANSFER_FAILURE, /**< There has been a problem during you task
+ transfer. Either the network is down or the remote host has been
+ shutdown. */
+ MSG_HOST_FAILURE, /**< System shutdown. The host on which you are
+ running has just been rebooted. Free your datastructures and
+ return now !*/
+ MSG_FATAL /**< You've done something wrong. You'd better look at it... */
+} MSG_error_t;
+
+typedef enum {
+ MSG_SILENT = 0,
+ MSG_SOME,
+ MSG_VERBOSE
+} MSG_outputmode_t;
+
+typedef enum {
+ MSG_STORE_AND_FORWARD = 1, /* 0 means uninitialized value */
+ MSG_TCP
+} MSG_sharing_t;
+
+#endif
--- /dev/null
+/* $Id$ */
+
+/* Copyright (c) 2002,2003,2004 Arnaud Legrand. All rights reserved. */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
+
+#ifndef MSG_H
+#define MSG_H
+
+#include "msg/datatypes.h"
+
+/************************** MSG **********************************************/
+void MSG_global_init(void);
+void MSG_set_verbosity(MSG_outputmode_t mode);
+MSG_error_t MSG_set_channel_number(int number);
+MSG_error_t MSG_set_sharing_policy(MSG_sharing_t mode, long double param);
+int MSG_get_channel_number(void);
+MSG_error_t MSG_main(void);
+MSG_error_t MSG_clean(void);
+
+MSG_error_t MSG_routing_table_init(void);
+MSG_error_t MSG_routing_table_set(m_host_t host1, m_host_t host2,
+ m_link_t link);
+m_link_t MSG_routing_table_get(m_host_t host1, m_host_t host2);
+
+/************************** Management ***************************************/
+m_host_t MSG_host_create(const char *name,
+ char *trace_file,
+ long double fixed_cpu,
+ char* failure_trace,
+ long double fixed_failure,
+ void *data);
+
+MSG_error_t MSG_host_set_data(m_host_t host, void *data);
+void *MSG_host_get_data(m_host_t host);
+int MSG_host_get_PID(m_host_t host);
+int MSG_process_get_PPID(m_process_t process);
+const char *MSG_host_get_name(m_host_t host);
+m_host_t MSG_host_from_PID(int PID);
+m_host_t MSG_host_self(void);
+MSG_error_t MSG_host_destroy(m_host_t host);
+
+int MSG_get_host_msgload(m_host_t host);
+int MSG_get_msgload(void);
+
+
+void MSG_link_set_sharing_value(long double alpha);
+m_link_t MSG_link_create(const char *name,
+ char *lat_trace_file, long double fixed_latency,
+ char *bw_trace_file, long double fixed_bandwidth);
+MSG_error_t MSG_link_destroy(m_link_t link);
+m_link_t MSG_link_merge(const char *name, m_link_t src1, m_link_t src2);
+
+
+m_task_t MSG_task_create(const char *name, long double compute_duration,
+ long double message_size, void *data);
+void *MSG_task_get_data(m_task_t task);
+MSG_error_t MSG_task_destroy(m_task_t task);
+
+m_process_t MSG_process_create(const char *name,
+ m_process_code_t code, void *data,
+ m_host_t host);
+
+MSG_error_t MSG_process_change_host(m_process_t process, m_host_t host);
+
+void *MSG_process_get_data(m_process_t process);
+MSG_error_t MSG_process_set_data(m_process_t process, void *data);
+m_host_t MSG_process_get_host(m_process_t process);
+m_process_t MSG_process_from_PID(int PID);
+int MSG_process_get_PID(m_process_t process);
+const char *MSG_process_get_name(m_process_t process);
+int MSG_process_self_PID(void);
+int MSG_process_self_PPID(void);
+m_process_t MSG_process_self(void);
+
+MSG_error_t MSG_process_suspend(m_process_t process);
+MSG_error_t MSG_process_resume(m_process_t process);
+int MSG_process_isSuspended(m_process_t process);
+
+MSG_error_t MSG_process_start(m_process_t process);
+
+
+/************************** GOS **********************************************/
+MSG_error_t MSG_task_get(m_task_t * task, m_channel_t channel);
+MSG_error_t MSG_task_put(m_task_t task, m_host_t dest,
+ m_channel_t channel);
+MSG_error_t MSG_task_execute(m_task_t task);
+int MSG_task_Iprobe(m_channel_t channel);
+void MSG_process_sleep(long double nb_sec);
+void MSG_tracelink(m_host_t dest, const char* **names, int *count);
+MSG_error_t MSG_get_errno(void);
+
+/************************** GIS **********************************************/
+void MSG_create_environment(const char *file);
+
+m_host_t MSG_get_host_by_name(const char *name);
+m_link_t MSG_get_link_by_name(const char *name);
+int MSG_get_host_number(void);
+m_host_t *MSG_get_host_table(void);
+void MSG_function_register(const char *name, m_process_code_t code);
+m_process_code_t MSG_get_registered_function(const char *name);
+void MSG_launch_application(const char *file);
+
+MSG_error_t MSG_get_arguments(int *argc, char ***argv);
+MSG_error_t MSG_set_arguments(m_process_t process,int argc, char *argv[]);
+
+long double MSG_getClock(void);
+
+/************************** FS **********************************************/
+/* MSG_error_t MSG_get_cpu(m_host_t * h, long double time, long double *val); */
+/* MSG_error_t MSG_get_bw(m_link_t * h, long double time, long double *val); */
+/* MSG_error_t MSG_get_lat(m_link_t * h, long double time, long double *val); */
+
+#endif