myco-agent.c 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. /* Copyright (C) 2016 Max Riechelmann <max.riechelmann@student.kit.edu>
  2. (Karlsruhe Institute of Technology)
  3. This library is free software; you can redistribute it and/or modify it
  4. under the terms of the GNU Lesser General Public License as published by the
  5. Free Software Foundation; either version 2.1 of the License, or (at your
  6. option) any later version.
  7. This library is distributed in the hope that it will be useful, but WITHOUT
  8. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  9. FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
  10. details.
  11. You should have received a copy of the GNU Lesser General Public License along
  12. with this library; if not, write to the Free Software Foundation, Inc., 51
  13. Franklin St, Fifth Floor, Boston, MA 02110, USA
  14. */
  15. #include "myco-agent.h"
  16. #include "../src/myco-memory.c"
  17. #define DEBUG 1
  18. int myco_agent_register(const char *agent_name) {
  19. int agent_message_queue_id;
  20. int global_message_queue_id;
  21. message msg;
  22. sprintf(msg.agent_name, "%s", agent_name);
  23. agent_message_queue_id = myco_create_private_message_queue();
  24. msg.agent_message_queue_id = agent_message_queue_id;
  25. sprintf(msg.message, "REGISTER AGENT\n");
  26. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  27. if (DEBUG) {
  28. printf("%s", msg.message);
  29. }
  30. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  31. myco_remove_message_queue(agent_message_queue_id);
  32. return -1;
  33. }
  34. return agent_message_queue_id;
  35. }
  36. int myco_agent_unregister (const char *agent_name, int agent_message_queue_id) {
  37. message msg;
  38. msg.agent_message_queue_id = agent_message_queue_id;
  39. sprintf(msg.agent_name, "%s", agent_name);
  40. sprintf(msg.message, "UNREGISTER AGENT\n");
  41. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  42. if (DEBUG) {
  43. printf("%s", msg.message);
  44. }
  45. if (strncmp(msg.message, "SUCCESS:", 8) == 0) {
  46. myco_remove_message_queue(agent_message_queue_id);
  47. } else {
  48. return -1;
  49. }
  50. return 0;
  51. }
  52. void *myco_agent_register_resource (int agent_message_queue_id, const char *agent_name, const char *resource_name, int resource_transactional, pid_t pid, int size) {
  53. int file_descriptor = shm_open(resource_name, O_CREAT | O_TRUNC | O_RDWR, 0666);
  54. int r = ftruncate(file_descriptor, size);
  55. void *pointer = mmap(0, size, PROT_READ | PROT_WRITE, MAP_SHARED, file_descriptor, 0);
  56. message msg;
  57. msg.agent_message_queue_id = agent_message_queue_id;
  58. sprintf(msg.agent_name, "%s", agent_name);
  59. sprintf(msg.resource_name, "%s", resource_name);
  60. msg.resource_transactional = resource_transactional;
  61. msg.sender_pid = pid;
  62. msg.resource_size = size;
  63. msg.resource_pointer = pointer;
  64. sprintf(msg.message, "REGISTER RESOURCE\n");
  65. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  66. if(DEBUG) {
  67. printf("%s", msg.message);
  68. }
  69. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  70. return NULL;
  71. }
  72. return pointer;
  73. }
  74. int myco_agent_unregister_resource (int agent_message_queue_id, const char *resource_name) {
  75. message msg;
  76. msg.agent_message_queue_id = agent_message_queue_id;
  77. sprintf(msg.resource_name, "%s", resource_name);
  78. sprintf(msg.message, "UNREGISTER RESOURCE\n");
  79. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  80. if(DEBUG) {
  81. printf("%s", msg.message);
  82. }
  83. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  84. return -1;
  85. }
  86. int r = shm_unlink(resource_name);
  87. return 0;
  88. }
  89. int myco_agent_lock_resource (int agent_message_queue_id, const char *agent_name, const char *resource_name) {
  90. message msg;
  91. msg.agent_message_queue_id = agent_message_queue_id;
  92. sprintf(msg.resource_name, "%s", resource_name);
  93. sprintf(msg.agent_name, "%s", agent_name);
  94. sprintf(msg.message, "LOCK RESOURCE\n");
  95. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  96. if(DEBUG) {
  97. printf("%s", msg.message);
  98. }
  99. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  100. return -1;
  101. }
  102. return 0;
  103. }
  104. int myco_agent_release_resource (int agent_message_queue_id, const char *resource_name, void *resource_pointer, int resource_size) {
  105. message msg;
  106. msg.agent_message_queue_id = agent_message_queue_id;
  107. sprintf(msg.resource_name, "%s", resource_name);
  108. sprintf(msg.message, "RELEASE RESOURCE\n");
  109. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  110. if(DEBUG) {
  111. printf("%s", msg.message);
  112. }
  113. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  114. return -1;
  115. }
  116. int r = munmap(resource_pointer, resource_size);
  117. return 0;
  118. }
  119. int myco_agent_unlock_resource (int agent_message_queue_id, const char *agent_name, const char *resource_name) {
  120. message msg;
  121. msg.agent_message_queue_id = agent_message_queue_id;
  122. sprintf(msg.resource_name, "%s", resource_name);
  123. sprintf(msg.agent_name, "%s", agent_name);
  124. sprintf(msg.message, "UNLOCK RESOURCE\n");
  125. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  126. if(DEBUG) {
  127. printf("%s", msg.message);
  128. }
  129. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  130. return -1;
  131. }
  132. return 0;
  133. }
  134. struct resource myco_agent_request_resource(int agent_message_queue_id, char *resource_name) {
  135. struct resource myresource;
  136. message msg;
  137. msg.agent_message_queue_id = agent_message_queue_id;
  138. sprintf(msg.resource_name, "%s", resource_name);
  139. sprintf(msg.message, "REQUEST RESOURCE\n");
  140. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  141. if(DEBUG) {
  142. printf("%s", msg.message);
  143. }
  144. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  145. myresource.size = -1;
  146. return myresource;
  147. }
  148. myresource.pointer = myco_malloc(msg.resource_size);
  149. myresource.size = msg.resource_size;
  150. if (myco_copy_memory(msg.sender_pid, msg.resource_pointer, msg.resource_size, myresource.pointer, myresource.size) == -1) {
  151. fprintf(stderr, "FATAL ERROR in myco_copy_memory() %s\n", strerror(errno));
  152. myresource.size = -1;
  153. return myresource;
  154. }
  155. sprintf(msg.message, "RESOURCE GRANTED\n");
  156. myco_send(msg.agent_message_queue_id, msg);
  157. return myresource;
  158. }
  159. int myco_agent_request_resource_list(int agent_message_queue_id) {
  160. char *resource_pointer;
  161. char *split;
  162. message msg;
  163. msg.agent_message_queue_id = agent_message_queue_id;
  164. sprintf(msg.message, "REQUEST LIST\n");
  165. msg.resource_size = 0;
  166. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  167. if(DEBUG) {
  168. //printf("%s", msg.message);
  169. }
  170. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  171. return -1;
  172. }
  173. resource_pointer = myco_malloc(msg.resource_size);
  174. if (myco_copy_memory(msg.sender_pid, msg.resource_pointer, msg.resource_size, (void *)resource_pointer, msg.resource_size) == -1) {
  175. printf("ERROR: %s\n", strerror(errno));
  176. return -1;
  177. }
  178. sprintf(msg.message, "RESOURCE LIST GRANTED\n");
  179. myco_send(agent_message_queue_id, msg);
  180. printf("%s\n", resource_pointer);
  181. /*
  182. split = strtok(resource_pointer, ";");
  183. while (split != NULL) {
  184. printf("%s\n", split);
  185. split = strtok(NULL, ";");
  186. }
  187. */
  188. myco_free(resource_pointer);
  189. return 0;
  190. }
  191. int myco_agent_write_remote_resource(int agent_message_queue_id, char *resource_name) {
  192. message msg;
  193. msg.agent_message_queue_id = agent_message_queue_id;
  194. sprintf(msg.resource_name, "%s", resource_name);
  195. sprintf(msg.message, "WRITE REMOTE RESOURCE\n");
  196. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  197. if(DEBUG) {
  198. printf("%s", msg.message);
  199. }
  200. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  201. return -1;
  202. }
  203. return 0;
  204. }
  205. struct resource myco_agent_read_remote_resource(int agent_message_queue_id, char *resource_name) {
  206. struct resource myresource;
  207. message msg;
  208. msg.agent_message_queue_id = agent_message_queue_id;
  209. sprintf(msg.resource_name, "%s", resource_name);
  210. sprintf(msg.message, "READ REMOTE RESOURCE\n");
  211. msg = myco_send_and_receive(msg, myco_get_global_message_queue(), agent_message_queue_id);
  212. if(DEBUG) {
  213. printf("%s", msg.message);
  214. }
  215. if (strncmp(msg.message, "SUCCESS:", 8) != 0) {
  216. myresource.size = -1;
  217. return myresource;
  218. }
  219. myresource.pointer = myco_malloc(msg.resource_size);
  220. myresource.size = msg.resource_size;
  221. if (myco_copy_memory(msg.sender_pid, msg.resource_pointer, msg.resource_size, myresource.pointer, myresource.size) == -1) {
  222. fprintf(stderr, "FATAL ERROR in myco_copy_memory() %s\n", strerror(errno));
  223. myresource.size = -1;
  224. return myresource;
  225. }
  226. sprintf(msg.message, "RESOURCE READ\n");
  227. myco_send(msg.agent_message_queue_id, msg);
  228. return myresource;
  229. }