diff options
Diffstat (limited to 'fs/erofs/internal.h')
| -rw-r--r-- | fs/erofs/internal.h | 55 | 
1 files changed, 49 insertions, 6 deletions
| diff --git a/fs/erofs/internal.h b/fs/erofs/internal.h index 3265688af7f9..b8272fb95fd6 100644 --- a/fs/erofs/internal.h +++ b/fs/erofs/internal.h @@ -51,17 +51,24 @@ struct erofs_device_info {  	char *path;  	struct block_device *bdev;  	struct dax_device *dax_dev; +	u64 dax_part_off;  	u32 blocks;  	u32 mapped_blkaddr;  }; +enum { +	EROFS_SYNC_DECOMPRESS_AUTO, +	EROFS_SYNC_DECOMPRESS_FORCE_ON, +	EROFS_SYNC_DECOMPRESS_FORCE_OFF +}; +  struct erofs_mount_opts {  #ifdef CONFIG_EROFS_FS_ZIP  	/* current strategy of how to use managed cache */  	unsigned char cache_strategy; -	/* strategy of sync decompression (false - auto, true - force on) */ -	bool readahead_sync_decompress; +	/* strategy of sync decompression (0 - auto, 1 - force on, 2 - force off) */ +	unsigned int sync_decompress;  	/* threshold for decompression synchronously */  	unsigned int max_sync_decompress_pages; @@ -109,6 +116,7 @@ struct erofs_sb_info {  #endif	/* CONFIG_EROFS_FS_ZIP */  	struct erofs_dev_context *devs;  	struct dax_device *dax_dev; +	u64 dax_part_off;  	u64 total_blocks;  	u32 primarydevice_blocks; @@ -134,6 +142,10 @@ struct erofs_sb_info {  	u8 volume_name[16];             /* volume name */  	u32 feature_compat;  	u32 feature_incompat; + +	/* sysfs support */ +	struct kobject s_kobj;		/* /sys/fs/erofs/<devname> */ +	struct completion s_kobj_unregister;  };  #define EROFS_SB(sb) ((struct erofs_sb_info *)(sb)->s_fs_info) @@ -241,6 +253,19 @@ static inline int erofs_wait_on_workgroup_freezed(struct erofs_workgroup *grp)  #error erofs cannot be used in this platform  #endif +enum erofs_kmap_type { +	EROFS_NO_KMAP,		/* don't map the buffer */ +	EROFS_KMAP,		/* use kmap() to map the buffer */ +	EROFS_KMAP_ATOMIC,	/* use kmap_atomic() to map the buffer */ +}; + +struct erofs_buf { +	struct page *page; +	void *base; +	enum erofs_kmap_type kmap_type; +}; +#define __EROFS_BUF_INITIALIZER	((struct erofs_buf){ .page = NULL }) +  #define ROOT_NID(sb)		((sb)->root_nid)  #define erofs_blknr(addr)       ((addr) / EROFS_BLKSIZ) @@ -258,10 +283,13 @@ static inline bool erofs_sb_has_##name(struct erofs_sb_info *sbi) \  	return sbi->feature_##compat & EROFS_FEATURE_##feature; \  } -EROFS_FEATURE_FUNCS(lz4_0padding, incompat, INCOMPAT_LZ4_0PADDING) +EROFS_FEATURE_FUNCS(zero_padding, incompat, INCOMPAT_ZERO_PADDING)  EROFS_FEATURE_FUNCS(compr_cfgs, incompat, INCOMPAT_COMPR_CFGS)  EROFS_FEATURE_FUNCS(big_pcluster, incompat, INCOMPAT_BIG_PCLUSTER) +EROFS_FEATURE_FUNCS(chunked_file, incompat, INCOMPAT_CHUNKED_FILE)  EROFS_FEATURE_FUNCS(device_table, incompat, INCOMPAT_DEVICE_TABLE) +EROFS_FEATURE_FUNCS(compr_head2, incompat, INCOMPAT_COMPR_HEAD2) +EROFS_FEATURE_FUNCS(ztailpacking, incompat, INCOMPAT_ZTAILPACKING)  EROFS_FEATURE_FUNCS(sb_chksum, compat, COMPAT_SB_CHKSUM)  /* atomic flag definitions */ @@ -296,6 +324,9 @@ struct erofs_inode {  			unsigned short z_advise;  			unsigned char  z_algorithmtype[2];  			unsigned char  z_logical_clusterbits; +			unsigned long  z_tailextent_headlcn; +			unsigned int   z_idataoff; +			unsigned short z_idata_size;  		};  #endif	/* CONFIG_EROFS_FS_ZIP */  	}; @@ -390,14 +421,14 @@ enum {  #define EROFS_MAP_FULL_MAPPED	(1 << BH_FullMapped)  struct erofs_map_blocks { +	struct erofs_buf buf; +  	erofs_off_t m_pa, m_la;  	u64 m_plen, m_llen;  	unsigned short m_deviceid;  	char m_algorithmformat;  	unsigned int m_flags; - -	struct page *mpage;  };  /* Flags used by erofs_map_blocks_flatmode() */ @@ -409,6 +440,8 @@ struct erofs_map_blocks {  #define EROFS_GET_BLOCKS_FIEMAP	0x0002  /* Used to map the whole extent if non-negligible data is requested for LZMA */  #define EROFS_GET_BLOCKS_READMORE	0x0004 +/* Used to map tail extent for tailpacking inline pcluster */ +#define EROFS_GET_BLOCKS_FINDTAIL	0x0008  enum {  	Z_EROFS_COMPRESSION_SHIFTED = Z_EROFS_COMPRESSION_MAX, @@ -436,6 +469,7 @@ static inline int z_erofs_map_blocks_iter(struct inode *inode,  struct erofs_map_dev {  	struct block_device *m_bdev;  	struct dax_device *m_daxdev; +	u64 m_dax_part_off;  	erofs_off_t m_pa;  	unsigned int m_deviceid; @@ -443,7 +477,10 @@ struct erofs_map_dev {  /* data.c */  extern const struct file_operations erofs_file_fops; -struct page *erofs_get_meta_page(struct super_block *sb, erofs_blk_t blkaddr); +void erofs_unmap_metabuf(struct erofs_buf *buf); +void erofs_put_metabuf(struct erofs_buf *buf); +void *erofs_read_metabuf(struct erofs_buf *buf, struct super_block *sb, +			 erofs_blk_t blkaddr, enum erofs_kmap_type type);  int erofs_map_dev(struct super_block *sb, struct erofs_map_dev *dev);  int erofs_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,  		 u64 start, u64 len); @@ -498,6 +535,12 @@ int erofs_pcpubuf_growsize(unsigned int nrpages);  void erofs_pcpubuf_init(void);  void erofs_pcpubuf_exit(void); +/* sysfs.c */ +int erofs_register_sysfs(struct super_block *sb); +void erofs_unregister_sysfs(struct super_block *sb); +int __init erofs_init_sysfs(void); +void erofs_exit_sysfs(void); +  /* utils.c / zdata.c */  struct page *erofs_allocpage(struct page **pagepool, gfp_t gfp);  static inline void erofs_pagepool_add(struct page **pagepool, |