yaffs direct: Expose background garbage collection
[yaffs2.git] / direct / yaffsfs.h
1 /*
2  * YAFFS: Yet another Flash File System . A NAND-flash specific file system.
3  *
4  * Copyright (C) 2002-2011 Aleph One Ltd.
5  *   for Toby Churchill Ltd and Brightstar Engineering
6  *
7  * Created by Charles Manning <charles@aleph1.co.uk>
8  *
9  * This program is free software; you can redistribute it and/or modify
10  * it under the terms of the GNU Lesser General Public License version 2.1 as
11  * published by the Free Software Foundation.
12  *
13  * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
14  */
15
16 /*
17  * Header file for using yaffs in an application via
18  * a direct interface.
19  */
20
21
22 #ifndef __YAFFSFS_H__
23 #define __YAFFSFS_H__
24
25 #include "yaffscfg.h"
26 #include "yportenv.h"
27
28
29 #ifndef NAME_MAX
30 #define NAME_MAX        256
31 #endif
32
33 #define YAFFS_MAX_FILE_SIZE \
34         ( (sizeof(Y_LOFF_T) < 8) ? YAFFS_MAX_FILE_SIZE_32 : (0x800000000LL - 1) )
35
36
37 #ifdef __cplusplus
38 extern "C"
39 {
40 #endif
41
42
43 struct yaffs_dirent {
44         long d_ino;                     /* inode number */
45         off_t d_off;                    /* offset to this dirent */
46         unsigned short d_reclen;        /* length of this dirent */
47         YUCHAR d_type;                  /* type of this record */
48         YCHAR d_name[NAME_MAX+1];       /* file name (null-terminated) */
49         unsigned d_dont_use;            /* debug: not for public consumption */
50 };
51
52 typedef struct opaque_structure yaffs_DIR;
53
54
55
56 struct yaffs_stat {
57         int             st_dev;         /* device */
58         int             st_ino;         /* inode */
59         unsigned        st_mode;        /* protection */
60         int             st_nlink;       /* number of hard links */
61         int             st_uid;         /* user ID of owner */
62         int             st_gid;         /* group ID of owner */
63         unsigned        st_rdev;        /* device type (if inode device) */
64         Y_LOFF_T                st_size;        /* total size, in bytes */
65         unsigned long   st_blksize;     /* blocksize for filesystem I/O */
66         unsigned long   st_blocks;      /* number of blocks allocated */
67 #ifdef CONFIG_YAFFS_WINCE
68         /* Special 64-bit times for WinCE */
69         unsigned long   yst_wince_atime[2];
70         unsigned long   yst_wince_mtime[2];
71         unsigned long   yst_wince_ctime[2];
72 #else
73         unsigned long   yst_atime;      /* time of last access */
74         unsigned long   yst_mtime;      /* time of last modification */
75         unsigned long   yst_ctime;      /* time of last change */
76 #endif
77 };
78
79
80 struct yaffs_utimbuf {
81         unsigned long actime;
82         unsigned long modtime;
83 };
84
85 /* Normal POSIX-style API functions */
86
87 int yaffs_open(const YCHAR *path, int oflag, int mode) ;
88
89 int yaffs_close(int fd) ;
90 int yaffs_fsync(int fd) ;
91 int yaffs_fdatasync(int fd) ;
92 int yaffs_flush(int fd) ; /* same as yaffs_fsync() */
93
94 int yaffs_access(const YCHAR *path, int amode);
95
96 int yaffs_dup(int fd);
97
98 int yaffs_read(int fd, void *buf, unsigned int nbyte) ;
99 int yaffs_write(int fd, const void *buf, unsigned int nbyte) ;
100
101 int yaffs_pread(int fd, void *buf, unsigned int nbyte, Y_LOFF_T offset);
102 int yaffs_pwrite(int fd, const void *buf, unsigned int nbyte, Y_LOFF_T offset);
103
104 Y_LOFF_T yaffs_lseek(int fd, Y_LOFF_T offset, int whence) ;
105
106 int yaffs_truncate(const YCHAR *path, Y_LOFF_T new_size);
107 int yaffs_ftruncate(int fd, Y_LOFF_T new_size);
108
109 int yaffs_unlink(const YCHAR *path) ;
110 int yaffs_rename(const YCHAR *oldPath, const YCHAR *newPath) ;
111
112 int yaffs_stat(const YCHAR *path, struct yaffs_stat *buf) ;
113 int yaffs_lstat(const YCHAR *path, struct yaffs_stat *buf) ;
114 int yaffs_fstat(int fd, struct yaffs_stat *buf) ;
115
116 int yaffs_utime(const YCHAR *path, const struct yaffs_utimbuf *buf);
117 int yaffs_futime(int fd, const struct yaffs_utimbuf *buf);
118
119
120 int yaffs_setxattr(const char *path, const char *name,
121                         const void *data, int size, int flags);
122 int yaffs_lsetxattr(const char *path, const char *name,
123                         const void *data, int size, int flags);
124 int yaffs_fsetxattr(int fd, const char *name,
125                         const void *data, int size, int flags);
126
127 int yaffs_getxattr(const char *path, const char *name,
128                         void *data, int size);
129 int yaffs_lgetxattr(const char *path, const char *name,
130                         void *data, int size);
131 int yaffs_fgetxattr(int fd, const char *name,
132                         void *data, int size);
133
134 int yaffs_removexattr(const char *path, const char *name);
135 int yaffs_lremovexattr(const char *path, const char *name);
136 int yaffs_fremovexattr(int fd, const char *name);
137
138 int yaffs_listxattr(const char *path, char *list, int size);
139 int yaffs_llistxattr(const char *path, char *list, int size);
140 int yaffs_flistxattr(int fd, char *list, int size);
141
142 int yaffs_chmod(const YCHAR *path, mode_t mode);
143 int yaffs_fchmod(int fd, mode_t mode);
144
145 int yaffs_mkdir(const YCHAR *path, mode_t mode) ;
146 int yaffs_rmdir(const YCHAR *path) ;
147
148 yaffs_DIR *yaffs_opendir(const YCHAR *dirname) ;
149 struct yaffs_dirent *yaffs_readdir(yaffs_DIR *dirp) ;
150 void yaffs_rewinddir(yaffs_DIR *dirp) ;
151 int yaffs_closedir(yaffs_DIR *dirp) ;
152
153 int yaffs_mount(const YCHAR *path) ;
154 int yaffs_mount2(const YCHAR *path, int read_only);
155 int yaffs_mount3(const YCHAR *path, int read_only, int skip_checkpt);
156
157 int yaffs_unmount(const YCHAR *path) ;
158 int yaffs_unmount2(const YCHAR *path, int force);
159 int yaffs_remount(const YCHAR *path, int force, int read_only);
160
161 int yaffs_format(const YCHAR *path,
162                 int unmount_flag,
163                 int force_unmount_flag,
164                 int remount_flag);
165
166 int yaffs_sync(const YCHAR *path) ;
167
168 int yaffs_symlink(const YCHAR *oldpath, const YCHAR *newpath);
169 int yaffs_readlink(const YCHAR *path, YCHAR *buf, int bufsiz);
170
171 int yaffs_link(const YCHAR *oldpath, const YCHAR *newpath);
172 int yaffs_mknod(const YCHAR *pathname, mode_t mode, dev_t dev);
173
174 Y_LOFF_T yaffs_freespace(const YCHAR *path);
175 Y_LOFF_T yaffs_totalspace(const YCHAR *path);
176
177 /* Function variants that use a relative directory */
178 struct yaffs_obj;
179 int yaffs_open_sharing_reldir(struct yaffs_obj *reldir, const YCHAR *path, int oflag, int mode, int sharing);
180 int yaffs_open_reldir(struct yaffs_obj *reldir,const YCHAR *path, int oflag, int mode);
181 int yaffs_truncate_reldir(struct yaffs_obj *reldir, const YCHAR *path, Y_LOFF_T new_size);
182 int yaffs_unlink_reldir(struct yaffs_obj *reldir, const YCHAR *path);
183 int yaffs_rename_reldir(struct yaffs_obj *reldir,
184                         const YCHAR *oldPath, const YCHAR *newPath);
185 int yaffs_stat_reldir(struct yaffs_obj *reldir, const YCHAR *path, struct yaffs_stat *buf);
186 int yaffs_lstat_reldir(struct yaffs_obj *reldir, const YCHAR *path, struct yaffs_stat *buf);
187 int yaffs_utime_reldir(struct yaffs_obj *reldir, const YCHAR *path, const struct yaffs_utimbuf *buf);
188 int yaffs_setxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
189                         const char *name, const void *data, int size, int flags);
190 int yaffs_lsetxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
191                         const char *name, const void *data, int size, int flags);
192 int yaffs_getxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
193                         const char *name, void *data, int size);
194 int yaffs_lgetxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
195                         const char *name, void *data, int size);
196 int yaffs_listxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
197                         char *data, int size);
198 int yaffs_llistxattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
199                         char *data, int size);
200 int yaffs_removexattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
201                         const char *name);
202 int yaffs_lremovexattr_reldir(struct yaffs_obj *reldir, const YCHAR *path,
203                         const char *name);
204 int yaffs_access_reldir(struct yaffs_obj *reldir, const YCHAR *path, int amode);
205 int yaffs_chmod_reldir(struct yaffs_obj *reldir, const YCHAR *path, mode_t mode);
206 int yaffs_mkdir_reldir(struct yaffs_obj *reldir, const YCHAR *path, mode_t mode);
207 int yaffs_rmdir_reldir(struct yaffs_obj *reldir, const YCHAR *path);
208 yaffs_DIR *yaffs_opendir_reldir(struct yaffs_obj *reldir, const YCHAR *dirname);
209 int yaffs_symlink_reldir(struct yaffs_obj *reldir,
210                         const YCHAR *oldpath, const YCHAR *newpath);
211 int yaffs_readlink_reldir(struct yaffs_obj *reldir,const YCHAR *path,
212                         YCHAR *buf, int bufsiz);
213 int yaffs_link_reldir(struct yaffs_obj *reldir,
214                         const YCHAR *oldpath, const YCHAR *linkpath);
215 int yaffs_mknod_reldir(struct yaffs_obj *reldir, const YCHAR *pathname,
216                      mode_t mode, dev_t dev);
217
218 /* Function variants that use a relative device */
219 struct yaffs_dev;
220 int yaffs_open_sharing_reldev(struct yaffs_dev *dev, const YCHAR *path, int oflag, int mode, int sharing);
221 int yaffs_open_reldev(struct yaffs_dev *dev,const YCHAR *path, int oflag, int mode);
222 int yaffs_truncate_reldev(struct yaffs_dev *dev, const YCHAR *path, Y_LOFF_T new_size);
223 int yaffs_unlink_reldev(struct yaffs_dev *dev, const YCHAR *path);
224 int yaffs_rename_reldev(struct yaffs_dev *dev,
225                         const YCHAR *oldPath, const YCHAR *newPath);
226 int yaffs_stat_reldev(struct yaffs_dev *dev, const YCHAR *path, struct yaffs_stat *buf);
227 int yaffs_lstat_reldev(struct yaffs_dev *dev, const YCHAR *path, struct yaffs_stat *buf);
228 int yaffs_utime_reldev(struct yaffs_dev *dev, const YCHAR *path, const struct yaffs_utimbuf *buf);
229 int yaffs_setxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
230                         const char *name, const void *data, int size, int flags);
231 int yaffs_lsetxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
232                         const char *name, const void *data, int size, int flags);
233 int yaffs_getxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
234                         const char *name, void *data, int size);
235 int yaffs_lgetxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
236                         const char *name, void *data, int size);
237 int yaffs_listxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
238                         char *data, int size);
239 int yaffs_llistxattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
240                         char *data, int size);
241 int yaffs_removexattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
242                         const char *name);
243 int yaffs_lremovexattr_reldev(struct yaffs_dev *dev, const YCHAR *path,
244                         const char *name);
245 int yaffs_access_reldev(struct yaffs_dev *dev, const YCHAR *path, int amode);
246 int yaffs_chmod_reldev(struct yaffs_dev *dev, const YCHAR *path, mode_t mode);
247 int yaffs_mkdir_reldev(struct yaffs_dev *dev, const YCHAR *path, mode_t mode);
248 int yaffs_rmdir_reldev(struct yaffs_dev *dev, const YCHAR *path);
249 yaffs_DIR *yaffs_opendir_reldev(struct yaffs_dev *dev, const YCHAR *dirname);
250 int yaffs_symlink_reldev(struct yaffs_dev *dev,
251                         const YCHAR *oldpath, const YCHAR *newpath);
252 int yaffs_readlink_reldev(struct yaffs_dev *dev, const YCHAR *path,
253                         YCHAR *buf, int bufsiz);
254 int yaffs_link_reldev(struct yaffs_dev *dev,
255                         const YCHAR *oldpath, const YCHAR *linkpath);
256 int yaffs_mknod_reldev(struct yaffs_dev *dev, const YCHAR *pathname,
257                      mode_t mode, dev_t dev_val);
258
259 /* Some non-standard functions to use fds to access directories */
260 struct yaffs_dirent *yaffs_readdir_fd(int fd);
261 void yaffs_rewinddir_fd(int fd);
262
263 /* Non-standard functions to pump garbage collection. */
264 int yaffs_do_background_gc(const YCHAR *path, int urgency);
265 int yaffs_do_background_gc_reldev(struct yaffs_dev *dev, int urgency);
266
267 /* Non-standard functions to get usage info */
268 int yaffs_inodecount(const YCHAR *path);
269
270 int yaffs_n_handles(const YCHAR *path);
271
272 int yaffs_n_handles_reldir(struct yaffs_obj *reldir, const YCHAR *path);
273 int yaffs_dump_dev_reldir(struct yaffs_obj *reldir, const YCHAR *path);
274 int yaffs_n_handles_reldev(struct yaffs_dev *dev, const YCHAR *path);
275 int yaffs_dump_dev_reldev(struct yaffs_dev *dev, const YCHAR *path);
276
277 #ifdef CONFIG_YAFFS_WINCE
278 int yaffs_set_wince_times(int fd,
279                         const unsigned *wctime,
280                         const unsigned *watime,
281                         const unsigned *wmtime);
282 int yaffs_get_wince_times(int fd,
283                         unsigned *wctime,
284                         unsigned *watime,
285                         unsigned *wmtime);
286 #endif
287
288
289 #define YAFFS_SHARE_READ  1
290 #define YAFFS_SHARE_WRITE 2
291 int yaffs_open_sharing(const YCHAR *path, int oflag, int mode, int shareMode);
292
293 struct yaffs_dev;
294 void yaffs_add_device(struct yaffs_dev *dev);
295
296 int yaffs_start_up(void);
297 int yaffsfs_GetLastError(void);
298
299 /* Functions to iterate through devices. NB Use with extreme care! */
300 void yaffs_dev_rewind(void);
301 struct yaffs_dev *yaffs_next_dev(void);
302
303 /* Function to get the last error */
304 int yaffs_get_error(void);
305 const char *yaffs_error_to_str(int err);
306
307 /* Function only for debugging */
308 void *yaffs_getdev(const YCHAR *path);
309 int yaffs_dump_dev(const YCHAR *path);
310 int yaffs_set_error(int error);
311
312 /* Trace control functions */
313 unsigned  yaffs_set_trace(unsigned tm);
314 unsigned  yaffs_get_trace(void);
315
316
317 #ifdef __cplusplus
318 }
319 #endif
320
321
322 #endif