2011-02-17 18:11:09 +01:00
|
|
|
#include <sys/cdefs.h>
|
|
|
|
#include "namespace.h"
|
|
|
|
#include <lib.h>
|
|
|
|
|
2013-11-04 22:48:08 +01:00
|
|
|
#include <string.h>
|
2011-02-17 18:11:09 +01:00
|
|
|
#include <sys/time.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is the implementation of the function to
|
|
|
|
* invoke the interval timer setting system call.
|
|
|
|
*/
|
2012-03-30 17:11:01 +02:00
|
|
|
int setitimer(int which, const struct itimerval *__restrict value,
|
|
|
|
struct itimerval *__restrict ovalue)
|
2011-02-17 18:11:09 +01:00
|
|
|
{
|
|
|
|
message m;
|
|
|
|
|
|
|
|
/* A null pointer for 'value' would make setitimer behave like getitimer,
|
|
|
|
* which is not according to the specification, so disallow null pointers.
|
|
|
|
*/
|
2013-11-04 22:48:08 +01:00
|
|
|
if (value == NULL) {
|
|
|
|
errno = EINVAL;
|
|
|
|
return -1;
|
|
|
|
}
|
2011-02-17 18:11:09 +01:00
|
|
|
|
2013-11-04 22:48:08 +01:00
|
|
|
memset(&m, 0, sizeof(m));
|
2014-05-13 08:43:49 +02:00
|
|
|
m.m_lc_pm_itimer.which = which;
|
|
|
|
m.m_lc_pm_itimer.value = (vir_bytes)value;
|
|
|
|
m.m_lc_pm_itimer.ovalue = (vir_bytes)ovalue;
|
2011-02-17 18:11:09 +01:00
|
|
|
|
2013-11-04 22:48:08 +01:00
|
|
|
return _syscall(PM_PROC_NR, PM_ITIMER, &m);
|
2011-02-17 18:11:09 +01:00
|
|
|
}
|
2013-01-07 20:10:08 +01:00
|
|
|
|
2013-01-18 00:06:11 +01:00
|
|
|
#if defined(__minix) && defined(__weak_alias)
|
2013-01-07 20:10:08 +01:00
|
|
|
__weak_alias(setitimer, __setitimer50)
|
|
|
|
#endif
|