Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
3a4257445ba90e40f36fde805ed7bd38d596f67f
[simgrid.git] / src / simdag / sd_link.c
1 #include "private.h"
2 #include "simdag/simdag.h"
3 #include "surf/surf.h"
4 #include "xbt/sysdep.h" /* xbt_new0 */
5
6 /* Creates a link.
7  */
8 SD_link_t __SD_link_create(void *surf_link, char *name, void *data) {
9   CHECK_INIT_DONE();
10   xbt_assert0(surf_link != NULL, "surf_link is NULL !");
11   xbt_assert0(name != NULL, "name is NULL !");
12
13   SD_link_data_t sd_data = xbt_new0(s_SD_link_data_t, 1); /* link private data */
14   sd_data->surf_link = surf_link;
15   sd_data->name = xbt_strdup(name);
16
17   SD_link_t link = xbt_new0(s_SD_link_t, 1);
18   link->sd_data = sd_data; /* private data */
19   link->data = data; /* user data */
20
21   /*link->capacity = capacity;*/
22   /* link->current_bandwidth = bandwidth;
23      link->current_latency = latency;*/
24
25   /*xbt_dynar_push(sd_global->links, link);*/
26   xbt_dict_set(sd_global->links, name, link, __SD_link_destroy); /* add the workstation to the dictionary */
27
28   return link;
29 }
30
31 /* Returns the user data of a link. The user data can be NULL.
32  */
33 void* SD_link_get_data(SD_link_t link) {
34   CHECK_INIT_DONE();
35   xbt_assert0(link != NULL, "Invalid parameter");
36   return link->data;
37 }
38
39 /* Sets the user data of a link. The new data can be NULL. The old data should have been freed first if it was not NULL.
40  */
41 void SD_link_set_data(SD_link_t link, void *data) {
42   CHECK_INIT_DONE();
43   xbt_assert0(link != NULL, "Invalid parameter");
44   link->data = data;
45 }
46
47 /* Returns the name of a link. The name can be NULL.
48  */
49 const char* SD_link_get_name(SD_link_t link) {
50   CHECK_INIT_DONE();
51   xbt_assert0(link != NULL, "Invalid parameter");
52   return link->sd_data->name;
53
54   /*  return surf_network_resource->common_public->get_resource_name(link->sd_data->surf_link);*/
55 }
56
57 /* Returns the capacity of a link.
58  */
59 /*
60 double SD_link_get_capacity(SD_link_t link) {
61   xbt_assert0(link, "Invalid parameter");
62   return link->capacity;
63 }*/
64
65 /* Return the current bandwidth of a link.
66  */
67 double SD_link_get_current_bandwidth(SD_link_t link) {
68   CHECK_INIT_DONE();
69   xbt_assert0(link != NULL, "Invalid parameter");
70
71   /* TODO */
72   return 0;
73   /*  return link->current_bandwidth;*/
74 }
75
76 /* Return the current latency of a link.
77  */
78 double SD_link_get_current_latency(SD_link_t link) {
79   CHECK_INIT_DONE();
80   xbt_assert0(link != NULL, "Invalid parameter");
81
82   /* TODO */
83   return 0;
84   /*  return link->current_latency;*/
85 }
86
87 /* Destroys a link. The user data (if any) should have been destroyed first.
88  */
89 void __SD_link_destroy(void *link) {
90   CHECK_INIT_DONE();
91   xbt_assert0(link != NULL, "Invalid parameter");
92
93   if (((SD_link_t) link)->sd_data != NULL)
94     xbt_free(((SD_link_t) link)->sd_data);
95
96   /* TODO: name */
97   
98   xbt_free(link);
99 }
100