4 #include "surf_routing.hpp"
6 #ifndef SURF_MODEL_NETWORK_H_
7 #define SURF_MODEL_NETWORK_H_
12 class NetworkCm02Model;
13 typedef NetworkCm02Model *NetworkCm02ModelPtr;
15 class NetworkCm02Link;
16 typedef NetworkCm02Link *NetworkCm02LinkPtr;
18 class NetworkCm02LinkLmm;
19 typedef NetworkCm02LinkLmm *NetworkCm02LinkLmmPtr;
21 class NetworkCm02Action;
22 typedef NetworkCm02Action *NetworkCm02ActionPtr;
24 class NetworkCm02ActionLmm;
25 typedef NetworkCm02ActionLmm *NetworkCm02ActionLmmPtr;
30 extern NetworkCm02ModelPtr surf_network_model;
32 void net_define_callbacks(void);
37 class NetworkCm02Model : public Model {
41 NetworkCm02Model(int i) : Model("network") {
42 f_networkSolve = lmm_solve;
44 };//FIXME: add network clean interface
45 NetworkCm02Model(string name) : Model(name) {
48 NetworkCm02Model() : Model("network") {
51 //FIXME:NetworkCm02LinkPtr createResource(string name);
52 NetworkCm02LinkLmmPtr createResource(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);
61 void updateActionsStateLazy(double now, double delta);
62 virtual void gapAppend(double size, const NetworkCm02LinkLmmPtr link, NetworkCm02ActionLmmPtr action) {};
63 virtual ActionPtr communicate(RoutingEdgePtr src, RoutingEdgePtr dst,
64 double size, double rate);
65 xbt_dynar_t getRoute(RoutingEdgePtr src, RoutingEdgePtr dst); //FIXME: kill field? That is done by the routing nowadays
66 //FIXME: virtual void addTraces() =0;
67 void (*f_networkSolve)(lmm_system_t);
68 virtual double latencyFactor(double size);
69 virtual double bandwidthFactor(double size);
70 virtual double bandwidthConstraint(double rate, double bound, double size);
78 class NetworkCm02Link : virtual public Resource {
81 NetworkCm02Link(NetworkCm02ModelPtr model, const char* name, xbt_dict_t properties) : Resource(model, name, properties) {};
82 virtual double getBandwidth()=0;
83 virtual double getLatency();
84 virtual bool isShared()=0;
85 /* Using this object with the public part of
86 model does not make sense */
88 tmgr_trace_event_t p_latEvent;
91 class NetworkCm02LinkLmm : public ResourceLmm, public NetworkCm02Link {
93 NetworkCm02LinkLmm(NetworkCm02ModelPtr model, const char* name, xbt_dict_t properties)
94 : ResourceLmm(), NetworkCm02Link(model, name, properties) {};
95 NetworkCm02LinkLmm(NetworkCm02ModelPtr model, const char *name, xbt_dict_t props,
97 double constraint_value,
98 tmgr_history_t history,
99 e_surf_resource_state_t state_init,
100 tmgr_trace_t state_trace,
102 tmgr_trace_t metric_trace,
104 tmgr_trace_t lat_trace,
105 e_surf_link_sharing_policy_t policy);
108 double getBandwidth();
109 void updateState(tmgr_trace_event_t event_type, double value, double date);
116 class NetworkCm02Action : virtual public Action {
118 NetworkCm02Action(ModelPtr model, double cost, bool failed)
119 : Action(model, cost, failed) {};
124 const char* p_senderLinkName;
127 xbt_fifo_item_t p_senderFifoItem;
128 #ifdef HAVE_LATENCY_BOUND_TRACKING
129 int m_latencyLimited;
134 class NetworkCm02ActionLmm : public ActionLmm, public NetworkCm02Action {
136 NetworkCm02ActionLmm(ModelPtr model, double cost, bool failed)
137 : Action(model, cost, failed),
138 ActionLmm(model, cost, failed),
139 NetworkCm02Action(model, cost, failed) {};
140 void updateRemainingLazy(double now);
144 #endif /* SURF_MODEL_NETWORK_H_ */