#ifndef __FS_H #define __FS_H #include #define FS_TYPE_CRAMFS 1 #define FS_TYPE_RAMFS 2 #define FS_TYPE_DEVFS 3 #define PATH_MAX 1024 /* include/linux/limits.h */ struct partition; struct node_d; struct stat; struct dirent { char d_name[256]; }; typedef struct dir { struct device_d *dev; struct fs_driver_d *fsdrv; struct node_d *node; struct dirent d; void *priv; /* private data for the fs driver */ } DIR; typedef struct filep { struct device_d *dev; /* The device this FILE belongs to */ ulong pos; /* current position in stream */ ulong size; /* The size of this inode */ ulong flags; /* the O_* flags from open */ void *inode; /* private to the filesystem driver */ /* private fields. Mapping between FILE and filedescriptor number */ int no; char in_use; } FILE; #define FS_DRIVER_NO_DEV 1 struct fs_driver_d { ulong type; char *name; int (*probe) (struct device_d *dev); int (*mkdir)(struct device_d *dev, const char *pathname); int (*rmdir)(struct device_d *dev, const char *pathname); /* create a file. The file is guaranteed to not exist */ int (*create)(struct device_d *dev, const char *pathname, mode_t mode); int (*unlink)(struct device_d *dev, const char *pathname); /* Truncate a file to given size */ int (*truncate)(struct device_d *dev, FILE *f, ulong size); int (*open)(struct device_d *dev, FILE *f, const char *pathname); int (*close)(struct device_d *dev, FILE *f); int (*read)(struct device_d *dev, FILE *f, void *buf, size_t size); int (*write)(struct device_d *dev, FILE *f, const void *buf, size_t size); struct dir* (*opendir)(struct device_d *dev, const char *pathname); struct dirent* (*readdir)(struct device_d *dev, struct dir *dir); int (*closedir)(struct device_d *dev, DIR *dir); int (*stat)(struct device_d *dev, const char *file, struct stat *stat); int (*erase)(struct device_d *dev, FILE *f, size_t count, unsigned long offset); struct driver_d drv; unsigned long flags; }; struct fs_device_d { struct device_d *parent; /* the device we are associated with */ struct device_d dev; /* our own device */ struct fs_driver_d *driver; }; int open(const char *pathname, int flags); int creat(const char *pathname, mode_t mode); int unlink(const char *pathname); int close(int fd); int stat(const char *filename, struct stat *s); int read(int fd, void *buf, size_t count); int erase(int fd, size_t count, unsigned long offset); ssize_t write(int fd, const void *buf, size_t count); #define SEEK_SET 1 #define SEEK_CUR 2 #define SEEK_END 3 off_t lseek(int fildes, off_t offset, int whence); int ls(const char *path, ulong flags); int mkdir (const char *pathname); int rmdir (const char *pathname); int mount (const char *device, const char *fsname, const char *path); int umount(const char *pathname); const char *getcwd(void); int chdir(const char *pathname); DIR *opendir(const char *pathname); struct dirent *readdir(DIR *dir); int closedir(DIR *dir); char *mkmodestr(unsigned long mode, char *str); struct mtab_entry *get_mtab_entry_by_path(const char *path); struct mtab_entry *mtab_next_entry(struct mtab_entry *entry); struct mtab_entry { char path[PATH_MAX]; struct mtab_entry *next; struct device_d *dev; struct device_d *parent_device; }; char *normalise_path(const char *path); #endif /* __FS_H */