提交 c6e07188 编写于 作者: R Ryusuke Konishi

nilfs2: get rid of mi_nilfs back pointer to nilfs object

This removes a back pointer to nilfs object from nilfs_mdt_info
structure that is attached to metadata files.
Signed-off-by: NRyusuke Konishi <konishi.ryusuke@lab.ntt.co.jp>
上级 032dbb3b
...@@ -78,7 +78,7 @@ static int nilfs_mdt_create_block(struct inode *inode, unsigned long block, ...@@ -78,7 +78,7 @@ static int nilfs_mdt_create_block(struct inode *inode, unsigned long block,
struct buffer_head *, struct buffer_head *,
void *)) void *))
{ {
struct the_nilfs *nilfs = NILFS_MDT(inode)->mi_nilfs; struct the_nilfs *nilfs = NILFS_I_NILFS(inode);
struct super_block *sb = inode->i_sb; struct super_block *sb = inode->i_sb;
struct nilfs_transaction_info ti; struct nilfs_transaction_info ti;
struct buffer_head *bh; struct buffer_head *bh;
...@@ -167,9 +167,7 @@ nilfs_mdt_submit_block(struct inode *inode, unsigned long blkoff, ...@@ -167,9 +167,7 @@ nilfs_mdt_submit_block(struct inode *inode, unsigned long blkoff,
unlock_buffer(bh); unlock_buffer(bh);
goto failed_bh; goto failed_bh;
} }
bh->b_bdev = NILFS_MDT(inode)->mi_nilfs->ns_bdev; map_bh(bh, inode->i_sb, (sector_t)blknum);
bh->b_blocknr = (sector_t)blknum;
set_buffer_mapped(bh);
bh->b_end_io = end_buffer_read_sync; bh->b_end_io = end_buffer_read_sync;
get_bh(bh); get_bh(bh);
...@@ -412,7 +410,7 @@ nilfs_mdt_write_page(struct page *page, struct writeback_control *wbc) ...@@ -412,7 +410,7 @@ nilfs_mdt_write_page(struct page *page, struct writeback_control *wbc)
return 0; return 0;
sb = inode->i_sb; sb = inode->i_sb;
nilfs = NILFS_MDT(inode)->mi_nilfs; nilfs = NILFS_SB(sb)->s_nilfs;
if (!sb) { if (!sb) {
down_read(&nilfs->ns_writer_sem); down_read(&nilfs->ns_writer_sem);
...@@ -452,7 +450,6 @@ int nilfs_mdt_init(struct inode *inode, gfp_t gfp_mask, size_t objsz) ...@@ -452,7 +450,6 @@ int nilfs_mdt_init(struct inode *inode, gfp_t gfp_mask, size_t objsz)
if (!mi) if (!mi)
return -ENOMEM; return -ENOMEM;
mi->mi_nilfs = NILFS_I_NILFS(inode);
init_rwsem(&mi->mi_sem); init_rwsem(&mi->mi_sem);
inode->i_private = mi; inode->i_private = mi;
......
...@@ -37,7 +37,6 @@ struct nilfs_shadow_map { ...@@ -37,7 +37,6 @@ struct nilfs_shadow_map {
/** /**
* struct nilfs_mdt_info - on-memory private data of meta data files * struct nilfs_mdt_info - on-memory private data of meta data files
* @mi_nilfs: back pointer to the_nilfs struct
* @mi_sem: reader/writer semaphore for meta data operations * @mi_sem: reader/writer semaphore for meta data operations
* @mi_bgl: per-blockgroup locking * @mi_bgl: per-blockgroup locking
* @mi_entry_size: size of an entry * @mi_entry_size: size of an entry
...@@ -49,7 +48,6 @@ struct nilfs_shadow_map { ...@@ -49,7 +48,6 @@ struct nilfs_shadow_map {
* @mi_blocks_per_desc_block: number of blocks per descriptor block * @mi_blocks_per_desc_block: number of blocks per descriptor block
*/ */
struct nilfs_mdt_info { struct nilfs_mdt_info {
struct the_nilfs *mi_nilfs;
struct rw_semaphore mi_sem; struct rw_semaphore mi_sem;
struct blockgroup_lock *mi_bgl; struct blockgroup_lock *mi_bgl;
unsigned mi_entry_size; unsigned mi_entry_size;
...@@ -68,9 +66,7 @@ static inline struct nilfs_mdt_info *NILFS_MDT(const struct inode *inode) ...@@ -68,9 +66,7 @@ static inline struct nilfs_mdt_info *NILFS_MDT(const struct inode *inode)
static inline struct the_nilfs *NILFS_I_NILFS(struct inode *inode) static inline struct the_nilfs *NILFS_I_NILFS(struct inode *inode)
{ {
struct super_block *sb = inode->i_sb; return NILFS_SB(inode->i_sb)->s_nilfs;
return sb ? NILFS_SB(sb)->s_nilfs : NILFS_MDT(inode)->mi_nilfs;
} }
/* Default GFP flags using highmem */ /* Default GFP flags using highmem */
...@@ -117,7 +113,7 @@ static inline void nilfs_mdt_clear_dirty(struct inode *inode) ...@@ -117,7 +113,7 @@ static inline void nilfs_mdt_clear_dirty(struct inode *inode)
static inline __u64 nilfs_mdt_cno(struct inode *inode) static inline __u64 nilfs_mdt_cno(struct inode *inode)
{ {
return NILFS_MDT(inode)->mi_nilfs->ns_cno; return NILFS_I_NILFS(inode)->ns_cno;
} }
#define nilfs_mdt_bgl_lock(inode, bg) \ #define nilfs_mdt_bgl_lock(inode, bg) \
......
...@@ -505,7 +505,7 @@ int nilfs_sufile_get_stat(struct inode *sufile, struct nilfs_sustat *sustat) ...@@ -505,7 +505,7 @@ int nilfs_sufile_get_stat(struct inode *sufile, struct nilfs_sustat *sustat)
{ {
struct buffer_head *header_bh; struct buffer_head *header_bh;
struct nilfs_sufile_header *header; struct nilfs_sufile_header *header;
struct the_nilfs *nilfs = NILFS_MDT(sufile)->mi_nilfs; struct the_nilfs *nilfs = NILFS_I_NILFS(sufile);
void *kaddr; void *kaddr;
int ret; int ret;
...@@ -583,7 +583,7 @@ ssize_t nilfs_sufile_get_suinfo(struct inode *sufile, __u64 segnum, void *buf, ...@@ -583,7 +583,7 @@ ssize_t nilfs_sufile_get_suinfo(struct inode *sufile, __u64 segnum, void *buf,
struct nilfs_segment_usage *su; struct nilfs_segment_usage *su;
struct nilfs_suinfo *si = buf; struct nilfs_suinfo *si = buf;
size_t susz = NILFS_MDT(sufile)->mi_entry_size; size_t susz = NILFS_MDT(sufile)->mi_entry_size;
struct the_nilfs *nilfs = NILFS_MDT(sufile)->mi_nilfs; struct the_nilfs *nilfs = NILFS_I_NILFS(sufile);
void *kaddr; void *kaddr;
unsigned long nsegs, segusages_per_block; unsigned long nsegs, segusages_per_block;
ssize_t n; ssize_t n;
......
...@@ -31,7 +31,7 @@ ...@@ -31,7 +31,7 @@
static inline unsigned long nilfs_sufile_get_nsegments(struct inode *sufile) static inline unsigned long nilfs_sufile_get_nsegments(struct inode *sufile)
{ {
return NILFS_MDT(sufile)->mi_nilfs->ns_nsegments; return NILFS_I_NILFS(sufile)->ns_nsegments;
} }
unsigned long nilfs_sufile_get_ncleansegs(struct inode *sufile); unsigned long nilfs_sufile_get_ncleansegs(struct inode *sufile);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册