Lines Matching refs:sbi

200 static inline struct f2fs_super_block *F2FS_RAW_SUPER(struct f2fs_sb_info *sbi)  in F2FS_RAW_SUPER()  argument
202 return (struct f2fs_super_block *)(sbi->raw_super); in F2FS_RAW_SUPER()
205 static inline struct f2fs_checkpoint *F2FS_CKPT(struct f2fs_sb_info *sbi) in F2FS_CKPT() argument
207 return (struct f2fs_checkpoint *)(sbi->ckpt); in F2FS_CKPT()
210 static inline struct f2fs_fsck *F2FS_FSCK(struct f2fs_sb_info *sbi) in F2FS_FSCK() argument
212 return (struct f2fs_fsck *)(sbi->fsck); in F2FS_FSCK()
215 static inline struct f2fs_nm_info *NM_I(struct f2fs_sb_info *sbi) in NM_I() argument
217 return (struct f2fs_nm_info *)(sbi->nm_info); in NM_I()
220 static inline struct f2fs_sm_info *SM_I(struct f2fs_sb_info *sbi) in SM_I() argument
222 return (struct f2fs_sm_info *)(sbi->sm_info); in SM_I()
225 static inline struct sit_info *SIT_I(struct f2fs_sb_info *sbi) in SIT_I() argument
227 return (struct sit_info *)(SM_I(sbi)->sit_info); in SIT_I()
249 static inline unsigned long __bitmap_size(struct f2fs_sb_info *sbi, int flag) in __bitmap_size() argument
251 struct f2fs_checkpoint *ckpt = F2FS_CKPT(sbi); in __bitmap_size()
262 static inline block_t __cp_payload(struct f2fs_sb_info *sbi) in __cp_payload() argument
264 return le32_to_cpu(F2FS_RAW_SUPER(sbi)->cp_payload); in __cp_payload()
267 static inline void *__bitmap_ptr(struct f2fs_sb_info *sbi, int flag) in __bitmap_ptr() argument
269 struct f2fs_checkpoint *ckpt = F2FS_CKPT(sbi); in __bitmap_ptr()
278 if (le32_to_cpu(F2FS_RAW_SUPER(sbi)->cp_payload) > 0) { in __bitmap_ptr()
290 static inline block_t __start_cp_addr(struct f2fs_sb_info *sbi) in __start_cp_addr() argument
292 block_t start_addr = le32_to_cpu(F2FS_RAW_SUPER(sbi)->cp_blkaddr); in __start_cp_addr()
294 if (sbi->cur_cp == 2) in __start_cp_addr()
295 start_addr += sbi->blocks_per_seg; in __start_cp_addr()
299 static inline block_t __start_sum_addr(struct f2fs_sb_info *sbi) in __start_sum_addr() argument
301 return le32_to_cpu(F2FS_CKPT(sbi)->cp_pack_start_sum); in __start_sum_addr()
304 static inline block_t __end_block_addr(struct f2fs_sb_info *sbi) in __end_block_addr() argument
306 block_t end = SM_I(sbi)->main_blkaddr; in __end_block_addr()
307 return end + le64_to_cpu(F2FS_RAW_SUPER(sbi)->block_count); in __end_block_addr()
310 #define GET_ZONENO_FROM_SEGNO(sbi, segno) \ argument
311 ((segno / sbi->segs_per_sec) / sbi->secs_per_zone)
321 #define GET_SUM_BLKADDR(sbi, segno) \ argument
322 ((sbi->sm_info->ssa_blkaddr) + segno)
324 #define GET_SEGOFF_FROM_SEG0(sbi, blk_addr) \ argument
325 ((blk_addr) - SM_I(sbi)->seg0_blkaddr)
327 #define GET_SEGNO_FROM_SEG0(sbi, blk_addr) \ argument
328 (GET_SEGOFF_FROM_SEG0(sbi, blk_addr) >> sbi->log_blocks_per_seg)
330 #define GET_BLKOFF_FROM_SEG0(sbi, blk_addr) \ argument
331 (GET_SEGOFF_FROM_SEG0(sbi, blk_addr) & (sbi->blocks_per_seg - 1))
333 #define FREE_I_START_SEGNO(sbi) \ argument
334 GET_SEGNO_FROM_SEG0(sbi, SM_I(sbi)->main_blkaddr)
335 #define GET_R2L_SEGNO(sbi, segno) (segno + FREE_I_START_SEGNO(sbi)) argument
337 #define START_BLOCK(sbi, segno) (SM_I(sbi)->main_blkaddr + \ argument
338 ((segno) << sbi->log_blocks_per_seg))
340 static inline struct curseg_info *CURSEG_I(struct f2fs_sb_info *sbi, int type) in CURSEG_I() argument
342 return (struct curseg_info *)(SM_I(sbi)->curseg_array + type); in CURSEG_I()
345 static inline block_t start_sum_block(struct f2fs_sb_info *sbi) in start_sum_block() argument
347 return __start_cp_addr(sbi) + le32_to_cpu(F2FS_CKPT(sbi)->cp_pack_start_sum); in start_sum_block()
350 static inline block_t sum_blk_addr(struct f2fs_sb_info *sbi, int base, int type) in sum_blk_addr() argument
352 return __start_cp_addr(sbi) + le32_to_cpu(F2FS_CKPT(sbi)->cp_pack_total_block_count) in sum_blk_addr()
368 #define TOTAL_SEGS(sbi) (SM_I(sbi)->main_segments) argument
370 static inline bool IS_VALID_NID(struct f2fs_sb_info *sbi, u32 nid) in IS_VALID_NID() argument
373 le32_to_cpu(F2FS_RAW_SUPER(sbi)->segment_count_nat) in IS_VALID_NID()
374 << (sbi->log_blocks_per_seg - 1))); in IS_VALID_NID()
377 static inline bool IS_VALID_BLK_ADDR(struct f2fs_sb_info *sbi, u32 addr) in IS_VALID_BLK_ADDR() argument
382 if (addr >= le64_to_cpu(F2FS_RAW_SUPER(sbi)->block_count) || in IS_VALID_BLK_ADDR()
383 addr < SM_I(sbi)->main_blkaddr) { in IS_VALID_BLK_ADDR()
391 static inline int IS_CUR_SEGNO(struct f2fs_sb_info *sbi, u32 segno) in IS_CUR_SEGNO() argument
396 struct curseg_info *curseg = CURSEG_I(sbi, i); in IS_CUR_SEGNO()
404 static inline u64 BLKOFF_FROM_MAIN(struct f2fs_sb_info *sbi, u64 blk_addr) in BLKOFF_FROM_MAIN() argument
406 ASSERT(blk_addr >= SM_I(sbi)->main_blkaddr); in BLKOFF_FROM_MAIN()
407 return blk_addr - SM_I(sbi)->main_blkaddr; in BLKOFF_FROM_MAIN()
410 static inline u32 GET_SEGNO(struct f2fs_sb_info *sbi, u64 blk_addr) in GET_SEGNO() argument
412 return (u32)(BLKOFF_FROM_MAIN(sbi, blk_addr) in GET_SEGNO()
413 >> sbi->log_blocks_per_seg); in GET_SEGNO()
416 static inline u32 OFFSET_IN_SEG(struct f2fs_sb_info *sbi, u64 blk_addr) in OFFSET_IN_SEG() argument
418 return (u32)(BLKOFF_FROM_MAIN(sbi, blk_addr) in OFFSET_IN_SEG()
419 % (1 << sbi->log_blocks_per_seg)); in OFFSET_IN_SEG()
465 extern int lookup_nat_in_journal(struct f2fs_sb_info *sbi, u32 nid, struct f2fs_nat_entry *ne);