2013-01-05 44 views
6

私はシングルスレッドアプリケーションを持っています。以下のコードを使用すると、sched_setscheduler(): Operation not permitted となります。Linuxのスレッド優先度とスケジューラを変更する

struct sched_param param; 
param.sched_priority = 1; 
if (sched_setscheduler(getpid(), SCHED_RR, &param)) 
printf(stderr, "sched_setscheduler(): %s\n", strerror(errno)); 

しかし、以下のようなpthread apiを使用するとエラーは表示されません。単一のスレッドアプリケーションの2つの違いは何ですか?以下の関数はスケジューラと優先順位を実際に変更していますか、エラー処理が不足していますか?

void assignRRPriority(int tPriority) 
{ 
    int policy; 
    struct sched_param param; 

    pthread_getschedparam(pthread_self(), &policy, &param); 
    param.sched_priority = tPriority; 
    if(pthread_setschedparam(pthread_self(), SCHED_RR, &param)) 
      printf("error while setting thread priority to %d", tPriority); 
} 

答えて

3

エラー(ulimit -rは1-99優先度を可能にするために、ulimit -r 99をチェックするために)リアルタイム優先度に設定された制限によって引き起こされ得ます。 pthread_setschedparamが成功しました:-pthreadオプションなしでコンパイルした場合、この関数は他のpthread関数と同様にスタブに過ぎません。 -pthreadオプションを指定すると、結果は同じになります(straceは、同じシステムコールが使用されていることを示しています)。

+0

1.アプリケーションを-lpthreadとリンクしました。 2. ulimit -rは0を示していますので、関数assignRRPriorityを80という値で呼び出すことができます。どうしてそれがエラーにならないのですか? – Jimm

+0

'-lpthread'で十分ではありませんが、' -pthread'が必要です(_both_コンパイルの_and_リンク用)。次に、assignRRPriorityは失敗します。 –

0

いくつかの基本的なエラー処理がありません。そこには<が必要です。これを試してみてください:

if(pthread_setschedparam(pthread_self(), SCHED_RR, &param) < 0) { 
    perror("pthread_setschedparam"); 
} 
関連する問題