2005-04-21 16:53:53 +02:00
|
|
|
/* This file takes care of those system calls that deal with time.
|
|
|
|
*
|
|
|
|
* The entry points into this file are
|
|
|
|
* do_utime: perform the UTIME system call
|
2005-05-31 11:50:51 +02:00
|
|
|
* do_stime: PM informs FS about STIME system call
|
2005-04-21 16:53:53 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "fs.h"
|
|
|
|
#include <minix/callnr.h>
|
|
|
|
#include <minix/com.h>
|
|
|
|
#include "file.h"
|
|
|
|
#include "fproc.h"
|
|
|
|
#include "param.h"
|
2007-08-07 14:52:47 +02:00
|
|
|
#include "vnode.h"
|
2005-04-21 16:53:53 +02:00
|
|
|
|
2006-10-25 15:40:36 +02:00
|
|
|
#include <minix/vfsif.h>
|
|
|
|
#include "vmnt.h"
|
|
|
|
|
2005-04-21 16:53:53 +02:00
|
|
|
/*===========================================================================*
|
|
|
|
* do_utime *
|
|
|
|
*===========================================================================*/
|
|
|
|
PUBLIC int do_utime()
|
|
|
|
{
|
|
|
|
/* Perform the utime(name, timep) system call. */
|
2006-10-25 15:40:36 +02:00
|
|
|
register int len;
|
|
|
|
int r;
|
2007-08-07 14:52:47 +02:00
|
|
|
uid_t uid;
|
|
|
|
time_t actime, modtime;
|
|
|
|
struct vnode *vp;
|
2006-10-25 15:40:36 +02:00
|
|
|
|
2005-04-21 16:53:53 +02:00
|
|
|
/* Adjust for case of 'timep' being NULL;
|
|
|
|
* utime_strlen then holds the actual size: strlen(name)+1.
|
|
|
|
*/
|
|
|
|
len = m_in.utime_length;
|
|
|
|
if (len == 0) len = m_in.utime_strlen;
|
|
|
|
|
|
|
|
if (fetch_name(m_in.utime_file, len, M1) != OK) return(err_code);
|
2006-10-25 15:40:36 +02:00
|
|
|
|
|
|
|
/* Request lookup */
|
2007-08-07 14:52:47 +02:00
|
|
|
if ((r = lookup_vp(0 /*flags*/, 0 /*!use_realuid*/, &vp)) != OK) return r;
|
2005-04-21 16:53:53 +02:00
|
|
|
|
2006-10-25 15:40:36 +02:00
|
|
|
/* Fill in request fields.*/
|
|
|
|
if (m_in.utime_length == 0) {
|
2007-08-07 14:52:47 +02:00
|
|
|
actime = modtime = clock_time();
|
2006-10-25 15:40:36 +02:00
|
|
|
} else {
|
2007-08-07 14:52:47 +02:00
|
|
|
actime = m_in.utime_actime;
|
|
|
|
modtime = m_in.utime_modtime;
|
2005-04-21 16:53:53 +02:00
|
|
|
}
|
|
|
|
|
2007-08-07 14:52:47 +02:00
|
|
|
uid= fp->fp_effuid;
|
2006-10-25 15:40:36 +02:00
|
|
|
|
2007-08-07 14:52:47 +02:00
|
|
|
r= OK;
|
|
|
|
if (vp->v_uid != uid && uid != SU_UID) r = EPERM;
|
|
|
|
if (m_in.utime_length == 0 && r != OK)
|
|
|
|
{
|
|
|
|
/* With a null times pointer, updating the times (to the current time)
|
|
|
|
* is allow if the object is writable.
|
|
|
|
*/
|
|
|
|
r = forbidden(vp, W_BIT, 0 /*!use_realuid*/);
|
2006-10-25 15:40:36 +02:00
|
|
|
}
|
|
|
|
|
2007-08-07 14:52:47 +02:00
|
|
|
if (r != OK)
|
|
|
|
{
|
|
|
|
put_vnode(vp);
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Issue request */
|
|
|
|
r= req_utime(vp->v_fs_e, vp->v_inode_nr, actime, modtime);
|
|
|
|
put_vnode(vp);
|
|
|
|
return r;
|
2005-04-21 16:53:53 +02:00
|
|
|
}
|
|
|
|
|