blob: 40a8e8746e07dbfef702bd055f9b07834c64475f [file] [log] [blame]
#pragma once
#include "kint.h"
struct fs_vtable;
struct fs_node
{
/** file name */
char name[128];
/** identifier */
uint inode;
/** type of node */
uint flags;
/** permissions */
uint mask;
/** group id */
uint gid;
/** user id */
uint uid;
/** size in bytes */
size_t size;
/** reserved for driver */
uint dri_res;
struct fs_vtable *vtable;
/** used for mounts */
struct fs_node *mount;
};
struct fs_dirent
{
char name[128];
uint inode;
};
typedef uint (*fs_read_t)(struct fs_node *node, size_t offset, size_t size, uchar *buffer);
typedef uint (*fs_write_t)(struct fs_node *node, size_t offset, size_t size, uchar *buffer);
typedef void (*fs_open_t)(struct fs_node *node);
typedef void (*fs_close_t)(struct fs_node *node);
typedef bool (*fs_readdir_t)(struct fs_node *node, uint index, struct fs_dirent *dirent);
typedef struct fs_node *(*fs_finddir_t)(struct fs_node *node, char *name);
struct fs_vtable
{
fs_read_t read;
fs_write_t write;
fs_open_t open;
fs_close_t close;
fs_readdir_t readdir;
fs_finddir_t finddir;
};
enum fs_flags
{
FS_FILE = 1,
FS_DIRECTORY,
FS_CHARDEVICE,
FS_BLOCKDEVICE,
FS_PIPE,
FS_SYMLINK,
FS_MOUNT = 8, /* Can be or'd with others */
};
extern struct fs_node root, dev, initrd;
/* Not to be confused normal open, close, etc functions, these operate
* on the VFS directly
* read and write return the number of bytes written/read, */
uint fs_read(struct fs_node *node, size_t offset, size_t size, uchar *buffer);
uint fs_write(struct fs_node *node, size_t offset, size_t size, uchar *buffer);
void fs_open(struct fs_node *node);
void fs_close(struct fs_node *node);
bool fs_readdir(struct fs_node *node, uint index, struct fs_dirent *out);
struct fs_node *fs_finddir(struct fs_node *node, char *name);
/* Returns the following error codes:
* 0: success
* 1: target is not a directory
* 2: target is already a mount point
* 3: source is not a directory */
uint fs_mount(struct fs_node *target, struct fs_node *source);
void init_vfs();