2006-10-25 15:40:36 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "fs.h"
|
|
|
|
#include <minix/callnr.h>
|
|
|
|
#include <minix/com.h>
|
|
|
|
#include "inode.h"
|
|
|
|
|
|
|
|
#include <minix/vfsif.h>
|
|
|
|
|
|
|
|
|
|
|
|
/*===========================================================================*
|
|
|
|
* fs_utime *
|
|
|
|
*===========================================================================*/
|
|
|
|
PUBLIC int fs_utime()
|
|
|
|
{
|
|
|
|
register struct inode *rip;
|
|
|
|
register int r;
|
|
|
|
|
|
|
|
/* Temporarily open the file. */
|
|
|
|
if ( (rip = get_inode(fs_dev, fs_m_in.REQ_INODE_NR)) == NIL_INODE) {
|
|
|
|
printf("MFS(%d) get_inode by fs_utime() failed\n", SELF_E);
|
|
|
|
return(EINVAL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Only the owner of a file or the super_user can change its time. */
|
|
|
|
r = OK;
|
|
|
|
if (read_only(rip) != OK) r = EROFS; /* not even su can touch if R/O */
|
|
|
|
if (r == OK) {
|
2007-08-07 14:38:35 +02:00
|
|
|
rip->i_atime = fs_m_in.REQ_ACTIME;
|
|
|
|
rip->i_mtime = fs_m_in.REQ_MODTIME;
|
|
|
|
|
2006-10-25 15:40:36 +02:00
|
|
|
rip->i_update = CTIME; /* discard any stale ATIME and MTIME flags */
|
|
|
|
rip->i_dirt = DIRTY;
|
|
|
|
}
|
|
|
|
|
|
|
|
put_inode(rip);
|
|
|
|
return(r);
|
|
|
|
}
|
|
|
|
|
|
|
|
PUBLIC int fs_stime()
|
|
|
|
{
|
|
|
|
boottime = fs_m_in.REQ_BOOTTIME;
|
|
|
|
return OK;
|
|
|
|
}
|
|
|
|
|