выполнение двух программ в разных процессорах параллельно - PullRequest
0 голосов
/ 15 декабря 2011

Я использовал этот код c / c ++ для планирования 2 процессоров для параллельного запуска 2 разных программ.пожалуйста, как мне подтвердить, что 2 процессора работают 2 программы параллельно?

#include <stdlib.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <iostream>
#include <sched.h>
#include <stdio.h>
#include <cstdlib>

int main(int argc, char *argv[])
{
cpu_set_t  mask;
CPU_ZERO(&mask);
int pid;
pid=fork();
  if (pid == 0) { /* second child */
        CPU_SET(0, &mask);
     sched_setaffinity(0, sizeof(mask), &mask);
     system("/home/ifeanyi/Process/PID/Debug/PID");
  }
  else if (pid > 0) { // Parent ends
      CPU_SET(1, &mask);
      sched_setaffinity(getpid(), sizeof(mask), &mask);
      cout << getpid() << endl;
      system("/home/ifeanyi/Process/checkpointing/Debug/checkpointing"); // Last leaf
      }
       cout << endl;
  }

1 Ответ

0 голосов
/ 15 декабря 2011

Вместо того, чтобы жестко кодировать эти детали в вашей программе, в целом проще и гибче сделать это из командной строки, используя taskset , например,

$ taskset -c 0 ./my_program &
$ taskset -c 1 ./my_program &
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...