Использование доступного физического ядра процессора в pthread в Linux - PullRequest
1 голос
/ 27 октября 2011

Я использую Linux Centos.

Я кодирую в c с помощью pthread и использую pthread_set_affinity . Я хочу, чтобы каждый поток работал в уникальном процессоре. Как ---

thread1 in proccessor 0
thread2 in proccessor 1
.
.
.
threadn in processor n

в настоящее время, когда я использую этот set_affinity, он запускается, но когда я увидел системный монитор, я вижу, что загрузка ЦП восьми ядер не распределяется.

КОД похож на это: *

        if(for thread 1 )
        { 
        pthread_attr_init(&pta);
        CPU_SET(0,&cpuset);
        pthread_setaffinity_np(thread1, sizeof(cpu_set_t), &cpuset);
        pthread_create(&thread1,&pta,&sendimsg,(void*)&message);
        pthread_join(thread1,NULL);
        printf("User for Thread One : %d\n",numb.fir);
        pthread_attr_destroy(&pta);
        CPU_ZERO(&cpuset);
        }  

            else if(for thread 2)
            {
            pthread_attr_init(&pra);
            CPU_SET(1,&cpuset1);
            pthread_setaffinity_np(thread2, sizeof(cpu_set_t), &cpuset);
            pthread_create(&thread2,&pra,&sendimsg,(void*)&message);
            pthread_join(thread2,NULL);
            printf("User for Thread Two : %d\n",numb.sec);
            pthread_attr_destroy(&pra);
            CPU_ZERO(&cpuset1);
            }  

            for eight thread that way. 

Примечание: потоки распределяются по типу 20 20 20 20 ... 20

процент такой:

10% 1% 0% 2% 0% 1% 0% 0% 1%

У меня 8-ядерный ПК, и я пытаюсь запустить 8 потоков в 8 ядрах. Есть способ полностью использовать 8 ядер в этом pthread и pthread_set_affinity.

1 Ответ

0 голосов
/ 27 октября 2011

Вам, вероятно, не хватает работы, чтобы полностью использовать потоки.Вам не нужно устанавливать сродство для этого, просто создайте 8 потоков, которые могут на 100% использовать один поток.

...