X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fapi%2Fsched.c;h=def5b354fc40e14ad051bc54d9c3b133dbb64056;hb=50ab48b035c2555e09cc9ac94c74f45b74b234f4;hp=23ce364030f04f9288ae9d4e623bc2d6c7a72557;hpb=3c60f40d564ec78f1403eff277095640aed3f01c;p=libc-test diff --git a/src/api/sched.c b/src/api/sched.c index 23ce364..def5b35 100644 --- a/src/api/sched.c +++ b/src/api/sched.c @@ -1,39 +1,35 @@ #include +#include "options.h" #define T(t) (t*)0; #define F(t,n) {t *y = &x.n;} #define C(n) switch(n){case n:;} static void f() { -#ifdef X_PS -T(pid_t) -#endif -T(time_t) T(struct timespec) { struct sched_param x; F(int,sched_priority) +#if defined(POSIX_SPORADIC_SERVER) || defined(POSIX_THREAD_SPORADIC_SERVER) F(int,sched_ss_low_priority) F(struct timespec,sched_ss_repl_period) F(struct timespec,sched_ss_init_budget) F(int,sched_ss_max_repl) -} - +T(time_t) C(SCHED_SPORADIC) -{int(*p)(void) = sched_yield;} - -#if defined(X_PS) || defined(X_TPS) -C(SCHED_FIFO) -C(SCHED_RR) -C(SCHED_OTHER) -{int(*p)(int) = sched_get_priority_max;} -{int(*p)(int) = sched_get_priority_min;} -{int(*p)(pid_t,struct timespec*) = sched_rr_get_interval;} #endif - -#ifdef X_PS +} +#ifdef POSIX_PRIORITY_SCHEDULING +T(pid_t) {int(*p)(pid_t,struct sched_param*) = sched_getparam;} {int(*p)(pid_t) = sched_getscheduler;} {int(*p)(pid_t,const struct sched_param*) = sched_setparam;} {int(*p)(pid_t,int,const struct sched_param*) = sched_setscheduler;} #endif +C(SCHED_FIFO) +C(SCHED_RR) +C(SCHED_OTHER) +{int(*p)(int) = sched_get_priority_max;} +{int(*p)(int) = sched_get_priority_min;} +{int(*p)(pid_t,struct timespec*) = sched_rr_get_interval;} +{int(*p)(void) = sched_yield;} }