Blob Blame History Raw
// commit: 9d5251f72b627974bcf438501e07ad42c24d94be 2011-03-08
// disallow cpu time clocks in condattr
#include <pthread.h>
#include <time.h>
#include <string.h>
#include <errno.h>
#include "test.h"
#define T(r,f) if ((r=(f))) t_error(#f " failed: %s\n", strerror(r))
int main(void)
{
pthread_cond_t c;
pthread_condattr_t a;
pthread_mutex_t m;
clockid_t clk;
struct timespec ts;
void *p;
int r;
T(r,pthread_condattr_init(&a));
r = pthread_condattr_setclock(&a, CLOCK_PROCESS_CPUTIME_ID);
if (r != EINVAL)
t_error("pthread_condattr_setclock CLOCK_PROCESS_CPUTIME_ID should fail with EINVAL, got %s\n", strerror(r));
r = pthread_condattr_setclock(&a, CLOCK_THREAD_CPUTIME_ID);
if (r != EINVAL)
t_error("pthread_condattr_setclock CLOCK_THREAD_CPUTIME_ID should fail with EINVAL, got %s\n", strerror(r));
T(r,pthread_condattr_getclock(&a, &clk));
if (clk != CLOCK_REALTIME)
t_error("condattr default clock is %d, wanted CLOCK_REALTIME (%d)\n", (int)clk, (int)CLOCK_REALTIME);
T(r,pthread_cond_init(&c, &a));
T(r,pthread_mutex_init(&m, 0));
T(r,pthread_mutex_lock(&m));
r = clock_gettime(CLOCK_REALTIME, &ts);
if (r)
t_error("clock_gettime failed: %s\n", strerror(errno));
/* wait 10ms */
ts.tv_nsec += 10*1000*1000;
if (ts.tv_nsec >= 1000*1000*1000) {
ts.tv_nsec -= 1000*1000*1000;
ts.tv_sec += 1;
}
r = pthread_cond_timedwait(&c, &m, &ts);
if (r != ETIMEDOUT)
t_error("pthread_cond_timedwait did not timeout, returned %s\n", strerror(r));
T(r,pthread_mutex_unlock(&m));
T(r,pthread_mutex_destroy(&m));
T(r,pthread_cond_destroy(&c));
T(r,pthread_condattr_destroy(&a));
return t_status;
}