2005-05-31 12:57:19 +02:00
|
|
|
/* This file takes care of those system calls that deal with time.
|
|
|
|
*
|
|
|
|
* The entry points into this file are
|
|
|
|
* do_time: perform the TIME system call
|
|
|
|
* do_stime: perform the STIME system call
|
2005-08-05 12:45:54 +02:00
|
|
|
* do_times: perform the TIMES system call
|
2005-05-31 12:57:19 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "pm.h"
|
|
|
|
#include <minix/callnr.h>
|
|
|
|
#include <minix/com.h>
|
|
|
|
#include <signal.h>
|
|
|
|
#include "mproc.h"
|
|
|
|
#include "param.h"
|
|
|
|
|
|
|
|
/*===========================================================================*
|
|
|
|
* do_time *
|
|
|
|
*===========================================================================*/
|
|
|
|
PUBLIC int do_time()
|
|
|
|
{
|
|
|
|
/* Perform the time(tp) system call. This returns the time in seconds since
|
|
|
|
* 1.1.1970. MINIX is an astrophysically naive system that assumes the earth
|
|
|
|
* rotates at a constant rate and that such things as leap seconds do not
|
|
|
|
* exist.
|
|
|
|
*/
|
2009-11-28 14:22:01 +01:00
|
|
|
clock_t uptime, boottime;
|
2005-05-31 12:57:19 +02:00
|
|
|
int s;
|
|
|
|
|
2009-11-28 14:22:01 +01:00
|
|
|
if ( (s=getuptime2(&uptime, &boottime)) != OK)
|
2010-03-05 16:05:11 +01:00
|
|
|
panic("do_time couldn't get uptime: %d", s);
|
2005-05-31 12:57:19 +02:00
|
|
|
|
2008-12-11 15:49:17 +01:00
|
|
|
mp->mp_reply.reply_time = (time_t) (boottime + (uptime/system_hz));
|
|
|
|
mp->mp_reply.reply_utime = (uptime%system_hz)*1000000/system_hz;
|
2005-05-31 12:57:19 +02:00
|
|
|
return(OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*===========================================================================*
|
|
|
|
* do_stime *
|
|
|
|
*===========================================================================*/
|
|
|
|
PUBLIC int do_stime()
|
|
|
|
{
|
|
|
|
/* Perform the stime(tp) system call. Retrieve the system's uptime (ticks
|
2009-11-28 14:22:01 +01:00
|
|
|
* since boot) and pass the new time in seconds at system boot to the kernel.
|
2005-05-31 12:57:19 +02:00
|
|
|
*/
|
2009-11-28 14:22:01 +01:00
|
|
|
clock_t uptime, boottime;
|
2005-05-31 12:57:19 +02:00
|
|
|
int s;
|
|
|
|
|
|
|
|
if (mp->mp_effuid != SUPER_USER) {
|
|
|
|
return(EPERM);
|
|
|
|
}
|
2005-07-14 17:16:12 +02:00
|
|
|
if ( (s=getuptime(&uptime)) != OK)
|
2010-03-05 16:05:11 +01:00
|
|
|
panic("do_stime couldn't get uptime: %d", s);
|
2008-12-11 15:49:17 +01:00
|
|
|
boottime = (long) m_in.stime - (uptime/system_hz);
|
2005-05-31 12:57:19 +02:00
|
|
|
|
2007-08-07 14:28:42 +02:00
|
|
|
s= sys_stime(boottime); /* Tell kernel about boottime */
|
|
|
|
if (s != OK)
|
2010-03-05 16:05:11 +01:00
|
|
|
panic("pm: sys_stime failed: %d", s);
|
2005-05-31 12:57:19 +02:00
|
|
|
|
2007-08-07 14:28:42 +02:00
|
|
|
return(OK);
|
2005-05-31 12:57:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/*===========================================================================*
|
2005-09-11 18:45:46 +02:00
|
|
|
* do_times *
|
2005-05-31 12:57:19 +02:00
|
|
|
*===========================================================================*/
|
|
|
|
PUBLIC int do_times()
|
|
|
|
{
|
|
|
|
/* Perform the times(buffer) system call. */
|
|
|
|
register struct mproc *rmp = mp;
|
2007-08-16 15:16:26 +02:00
|
|
|
clock_t user_time, sys_time, uptime;
|
2005-05-31 12:57:19 +02:00
|
|
|
int s;
|
|
|
|
|
2009-12-11 01:08:19 +01:00
|
|
|
if (OK != (s=sys_times(who_e, &user_time, &sys_time, &uptime, NULL)))
|
2010-03-05 16:05:11 +01:00
|
|
|
panic("do_times couldn't get times: %d", s);
|
2007-08-16 15:16:26 +02:00
|
|
|
rmp->mp_reply.reply_t1 = user_time; /* user time */
|
|
|
|
rmp->mp_reply.reply_t2 = sys_time; /* system time */
|
2005-05-31 12:57:19 +02:00
|
|
|
rmp->mp_reply.reply_t3 = rmp->mp_child_utime; /* child user time */
|
|
|
|
rmp->mp_reply.reply_t4 = rmp->mp_child_stime; /* child system time */
|
2007-08-16 15:16:26 +02:00
|
|
|
rmp->mp_reply.reply_t5 = uptime; /* uptime since boot */
|
2005-05-31 12:57:19 +02:00
|
|
|
|
|
|
|
return(OK);
|
|
|
|
}
|
|
|
|
|