2007-04-25 17:16:47 +04:00
/*
* JFFS2 - - Journalling Flash File System , Version 2.
*
* Copyright © 2001 - 2007 Red Hat , Inc .
2010-08-08 17:15:22 +04:00
* Copyright © 2004 - 2010 David Woodhouse < dwmw2 @ infradead . org >
2007-04-25 17:16:47 +04:00
*
* Created by David Woodhouse < dwmw2 @ infradead . org >
*
* For licensing information , see the file ' LICENCE ' in this directory .
*
*/
2005-04-17 02:20:36 +04:00
# ifndef _JFFS2_FS_SB
# define _JFFS2_FS_SB
# include <linux/types.h>
# include <linux/spinlock.h>
# include <linux/workqueue.h>
# include <linux/completion.h>
2008-04-22 18:13:40 +04:00
# include <linux/mutex.h>
2005-04-17 02:20:36 +04:00
# include <linux/timer.h>
# include <linux/wait.h>
# include <linux/list.h>
# include <linux/rwsem.h>
# define JFFS2_SB_FLAG_RO 1
2005-02-28 11:21:09 +03:00
# define JFFS2_SB_FLAG_SCANNING 2 /* Flash scanning is in progress */
# define JFFS2_SB_FLAG_BUILDING 4 /* File system building is in progress */
2005-04-17 02:20:36 +04:00
struct jffs2_inodirty ;
2011-10-17 05:15:16 +04:00
struct jffs2_mount_opts {
bool override_compr ;
unsigned int compr ;
2012-04-11 01:22:35 +04:00
/* The size of the reserved pool. The reserved pool is the JFFS2 flash
* space which may only be used by root cannot be used by the other
* users . This is implemented simply by means of not allowing the
* latter users to write to the file system if the amount if the
* available space is less then ' rp_size ' . */
unsigned int rp_size ;
2011-10-17 05:15:16 +04:00
} ;
2005-04-17 02:20:36 +04:00
/* A struct for the overall file system control. Pointers to
2005-11-07 14:16:07 +03:00
jffs2_sb_info structs are named ` c ' in the source code .
2005-04-17 02:20:36 +04:00
Nee jffs_control
*/
struct jffs2_sb_info {
struct mtd_info * mtd ;
uint32_t highest_ino ;
uint32_t checked_ino ;
unsigned int flags ;
struct task_struct * gc_task ; /* GC task struct */
2005-05-19 20:18:11 +04:00
struct completion gc_thread_start ; /* GC thread start completion */
2005-04-17 02:20:36 +04:00
struct completion gc_thread_exit ; /* GC thread exit completion port */
2008-04-22 18:13:40 +04:00
struct mutex alloc_sem ; /* Used to protect all the following
2005-04-17 02:20:36 +04:00
fields , and also to protect against
out - of - order writing of nodes . And GC . */
uint32_t cleanmarker_size ; /* Size of an _inline_ CLEANMARKER
( i . e . zero for OOB CLEANMARKER */
uint32_t flash_size ;
uint32_t used_size ;
uint32_t dirty_size ;
uint32_t wasted_size ;
uint32_t free_size ;
uint32_t erasing_size ;
uint32_t bad_size ;
uint32_t sector_size ;
uint32_t unchecked_size ;
uint32_t nr_free_blocks ;
uint32_t nr_erasing_blocks ;
/* Number of free blocks there must be before we... */
uint8_t resv_blocks_write ; /* ... allow a normal filesystem write */
uint8_t resv_blocks_deletion ; /* ... allow a normal filesystem deletion */
uint8_t resv_blocks_gctrigger ; /* ... wake up the GC thread */
uint8_t resv_blocks_gcbad ; /* ... pick a block from the bad_list to GC */
uint8_t resv_blocks_gcmerge ; /* ... merge pages when garbage collecting */
2007-10-06 23:12:58 +04:00
/* Number of 'very dirty' blocks before we trigger immediate GC */
uint8_t vdirty_blocks_gctrigger ;
2005-04-17 02:20:36 +04:00
uint32_t nospc_dirty_size ;
uint32_t nr_blocks ;
2005-11-07 14:16:07 +03:00
struct jffs2_eraseblock * blocks ; /* The whole array of blocks. Used for getting blocks
2005-04-17 02:20:36 +04:00
* from the offset ( blocks [ ofs / sector_size ] ) */
struct jffs2_eraseblock * nextblock ; /* The block we're currently filling */
struct jffs2_eraseblock * gcblock ; /* The block we're currently garbage-collecting */
struct list_head clean_list ; /* Blocks 100% full of clean data */
struct list_head very_dirty_list ; /* Blocks with lots of dirty space */
struct list_head dirty_list ; /* Blocks with some dirty space */
struct list_head erasable_list ; /* Blocks which are completely dirty, and need erasing */
struct list_head erasable_pending_wbuf_list ; /* Blocks which need erasing but only after the current wbuf is flushed */
struct list_head erasing_list ; /* Blocks which are currently erasing */
2008-04-23 17:15:24 +04:00
struct list_head erase_checking_list ; /* Blocks which are being checked and marked */
2005-04-17 02:20:36 +04:00
struct list_head erase_pending_list ; /* Blocks which need erasing now */
struct list_head erase_complete_list ; /* Blocks which are erased and need the clean marker written to them */
struct list_head free_list ; /* Blocks which are free and ready to be used */
struct list_head bad_list ; /* Bad blocks. */
struct list_head bad_used_list ; /* Bad blocks with valid data in. */
2005-11-07 14:16:07 +03:00
spinlock_t erase_completion_lock ; /* Protect free_list and erasing_list
2005-04-17 02:20:36 +04:00
against erase completion handler */
wait_queue_head_t erase_wait ; /* For waiting for erases to complete */
wait_queue_head_t inocache_wq ;
2010-10-07 22:14:02 +04:00
int inocache_hashsize ;
2005-04-17 02:20:36 +04:00
struct jffs2_inode_cache * * inocache_list ;
spinlock_t inocache_lock ;
2005-11-07 14:16:07 +03:00
2005-04-17 02:20:36 +04:00
/* Sem to allow jffs2_garbage_collect_deletion_dirent to
2005-11-07 14:16:07 +03:00
drop the erase_completion_lock while it ' s holding a pointer
2005-04-17 02:20:36 +04:00
to an obsoleted node . I don ' t like this . Alternatives welcomed . */
2008-04-22 18:13:40 +04:00
struct mutex erase_free_sem ;
2005-04-17 02:20:36 +04:00
2005-09-22 15:25:00 +04:00
uint32_t wbuf_pagesize ; /* 0 for NOR and other flashes with no wbuf */
2005-11-07 14:16:07 +03:00
2007-07-11 17:23:54 +04:00
# ifdef CONFIG_JFFS2_FS_WBUF_VERIFY
unsigned char * wbuf_verify ; /* read-back buffer for verification */
# endif
2005-02-09 12:24:26 +03:00
# ifdef CONFIG_JFFS2_FS_WRITEBUFFER
2007-01-31 12:38:53 +03:00
unsigned char * wbuf ; /* Write-behind buffer for NAND flash */
2005-04-17 02:20:36 +04:00
uint32_t wbuf_ofs ;
uint32_t wbuf_len ;
struct jffs2_inodirty * wbuf_inodes ;
struct rw_semaphore wbuf_sem ; /* Protects the write buffer */
2012-05-07 20:02:46 +04:00
struct delayed_work wbuf_dwork ; /* write-buffer write-out work */
int wbuf_queued ; /* non-zero delayed work is queued */
spinlock_t wbuf_dwork_lock ; /* protects wbuf_dwork and and wbuf_queued */
2007-01-31 12:38:53 +03:00
unsigned char * oobbuf ;
int oobavail ; /* How many bytes are available for JFFS2 in OOB */
2005-04-17 02:20:36 +04:00
# endif
2005-09-07 12:35:26 +04:00
struct jffs2_summary * summary ; /* Summary information */
2011-10-17 05:15:16 +04:00
struct jffs2_mount_opts mount_opts ;
2005-09-07 12:35:26 +04:00
2006-05-13 10:09:47 +04:00
# ifdef CONFIG_JFFS2_FS_XATTR
# define XATTRINDEX_HASHSIZE (57)
uint32_t highest_xid ;
2006-06-11 05:35:15 +04:00
uint32_t highest_xseqno ;
2006-05-13 10:09:47 +04:00
struct list_head xattrindex [ XATTRINDEX_HASHSIZE ] ;
struct list_head xattr_unchecked ;
2006-06-11 05:35:15 +04:00
struct list_head xattr_dead_list ;
struct jffs2_xattr_ref * xref_dead_list ;
2006-05-13 10:15:07 +04:00
struct jffs2_xattr_ref * xref_temp ;
2006-05-13 10:09:47 +04:00
struct rw_semaphore xattr_sem ;
uint32_t xdatum_mem_usage ;
uint32_t xdatum_mem_threshold ;
# endif
2005-04-17 02:20:36 +04:00
/* OS-private pointer for getting back to master superblock info */
void * os_priv ;
} ;
2010-11-15 21:20:05 +03:00
# endif /* _JFFS2_FS_SB */