1 /* Copyright (c) 2013-2015. The SimGrid Team.
2 * All rights reserved. */
4 /* This program is free software; you can redistribute it and/or modify it
5 * under the terms of the license (GNU LGPL) which comes with this package. */
7 #ifndef SURF_NETWORK_CM02_HPP_
8 #define SURF_NETWORK_CM02_HPP_
12 #include "network_interface.hpp"
14 #include "xbt/graph.h"
25 class XBT_PRIVATE NetworkCm02Model;
26 class XBT_PRIVATE NetworkCm02Action;
27 class XBT_PRIVATE NetworkSmpiModel;
36 XBT_PRIVATE void net_define_callbacks(void);
45 class NetworkCm02Model : public NetworkModel {
49 NetworkCm02Model(int /*i*/) : NetworkModel() {};
51 ~NetworkCm02Model() { }
52 Link* createLink(const char *name,
54 tmgr_trace_t bw_trace,
56 tmgr_trace_t lat_trace,
57 e_surf_resource_state_t state_initial,
58 tmgr_trace_t state_trace,
59 e_surf_link_sharing_policy_t policy,
60 xbt_dict_t properties) override;
62 void updateActionsStateLazy(double now, double delta);
63 void updateActionsStateFull(double now, double delta);
64 Action *communicate(RoutingEdge *src, RoutingEdge *dst,
65 double size, double rate);
66 bool shareResourcesIsIdempotent() {return true;}
67 virtual void gapAppend(double /*size*/, const Link* /*link*/, NetworkAction * /*action*/) {};
68 bool m_haveGap = false;
75 class NetworkCm02Link : public Link {
77 NetworkCm02Link(NetworkCm02Model *model, const char *name, xbt_dict_t props,
79 double constraint_value,
80 tmgr_history_t history,
81 e_surf_resource_state_t state_init,
82 tmgr_trace_t state_trace,
84 tmgr_trace_t metric_trace,
86 tmgr_trace_t lat_trace,
87 e_surf_link_sharing_policy_t policy);
88 void updateState(tmgr_trace_event_t event_type, double value, double date);
89 void updateBandwidth(double value, double date=surf_get_clock());
90 void updateLatency(double value, double date=surf_get_clock());
91 virtual void gapAppend(double /*size*/, const Link* /*link*/, NetworkAction * /*action*/) {};
100 class NetworkCm02Action : public NetworkAction {
101 friend Action *NetworkCm02Model::communicate(RoutingEdge *src, RoutingEdge *dst, double size, double rate);
102 friend NetworkSmpiModel;
105 NetworkCm02Action(Model *model, double cost, bool failed)
106 : NetworkAction(model, cost, failed) {};
107 void updateRemainingLazy(double now);
115 #endif /* SURF_NETWORK_CM02_HPP_ */