pthreads_setaffinity_np: неверный аргумент?
Мне удалось заставить мою программу pthreads работать. По сути, я пытаюсь вручную установить сродство 4 потоков, чтобы поток 1 работал на ЦП 1, поток 2 - на ЦП 2, поток 3 - на ЦП 3, а поток 4 - на ЦП 4.
После компиляции мой код работает для нескольких потоков, но не для других (кажется, что поток 1 никогда не работает), но запуск одной и той же скомпилированной программы несколько раз дает мне разные результаты.
Например:
hao @ Gorax: ~ / Desktop $./a.out
Поток 3 работает на процессоре 3
pthread_setaffinity_np: неверный аргумент
Thread Thread 2 работает на CPU 2
hao @ Gorax: ~ / Desktop $./a.out
Поток 2 работает на процессоре 2
pthread_setaffinity_np: неверный аргумент
pthread_setaffinity_np: неверный аргумент
Поток 3 работает на процессоре 3
Поток 3 работает на процессоре 3
hao @ Gorax: ~ / Desktop $./a.out
Поток 2 работает на процессоре 2
pthread_setaffinity_np: неверный аргумент
Thread 4 работает на CPU 4
Thread 4 работает на CPU 4
hao @ Gorax: ~ / Desktop $./a.out
pthread_setaffinity_np: неверный аргумент
Мой вопрос: "Почему это происходит? Кроме того, почему сообщение иногда печатается дважды?"
Вот код:
#define _GNU_SOURCE
#include <stdio.h>
#include <pthread.h>
#include <stdlib.h>
#include <sched.h>
#include <errno.h>
#define handle_error_en(en, msg) \
do { errno = en; perror(msg); exit(EXIT_FAILURE); } while (0)
void *thread_function(char *message)
{
int s, j, number;
pthread_t thread;
cpu_set_t cpuset;
number = (int)message;
thread = pthread_self();
CPU_SET(number, &cpuset);
s = pthread_setaffinity_np(thread, sizeof(cpu_set_t), &cpuset);
if (s != 0)
{
handle_error_en(s, "pthread_setaffinity_np");
}
printf("Thread %d is running on CPU %d\n", number, sched_getcpu());
exit(EXIT_SUCCESS);
}
int main()
{
pthread_t thread1, thread2, thread3, thread4;
int thread1Num = 1;
int thread2Num = 2;
int thread3Num = 3;
int thread4Num = 4;
int thread1Create, thread2Create, thread3Create, thread4Create, i, temp;
thread1Create = pthread_create(&thread1, NULL, (void *)thread_function, (char *)thread1Num);
thread2Create = pthread_create(&thread2, NULL, (void *)thread_function, (char *)thread2Num);
thread3Create = pthread_create(&thread3, NULL, (void *)thread_function, (char *)thread3Num);
thread4Create = pthread_create(&thread4, NULL, (void *)thread_function, (char *)thread4Num);
pthread_join(thread1, NULL);
pthread_join(thread2, NULL);
pthread_join(thread3, NULL);
pthread_join(thread4, NULL);
return 0;
}
1 ответ
Первый ЦП - это ЦП 0, а не ЦП 1. Итак, вы захотите изменить свои threadNums:
int thread1Num = 0;
int thread2Num = 1;
int thread3Num = 2;
int thread4Num = 3;
Вы должны инициализировать cpuset
с помощью макроса CPU_ZERO() следующим образом:
CPU_ZERO(&cpuset);
CPU_SET(number, &cpuset);
Также не вызывайте exit() из потока, так как он остановит весь процесс со всеми его потоками:
Выход (EXIT_SUCCESS);вернуть 0; // Используйте это вместо этого или вызовите pthread_exit()