X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/a3848e5ea6b2305d6059c89705edaccbec356455..d9e664e60bd7fab62db0f1d838efd1d7bfd4d367:/src/msg/msg_host.c diff --git a/src/msg/msg_host.c b/src/msg/msg_host.c index 76df2333d5..c5440ab9cd 100644 --- a/src/msg/msg_host.c +++ b/src/msg/msg_host.c @@ -13,7 +13,7 @@ XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(msg); /** @addtogroup m_host_management - * \htmlonly \endhtmlonly + * \htmlonly \endhtmlonly * (#msg_host_t) and the functions for managing it. * * A location (or host) is any possible place where @@ -204,15 +204,32 @@ double MSG_get_host_speed(msg_host_t h) /** \ingroup m_host_management - * \brief Return the number of core. + * \brief Return the number of cores. + * + * \param host a host + * \return the number of cores */ -int MSG_host_get_core_number(msg_host_t h) +int MSG_host_get_core_number(msg_host_t host) { - xbt_assert((h != NULL), "Invalid parameters"); + xbt_assert((host != NULL), "Invalid parameters"); + + return (simcall_host_get_core(host)); +} + +/** \ingroup m_host_management + * \brief Return the list of processes attached to an host. + * + * \param host a host + * \return a swag with the attached processes + */ +xbt_swag_t MSG_host_get_process_list(msg_host_t host) +{ + xbt_assert((host != NULL), "Invalid parameters"); - return (simcall_host_get_core(h)); + return (simcall_host_get_process_list(host)); } + /** \ingroup m_host_management * \brief Returns the value of a given host property * @@ -264,27 +281,33 @@ int MSG_host_is_avail(msg_host_t host) return (simcall_host_get_state(host)); } -/** - * \ingroup msg_gos_functions +/** \ingroup m_host_management + * \brief Return the speed of the processor (in flop/s) at a given pstate * + * \param host host to test + * \param pstate_index pstate to test + * \return Returns the processor speed associated with pstate_index */ double MSG_get_host_power_peak_at(msg_host_t host, int pstate_index) { xbt_assert((host != NULL), "Invalid parameters (host is NULL)"); return (simcall_host_get_power_peak_at(host, pstate_index)); } -/** - * \ingroup msg_gos_functions +/** \ingroup m_host_management + * \brief Return the current speed of the processor (in flop/s) * + * \param host host to test + * \return Returns the current processor speed */ double MSG_get_host_current_power_peak(msg_host_t host) { xbt_assert((host != NULL), "Invalid parameters (host is NULL)"); return simcall_host_get_current_power_peak(host); } -/** - * \ingroup msg_gos_functions +/** \ingroup m_host_management + * \brief Return the number of pstates defined for a host * + * \param host host to test */ int MSG_get_host_nb_pstates(msg_host_t host) { @@ -292,9 +315,11 @@ int MSG_get_host_nb_pstates(msg_host_t host) { return (simcall_host_get_nb_pstates(host)); } -/** - * \ingroup msg_gos_functions +/** \ingroup m_host_management + * \brief Sets the speed of the processor (in flop/s) at a given pstate * + * \param host host to test + * \param pstate_index pstate to switch to */ void MSG_set_host_power_peak_at(msg_host_t host, int pstate_index) { xbt_assert((host != NULL), "Invalid parameters (host is NULL)"); @@ -302,13 +327,45 @@ void MSG_set_host_power_peak_at(msg_host_t host, int pstate_index) { simcall_host_set_power_peak_at(host, pstate_index); } -/** - * \ingroup msg_gos_functions +/** \ingroup m_host_management + * \brief Return the total energy consumed by a host (in Joules) * + * \param host host to test + * \return Returns the consumed energy */ double MSG_get_host_consumed_energy(msg_host_t host) { xbt_assert((host != NULL), "Invalid parameters (host is NULL)"); return simcall_host_get_consumed_energy(host); } +/** \ingroup m_host_management + * \brief Return the list of mounted storages on an host. + * \param host a host + * \return a dynar containing all storages mounted on the host + */ +xbt_dynar_t MSG_host_get_storage_list(msg_host_t host) +{ + xbt_assert((host != NULL), "Invalid parameters"); + return (simcall_host_get_storage_list(host)); +} +/** \ingroup msg_host_management + * \brief Return the content of mounted storages on an host. + * \param host a host + * \return a dynar containing content (as a dict) of all storages mounted on the host + */ +xbt_dynar_t MSG_host_get_storage_content(msg_host_t host) +{ + xbt_assert((host != NULL), "Invalid parameters"); + xbt_dynar_t contents = xbt_dynar_new(sizeof(void *),NULL); + msg_storage_t storage; + char* storage_name; + unsigned int i; + xbt_dynar_t storage_list = simcall_host_get_storage_list(host); + xbt_dynar_foreach(storage_list, i, storage_name){ + storage = xbt_lib_get_elm_or_null(storage_lib,storage_name); + xbt_dict_t content = simcall_storage_get_content(storage); + xbt_dynar_push(contents, &content); + } + return contents; +}