gnunet_mpi_test.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #include "platform.h"
  2. #include "gnunet_util_lib.h"
  3. #include <mpi.h>
  4. /**
  5. * Generic logging shorthand
  6. */
  7. #define LOG(kind,...) \
  8. GNUNET_log_from (kind, "gnunet-mpi-test", __VA_ARGS__)
  9. int
  10. main (int argc, char *argv[])
  11. {
  12. char *msg;
  13. char *filename;
  14. char **argv2;
  15. struct GNUNET_OS_Process *proc;
  16. unsigned long code;
  17. pid_t pid;
  18. enum GNUNET_OS_ProcessStatusType proc_status;
  19. int ntasks;
  20. int rank;
  21. int msg_size;
  22. int ret;
  23. unsigned int cnt;
  24. ret = GNUNET_SYSERR;
  25. if (argc < 2)
  26. {
  27. printf ("Need arguments: gnunet-mpi-test <cmd> <cmd_args>");
  28. return 1;
  29. }
  30. if (MPI_SUCCESS != MPI_Init (&argc, &argv))
  31. {
  32. GNUNET_break (0);
  33. return 1;
  34. }
  35. if (MPI_SUCCESS != MPI_Comm_size (MPI_COMM_WORLD, &ntasks))
  36. {
  37. GNUNET_break (0);
  38. goto finalize;
  39. }
  40. if (MPI_SUCCESS != MPI_Comm_rank (MPI_COMM_WORLD, &rank))
  41. {
  42. GNUNET_break (0);
  43. goto finalize;
  44. }
  45. pid = getpid ();
  46. (void) GNUNET_asprintf (&filename, "%d-%d.mpiout", (int) pid, rank);
  47. msg_size = GNUNET_asprintf (&msg, "My rank is: %d\n", rank);
  48. printf ("%s", msg);
  49. if (msg_size ==
  50. GNUNET_DISK_fn_write (filename, msg, msg_size,
  51. GNUNET_DISK_PERM_USER_READ |
  52. GNUNET_DISK_PERM_GROUP_READ |
  53. GNUNET_DISK_PERM_USER_WRITE |
  54. GNUNET_DISK_PERM_GROUP_WRITE))
  55. ret = GNUNET_OK;
  56. GNUNET_free (filename);
  57. GNUNET_free (msg);
  58. if (GNUNET_OK != ret)
  59. {
  60. GNUNET_break (0);
  61. goto finalize;
  62. }
  63. ret = GNUNET_SYSERR;
  64. argv2 = GNUNET_malloc (sizeof (char *) * (argc));
  65. for (cnt = 1; cnt < argc; cnt++)
  66. argv2[cnt - 1] = argv[cnt];
  67. proc =
  68. GNUNET_OS_start_process_vap (GNUNET_NO, GNUNET_OS_INHERIT_STD_ALL, NULL,
  69. NULL, NULL, argv2[0], argv2);
  70. if (NULL == proc)
  71. {
  72. printf ("Cannot exec\n");
  73. GNUNET_free (argv2);
  74. goto finalize;
  75. }
  76. do
  77. {
  78. (void) sleep (1);
  79. ret = GNUNET_OS_process_status (proc, &proc_status, &code);
  80. }
  81. while (GNUNET_NO == ret);
  82. GNUNET_free (argv2);
  83. GNUNET_assert (GNUNET_NO != ret);
  84. if (GNUNET_OK == ret)
  85. {
  86. if (0 != code)
  87. {
  88. LOG (GNUNET_ERROR_TYPE_WARNING, "Child terminated abnormally\n");
  89. ret = GNUNET_SYSERR;
  90. GNUNET_break (0);
  91. goto finalize;
  92. }
  93. }
  94. else
  95. GNUNET_break (0);
  96. finalize:
  97. (void) MPI_Finalize ();
  98. if (GNUNET_OK == ret)
  99. return 0;
  100. printf ("Something went wrong\n");
  101. return 1;
  102. }