Невозможно установить приоритет pthread в настольном приложении Ubuntu - PullRequest
0 голосов
/ 13 октября 2018

Я пытаюсь установить приоритеты для pthreads с помощью SCHED_RR так, чтобы задача с более низким приоритетом не получала времени ЦП, когда задача с более высоким приоритетом готова к запуску.Моя система - конфигурации Ubuntu 18.04.1 LTS (без специальных опций ядра).

В тестовом примере обе задачи совместно используют реальное время, в то время как задача с высоким приоритетом готова к запуску.

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

Это происходит, даже если я запускаю код от имени пользователя root (например, sudo ./ThreadTest)

#include <iostream>
#include <error.h>
#include <pthread.h>
#include <string.h>
#include <time.h>
#include <unistd.h>

using namespace std;

// Thread function designed to use all realtime it can get intended to be started
// at high priority.  Prints once per second if it can.
void * BackGroundThread(void *)
{
    struct timespec now;
    cout << "Low priority task start" << endl;
    sleep(1);
    clock_gettime(CLOCK_MONOTONIC, &now);
    int32_t intStartSec = now.tv_sec;

    for (int i = 0; i < 10; i++)
    {
        do
        {
            clock_gettime(CLOCK_MONOTONIC, &now);
        } while (intStartSec == now.tv_sec); // Wait for second boundary.
        cout << "Low priority task i( " << i << " ) " << " Time( " << now.tv_sec
                << ", " << now.tv_nsec << " )" << endl;
        intStartSec = now.tv_sec;
    }
    cout << "Low priority task end." << endl;
    return NULL;
}
// Thread function designed to use all realtime it can get intended to be started
// at high priority.  Prints once per second.
void * HighPriorityThread(void *)
{
    sleep(3);
    cout << "High priority task start." << endl;
    volatile int y = 0;
    do
    {
        y++;
    } while (y != 0); // Wait for second boundary.
    cout << "High priority task end." << endl;
    return NULL;
}

pthread_t * CreateRRThreadWithPriority(pthread_t *myThread, int priority,
        void *(*start_routine)(void *))
{
    int retVal = -1;
    pthread_attr_t workingAttrib;
    struct sched_param prioParam;
    prioParam.sched_priority = priority;
    retVal = pthread_attr_init(&workingAttrib);
    if (retVal)
    {
        cout << "CreateRRThreadWithPriority: Failure from pthread_attr_init: "
                << strerror(retVal) << endl;
    }
    retVal = pthread_attr_setschedpolicy(&workingAttrib, SCHED_RR);
    if (retVal)
    {
        cout
                << "CreateRRThreadWithPriority: Failure from thread_attr_setschedpolic: "
                << strerror(retVal) << endl;
    }
    retVal = pthread_attr_setschedparam(&workingAttrib, &prioParam);
    if (retVal)
    {
        cout
                << "CreateRRThreadWithPriority: Failure from pthread_attr_setschedparam: "
                << strerror(retVal) << endl;
    }
    retVal = pthread_create(myThread, &workingAttrib, start_routine, NULL);
    if (retVal)
    {
        cout << "CreateRRThreadWithPriority: Failure from pthread_create: "
                << strerror(retVal) << endl;
    }
    return myThread;
}

int main()
{
    cout << "Thread Test" << endl; // prints Thread Test
    cout << sched_get_priority_min(SCHED_RR) << endl;
    cout << sched_get_priority_max(SCHED_RR) << endl;
    pthread_t LP, HP;
    CreateRRThreadWithPriority(&LP, sched_get_priority_min(SCHED_RR),
            BackGroundThread);
    CreateRRThreadWithPriority(&HP, sched_get_priority_max(SCHED_RR),
            HighPriorityThread);
    pthread_join(LP, NULL);
    pthread_join(HP, NULL);
    cout << "Complete" << endl;
    return 0;
}

Вывод:

Thread Test
1
99
Low priority task start
Low priority task i( 0 )  Time( 11093, 13 )
Low priority task i( 1 )  Time( 11094, 17 )
High priority task start.
Low priority task i( 2 )  Time( 11095, 3 )
Low priority task i( 3 )  Time( 11096, 4 )
Low priority task i( 4 )  Time( 11097, 16 )
Low priority task i( 5 )  Time( 11098, 8 )
Low priority task i( 6 )  Time( 11099, 14 )
Low priority task i( 7 )  Time( 11100, 1 )
Low priority task i( 8 )  Time( 11101, 5 )
High priority task end.
Low priority task i( 9 )  Time( 11102, 2 )
Low priority task end.
Complete

Дополнительная информация: Думая, что задание с низким приоритетом удалось запустить из-за наличия нескольких ядер, я увеличил числозадач с высоким приоритетом до 12. Задача с низким приоритетом продолжалась до тех пор, пока выполнялись 12 задач с высоким приоритетом.Чего мне не хватает?Есть ли настройка ядра?

...