mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-25 10:52:11 +01:00
948d6546af
All yaffs changes for library inclusion, arm compilation, and simposix integration.
335 lines
12 KiB
C
335 lines
12 KiB
C
/*
|
|
* YAFFS: Yet another Flash File System . A NAND-flash specific file system.
|
|
*
|
|
* Copyright (C) 2002-2011 Aleph One Ltd.
|
|
* for Toby Churchill Ltd and Brightstar Engineering
|
|
*
|
|
* Created by Charles Manning <charles@aleph1.co.uk>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License version 2.1 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
|
|
*/
|
|
|
|
/*
|
|
* Header file for using yaffs in an application via
|
|
* a direct interface.
|
|
*/
|
|
|
|
|
|
#ifndef __YAFFSFS_H__
|
|
#define __YAFFSFS_H__
|
|
|
|
#include "yaffscfg.h"
|
|
#include "yportenv.h"
|
|
|
|
|
|
#ifndef NAME_MAX
|
|
#define NAME_MAX 256
|
|
#endif
|
|
|
|
#ifdef CONFIG_YAFFS_OP
|
|
#define YAFFS_MAX_FILE_SIZE (Y_LOFF_T)16000000
|
|
#else
|
|
#define YAFFS_MAX_FILE_SIZE \
|
|
( (sizeof(Y_LOFF_T) < 8) ? YAFFS_MAX_FILE_SIZE_32 : (0x800000000LL - 1) )
|
|
#endif
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
|
|
struct yaffs_dirent {
|
|
long d_ino; /* inode number */
|
|
off_t d_off; /* offset to this dirent */
|
|
unsigned short d_reclen; /* length of this dirent */
|
|
YUCHAR d_type; /* type of this record */
|
|
YCHAR d_name[NAME_MAX+1]; /* file name (null-terminated) */
|
|
unsigned d_dont_use; /* debug: not for public consumption */
|
|
};
|
|
|
|
typedef struct opaque_structure yaffs_DIR;
|
|
|
|
|
|
|
|
struct yaffs_stat {
|
|
int st_dev; /* device */
|
|
int st_ino; /* inode */
|
|
unsigned st_mode; /* protection */
|
|
int st_nlink; /* number of hard links */
|
|
int st_uid; /* user ID of owner */
|
|
int st_gid; /* group ID of owner */
|
|
unsigned st_rdev; /* device type (if inode device) */
|
|
Y_LOFF_T st_size; /* total size, in bytes */
|
|
unsigned long st_blksize; /* blocksize for filesystem I/O */
|
|
unsigned long st_blocks; /* number of blocks allocated */
|
|
#ifdef CONFIG_YAFFS_WINCE
|
|
/* Special 64-bit times for WinCE */
|
|
unsigned long yst_wince_atime[2];
|
|
unsigned long yst_wince_mtime[2];
|
|
unsigned long yst_wince_ctime[2];
|
|
#else
|
|
unsigned long yst_atime; /* time of last access */
|
|
unsigned long yst_mtime; /* time of last modification */
|
|
unsigned long yst_ctime; /* time of last change */
|
|
#endif
|
|
};
|
|
|
|
|
|
struct yaffs_utimbuf {
|
|
unsigned long actime;
|
|
unsigned long modtime;
|
|
};
|
|
|
|
/* Normal POSIX-style API functions */
|
|
|
|
int yaffs_open(const YCHAR *path, int oflag, int mode) ;
|
|
|
|
int yaffs_close(int fd) ;
|
|
int yaffs_fsync(int fd) ;
|
|
int yaffs_fdatasync(int fd) ;
|
|
int yaffs_flush(int fd) ; /* same as yaffs_fsync() */
|
|
|
|
int yaffs_access(const YCHAR *path, int amode);
|
|
|
|
int yaffs_dup(int fd);
|
|
|
|
int yaffs_read(int fd, void *buf, unsigned int nbyte) ;
|
|
int yaffs_write(int fd, const void *buf, unsigned int nbyte) ;
|
|
|
|
int yaffs_pread(int fd, void *buf, unsigned int nbyte, Y_LOFF_T offset);
|
|
int yaffs_pwrite(int fd, const void *buf, unsigned int nbyte, Y_LOFF_T offset);
|
|
|
|
Y_LOFF_T yaffs_lseek(int fd, Y_LOFF_T offset, int whence) ;
|
|
|
|
int yaffs_truncate(const YCHAR *path, Y_LOFF_T new_size);
|
|
int yaffs_ftruncate(int fd, Y_LOFF_T new_size);
|
|
|
|
int yaffs_unlink(const YCHAR *path) ;
|
|
int yaffs_rename(const YCHAR *oldPath, const YCHAR *newPath) ;
|
|
|
|
int yaffs_stat(const YCHAR *path, struct yaffs_stat *buf) ;
|
|
int yaffs_lstat(const YCHAR *path, struct yaffs_stat *buf) ;
|
|
int yaffs_fstat(int fd, struct yaffs_stat *buf) ;
|
|
|
|
int yaffs_utime(const YCHAR *path, const struct yaffs_utimbuf *buf);
|
|
int yaffs_futime(int fd, const struct yaffs_utimbuf *buf);
|
|
|
|
|
|
int yaffs_setxattr(const char *path, const char *name,
|
|
const void *data, int size, int flags);
|
|
int yaffs_lsetxattr(const char *path, const char *name,
|
|
const void *data, int size, int flags);
|
|
int yaffs_fsetxattr(int fd, const char *name,
|
|
const void *data, int size, int flags);
|
|
|
|
int yaffs_getxattr(const char *path, const char *name,
|
|
void *data, int size);
|
|
int yaffs_lgetxattr(const char *path, const char *name,
|
|
void *data, int size);
|
|
int yaffs_fgetxattr(int fd, const char *name,
|
|
void *data, int size);
|
|
|
|
int yaffs_removexattr(const char *path, const char *name);
|
|
int yaffs_lremovexattr(const char *path, const char *name);
|
|
int yaffs_fremovexattr(int fd, const char *name);
|
|
|
|
int yaffs_listxattr(const char *path, char *list, int size);
|
|
int yaffs_llistxattr(const char *path, char *list, int size);
|
|
int yaffs_flistxattr(int fd, char *list, int size);
|
|
|
|
int yaffs_chmod(const YCHAR *path, mode_t mode);
|
|
int yaffs_fchmod(int fd, mode_t mode);
|
|
|
|
int yaffs_mkdir(const YCHAR *path, mode_t mode) ;
|
|
int yaffs_rmdir(const YCHAR *path) ;
|
|
|
|
yaffs_DIR *yaffs_opendir(const YCHAR *dirname) ;
|
|
struct yaffs_dirent *yaffs_readdir(yaffs_DIR *dirp) ;
|
|
void yaffs_rewinddir(yaffs_DIR *dirp) ;
|
|
int yaffs_closedir(yaffs_DIR *dirp) ;
|
|
|
|
int yaffs_mount(const YCHAR *path) ;
|
|
int yaffs_mount2(const YCHAR *path, int read_only);
|
|
int yaffs_mount3(const YCHAR *path, int read_only, int skip_checkpt);
|
|
|
|
int yaffs_unmount(const YCHAR *path) ;
|
|
int yaffs_unmount2(const YCHAR *path, int force);
|
|
int yaffs_remount(const YCHAR *path, int force, int read_only);
|
|
|
|
int yaffs_format(const YCHAR *path,
|
|
int unmount_flag,
|
|
int force_unmount_flag,
|
|
int remount_flag);
|
|
|
|
int yaffs_sync(const YCHAR *path) ;
|
|
|
|
int yaffs_symlink(const YCHAR *oldpath, const YCHAR *newpath);
|
|
int yaffs_readlink(const YCHAR *path, YCHAR *buf, int bufsiz);
|
|
|
|
int yaffs_link(const YCHAR *oldpath, const YCHAR *newpath);
|
|
int yaffs_mknod(const YCHAR *pathname, mode_t mode, dev_t dev);
|
|
|
|
Y_LOFF_T yaffs_freespace(const YCHAR *path);
|
|
Y_LOFF_T yaffs_totalspace(const YCHAR *path);
|
|
|
|
/* Function variants that use a relative directory */
|
|
struct yaffs_obj;
|
|
int yaffs_open_sharing_reldir(struct yaffs_obj *reldir, const YCHAR *path, int oflag, int mode, int sharing);
|
|
int yaffs_open_reldir(struct yaffs_obj *reldir,const YCHAR *path, int oflag, int mode);
|
|
int yaffs_truncate_reldir(struct yaffs_obj *reldir, const YCHAR *path, Y_LOFF_T new_size);
|
|
int yaffs_unlink_reldir(struct yaffs_obj *reldir, const YCHAR *path);
|
|
int yaffs_rename_reldir(struct yaffs_obj *reldir,
|
|
const YCHAR *oldPath, const YCHAR *newPath);
|
|
int yaffs_stat_reldir(struct yaffs_obj *reldir, const YCHAR *path, struct yaffs_stat *buf);
|
|
int yaffs_lstat_reldir(struct yaffs_obj *reldir, const YCHAR *path, struct yaffs_stat *buf);
|
|
int yaffs_utime_reldir(struct yaffs_obj *reldir, const YCHAR *path, const struct yaffs_utimbuf *buf);
|
|
int yaffs_setxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
|
|
const char *name, const void *data, int size, int flags);
|
|
int yaffs_lsetxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
|
|
const char *name, const void *data, int size, int flags);
|
|
int yaffs_getxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
|
|
const char *name, void *data, int size);
|
|
int yaffs_lgetxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
|
|
const char *name, void *data, int size);
|
|
int yaffs_listxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
|
|
char *data, int size);
|
|
int yaffs_llistxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
|
|
char *data, int size);
|
|
int yaffs_removexattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
|
|
const char *name);
|
|
int yaffs_lremovexattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
|
|
const char *name);
|
|
int yaffs_access_reldir(struct yaffs_obj *reldir, const YCHAR *path, int amode);
|
|
int yaffs_chmod_reldir(struct yaffs_obj *reldir, const YCHAR *path, mode_t mode);
|
|
int yaffs_mkdir_reldir(struct yaffs_obj *reldir, const YCHAR *path, mode_t mode);
|
|
int yaffs_rmdir_reldir(struct yaffs_obj *reldir, const YCHAR *path);
|
|
yaffs_DIR *yaffs_opendir_reldir(struct yaffs_obj *reldir, const YCHAR *dirname);
|
|
int yaffs_symlink_reldir(struct yaffs_obj *reldir,
|
|
const YCHAR *oldpath, const YCHAR *newpath);
|
|
int yaffs_readlink_reldir(struct yaffs_obj *reldir,const YCHAR *path,
|
|
YCHAR *buf, int bufsiz);
|
|
int yaffs_link_reldir(struct yaffs_obj *reldir,
|
|
const YCHAR *oldpath, const YCHAR *linkpath);
|
|
int yaffs_mknod_reldir(struct yaffs_obj *reldir, const YCHAR *pathname,
|
|
mode_t mode, dev_t dev);
|
|
|
|
/* Function variants that use a relative device */
|
|
struct yaffs_dev;
|
|
int yaffs_open_sharing_reldev(struct yaffs_dev *dev, const YCHAR *path, int oflag, int mode, int sharing);
|
|
int yaffs_open_reldev(struct yaffs_dev *dev,const YCHAR *path, int oflag, int mode);
|
|
int yaffs_truncate_reldev(struct yaffs_dev *dev, const YCHAR *path, Y_LOFF_T new_size);
|
|
int yaffs_unlink_reldev(struct yaffs_dev *dev, const YCHAR *path);
|
|
int yaffs_rename_reldev(struct yaffs_dev *dev,
|
|
const YCHAR *oldPath, const YCHAR *newPath);
|
|
int yaffs_stat_reldev(struct yaffs_dev *dev, const YCHAR *path, struct yaffs_stat *buf);
|
|
int yaffs_lstat_reldev(struct yaffs_dev *dev, const YCHAR *path, struct yaffs_stat *buf);
|
|
int yaffs_utime_reldev(struct yaffs_dev *dev, const YCHAR *path, const struct yaffs_utimbuf *buf);
|
|
int yaffs_setxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
const char *name, const void *data, int size, int flags);
|
|
int yaffs_lsetxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
const char *name, const void *data, int size, int flags);
|
|
int yaffs_getxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
const char *name, void *data, int size);
|
|
int yaffs_lgetxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
const char *name, void *data, int size);
|
|
int yaffs_listxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
char *data, int size);
|
|
int yaffs_llistxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
char *data, int size);
|
|
int yaffs_removexattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
const char *name);
|
|
int yaffs_lremovexattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
const char *name);
|
|
int yaffs_access_reldev(struct yaffs_dev *dev, const YCHAR *path, int amode);
|
|
int yaffs_chmod_reldev(struct yaffs_dev *dev, const YCHAR *path, mode_t mode);
|
|
int yaffs_mkdir_reldev(struct yaffs_dev *dev, const YCHAR *path, mode_t mode);
|
|
int yaffs_rmdir_reldev(struct yaffs_dev *dev, const YCHAR *path);
|
|
yaffs_DIR *yaffs_opendir_reldev(struct yaffs_dev *dev, const YCHAR *dirname);
|
|
int yaffs_symlink_reldev(struct yaffs_dev *dev,
|
|
const YCHAR *oldpath, const YCHAR *newpath);
|
|
int yaffs_readlink_reldev(struct yaffs_dev *dev, const YCHAR *path,
|
|
YCHAR *buf, int bufsiz);
|
|
int yaffs_link_reldev(struct yaffs_dev *dev,
|
|
const YCHAR *oldpath, const YCHAR *linkpath);
|
|
int yaffs_mknod_reldev(struct yaffs_dev *dev, const YCHAR *pathname,
|
|
mode_t mode, dev_t dev_val);
|
|
Y_LOFF_T yaffs_freespace_reldev(struct yaffs_dev *dev);
|
|
Y_LOFF_T yaffs_totalspace_reldev(struct yaffs_dev *dev);
|
|
|
|
int yaffs_sync_reldev(struct yaffs_dev *dev);
|
|
int yaffs_unmount_reldev(struct yaffs_dev *dev);
|
|
int yaffs_unmount2_reldev(struct yaffs_dev *dev, int force);
|
|
int yaffs_remount_reldev(struct yaffs_dev *dev, int force, int read_only);
|
|
|
|
|
|
/* Some non-standard functions to use fds to access directories */
|
|
struct yaffs_dirent *yaffs_readdir_fd(int fd);
|
|
void yaffs_rewinddir_fd(int fd);
|
|
|
|
/* Non-standard functions to pump garbage collection. */
|
|
int yaffs_do_background_gc(const YCHAR *path, int urgency);
|
|
int yaffs_do_background_gc_reldev(struct yaffs_dev *dev, int urgency);
|
|
|
|
/* Non-standard functions to get usage info */
|
|
int yaffs_inodecount(const YCHAR *path);
|
|
|
|
int yaffs_n_handles(const YCHAR *path);
|
|
|
|
int yaffs_n_handles_reldir(struct yaffs_obj *reldir, const YCHAR *path);
|
|
int yaffs_dump_dev_reldir(struct yaffs_obj *reldir, const YCHAR *path);
|
|
int yaffs_n_handles_reldev(struct yaffs_dev *dev, const YCHAR *path);
|
|
int yaffs_dump_dev_reldev(struct yaffs_dev *dev, const YCHAR *path);
|
|
|
|
#ifdef CONFIG_YAFFS_WINCE
|
|
int yaffs_set_wince_times(int fd,
|
|
const unsigned *wctime,
|
|
const unsigned *watime,
|
|
const unsigned *wmtime);
|
|
int yaffs_get_wince_times(int fd,
|
|
unsigned *wctime,
|
|
unsigned *watime,
|
|
unsigned *wmtime);
|
|
#endif
|
|
|
|
|
|
#define YAFFS_SHARE_READ 1
|
|
#define YAFFS_SHARE_WRITE 2
|
|
int yaffs_open_sharing(const YCHAR *path, int oflag, int mode, int shareMode);
|
|
|
|
struct yaffs_dev;
|
|
void yaffs_add_device(struct yaffs_dev *dev);
|
|
|
|
int yaffs_start_up(void);
|
|
int yaffsfs_GetLastError(void);
|
|
|
|
/* Functions to iterate through devices. NB Use with extreme care! */
|
|
void yaffs_dev_rewind(void);
|
|
struct yaffs_dev *yaffs_next_dev(void);
|
|
|
|
/* Function to get the last error */
|
|
int yaffs_get_error(void);
|
|
const char *yaffs_error_to_str(int err);
|
|
|
|
/* Function only for debugging */
|
|
void *yaffs_getdev(const YCHAR *path);
|
|
int yaffs_dump_dev(const YCHAR *path);
|
|
int yaffs_set_error(int error);
|
|
|
|
/* Trace control functions */
|
|
unsigned yaffs_set_trace(unsigned tm);
|
|
unsigned yaffs_get_trace(void);
|
|
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
|
|
#endif
|