Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Reorganize teshsuite/msg
[simgrid.git] / teshsuite / msg / pid / pid.c
diff --git a/teshsuite/msg/pid/pid.c b/teshsuite/msg/pid/pid.c
new file mode 100644 (file)
index 0000000..0fee70a
--- /dev/null
@@ -0,0 +1,69 @@
+/* Copyright (c) 2009-2010, 2013-2014. The SimGrid Team.
+ * All rights reserved.                                                     */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
+
+#include "msg/msg.h"
+#include "xbt/sysdep.h"
+
+XBT_LOG_NEW_DEFAULT_CATEGORY(msg_test,
+                             "Messages specific for this msg example");
+const char* mailbox = "mailbox";
+#define task_comp_size 1000
+#define task_comm_size 100000
+
+static int onexit(smx_process_exit_status_t status, int *pid){
+  XBT_INFO("Process \"%d\" killed.", *pid);
+  return 0;
+}
+
+static int sendpid(int argc, char *argv[])
+{
+  int pid = MSG_process_self_PID();
+  MSG_process_on_exit((int_f_pvoid_pvoid_t)onexit, &pid);
+  msg_task_t task = MSG_task_create("pid", task_comp_size, task_comm_size, &pid);
+  XBT_INFO("Sending pid of \"%d\".", pid);
+  MSG_task_send(task, mailbox);
+  XBT_INFO("Send of pid \"%d\" done.", pid);
+  MSG_process_suspend(MSG_process_self());
+  return 0;
+}
+
+static int killall(int argc, char *argv[]){
+  msg_task_t task = NULL;
+  _XBT_GNUC_UNUSED int res;
+  int i;
+  for (i=0; i<3;i++) {
+    res = MSG_task_receive(&(task), mailbox);
+    int pid = *(int*)MSG_task_get_data(task);
+    MSG_task_destroy(task);
+    XBT_INFO("Killing process \"%d\".", pid);
+    MSG_process_kill(MSG_process_from_PID(pid));
+    task = NULL;
+  }
+  return 0;
+}
+
+/** Main function */
+int main(int argc, char *argv[])
+{
+  msg_error_t res = MSG_OK;
+
+  MSG_init(&argc, argv);
+
+  /*   Application deployment */
+  MSG_function_register("sendpid", &sendpid);
+  MSG_function_register("killall", &killall);
+
+  MSG_process_killall(atoi(argv[3]));
+
+  MSG_create_environment(argv[1]);
+  MSG_launch_application(argv[2]);
+  res = MSG_main();
+
+  if (res == MSG_OK)
+    return 0;
+  else
+    return 1;
+}