2009-10-01 16:00:27 +02:00
|
|
|
#include "inc.h"
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <minix/callnr.h>
|
|
|
|
#include "buf.h"
|
|
|
|
|
|
|
|
#include <minix/vfsif.h>
|
|
|
|
|
|
|
|
/* This calling is used to access a particular file. */
|
|
|
|
/*===========================================================================*
|
|
|
|
* fs_access *
|
|
|
|
*===========================================================================*/
|
2012-03-25 20:25:53 +02:00
|
|
|
int fs_access()
|
2009-10-01 16:00:27 +02:00
|
|
|
{
|
|
|
|
struct dir_record *rip;
|
|
|
|
int r = OK;
|
|
|
|
|
|
|
|
/* Temporarily open the file whose access is to be checked. */
|
|
|
|
caller_uid = fs_m_in.REQ_UID;
|
|
|
|
caller_gid = fs_m_in.REQ_GID;
|
|
|
|
|
|
|
|
/* Temporarily open the file. */
|
|
|
|
if ( (rip = get_dir_record(fs_m_in.REQ_INODE_NR)) == NULL) {
|
2013-11-03 22:33:44 +01:00
|
|
|
printf("ISOFS(%d) get_dir_record by fs_access() failed\n", sef_self());
|
2009-10-01 16:00:27 +02:00
|
|
|
return(EINVAL);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* For now ISO9660 doesn't have permission control (read and execution to
|
|
|
|
* everybody by default. So the access is always granted. */
|
|
|
|
|
|
|
|
release_dir_record(rip); /* Release the dir record used */
|
|
|
|
return(r);
|
|
|
|
}
|