- move primary I/O buffer into vtreefs; change read hook API; - add hooks for write, truncate, symlink, mknod, unlink, chmod/chown; - modernize message_hook; - change procfs, devman, gpio accordingly; Change-Id: I9f0669e41195efa3253032e95d93f0a78e9d68d6
125 lines
2.2 KiB
C
125 lines
2.2 KiB
C
/* VTreeFS - stadir.c - file and file system status management */
|
|
|
|
#include "inc.h"
|
|
|
|
/*
|
|
* Retrieve file status.
|
|
*/
|
|
int
|
|
fs_stat(ino_t ino_nr, struct stat * buf)
|
|
{
|
|
char path[PATH_MAX];
|
|
time_t cur_time;
|
|
struct inode *node;
|
|
int r;
|
|
|
|
if ((node = find_inode(ino_nr)) == NULL)
|
|
return EINVAL;
|
|
|
|
/* Fill in the basic info. */
|
|
buf->st_dev = fs_dev;
|
|
buf->st_ino = get_inode_number(node);
|
|
buf->st_mode = node->i_stat.mode;
|
|
buf->st_nlink = !is_inode_deleted(node);
|
|
buf->st_uid = node->i_stat.uid;
|
|
buf->st_gid = node->i_stat.gid;
|
|
buf->st_rdev = (dev_t) node->i_stat.dev;
|
|
buf->st_size = node->i_stat.size;
|
|
|
|
/* If it is a symbolic link, return the size of the link target. */
|
|
if (S_ISLNK(node->i_stat.mode) && vtreefs_hooks->rdlink_hook != NULL) {
|
|
r = vtreefs_hooks->rdlink_hook(node, path, sizeof(path),
|
|
get_inode_cbdata(node));
|
|
|
|
if (r == OK)
|
|
buf->st_size = strlen(path);
|
|
}
|
|
|
|
/* Take the current time as file time for all files. */
|
|
cur_time = clock_time(NULL);
|
|
buf->st_atime = cur_time;
|
|
buf->st_mtime = cur_time;
|
|
buf->st_ctime = cur_time;
|
|
|
|
return OK;
|
|
}
|
|
|
|
/*
|
|
* Change file mode.
|
|
*/
|
|
int
|
|
fs_chmod(ino_t ino_nr, mode_t * mode)
|
|
{
|
|
struct inode *node;
|
|
struct inode_stat stat;
|
|
int r;
|
|
|
|
if ((node = find_inode(ino_nr)) == NULL)
|
|
return EINVAL;
|
|
|
|
if (vtreefs_hooks->chstat_hook == NULL)
|
|
return ENOSYS;
|
|
|
|
get_inode_stat(node, &stat);
|
|
|
|
stat.mode = (stat.mode & ~ALL_MODES) | (*mode & ALL_MODES);
|
|
|
|
r = vtreefs_hooks->chstat_hook(node, &stat, get_inode_cbdata(node));
|
|
|
|
if (r != OK)
|
|
return r;
|
|
|
|
get_inode_stat(node, &stat);
|
|
|
|
*mode = stat.mode;
|
|
|
|
return OK;
|
|
}
|
|
|
|
/*
|
|
* Change file ownership.
|
|
*/
|
|
int
|
|
fs_chown(ino_t ino_nr, uid_t uid, gid_t gid, mode_t * mode)
|
|
{
|
|
struct inode *node;
|
|
struct inode_stat stat;
|
|
int r;
|
|
|
|
if ((node = find_inode(ino_nr)) == NULL)
|
|
return EINVAL;
|
|
|
|
if (vtreefs_hooks->chstat_hook == NULL)
|
|
return ENOSYS;
|
|
|
|
get_inode_stat(node, &stat);
|
|
|
|
stat.uid = uid;
|
|
stat.gid = gid;
|
|
stat.mode &= ~(S_ISUID | S_ISGID);
|
|
|
|
r = vtreefs_hooks->chstat_hook(node, &stat, get_inode_cbdata(node));
|
|
|
|
if (r != OK)
|
|
return r;
|
|
|
|
get_inode_stat(node, &stat);
|
|
|
|
*mode = stat.mode;
|
|
|
|
return OK;
|
|
}
|
|
|
|
/*
|
|
* Retrieve file system statistics.
|
|
*/
|
|
int
|
|
fs_statvfs(struct statvfs * buf)
|
|
{
|
|
|
|
buf->f_flag = ST_NOTRUNC;
|
|
buf->f_namemax = PNAME_MAX;
|
|
|
|
return OK;
|
|
}
|