aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/nilfs2/sufile.c72
-rw-r--r--fs/nilfs2/sufile.h5
2 files changed, 0 insertions, 77 deletions
diff --git a/fs/nilfs2/sufile.c b/fs/nilfs2/sufile.c
index 3eed998df1c8..b6c36d0cc331 100644
--- a/fs/nilfs2/sufile.c
+++ b/fs/nilfs2/sufile.c
@@ -430,78 +430,6 @@ void nilfs_sufile_do_free(struct inode *sufile, __u64 segnum,
430} 430}
431 431
432/** 432/**
433 * nilfs_sufile_get_segment_usage - get a segment usage
434 * @sufile: inode of segment usage file
435 * @segnum: segment number
436 * @sup: pointer to segment usage
437 * @bhp: pointer to buffer head
438 *
439 * Description: nilfs_sufile_get_segment_usage() acquires the segment usage
440 * specified by @segnum.
441 *
442 * Return Value: On success, 0 is returned, and the segment usage and the
443 * buffer head of the buffer on which the segment usage is located are stored
444 * in the place pointed by @sup and @bhp, respectively. On error, one of the
445 * following negative error codes is returned.
446 *
447 * %-EIO - I/O error.
448 *
449 * %-ENOMEM - Insufficient amount of memory available.
450 *
451 * %-EINVAL - Invalid segment usage number.
452 */
453int nilfs_sufile_get_segment_usage(struct inode *sufile, __u64 segnum,
454 struct nilfs_segment_usage **sup,
455 struct buffer_head **bhp)
456{
457 struct buffer_head *bh;
458 struct nilfs_segment_usage *su;
459 void *kaddr;
460 int ret;
461
462 /* segnum is 0 origin */
463 if (segnum >= nilfs_sufile_get_nsegments(sufile))
464 return -EINVAL;
465 down_write(&NILFS_MDT(sufile)->mi_sem);
466 ret = nilfs_sufile_get_segment_usage_block(sufile, segnum, 1, &bh);
467 if (ret < 0)
468 goto out_sem;
469 kaddr = kmap(bh->b_page);
470 su = nilfs_sufile_block_get_segment_usage(sufile, segnum, bh, kaddr);
471 if (nilfs_segment_usage_error(su)) {
472 kunmap(bh->b_page);
473 brelse(bh);
474 ret = -EINVAL;
475 goto out_sem;
476 }
477
478 if (sup != NULL)
479 *sup = su;
480 *bhp = bh;
481
482 out_sem:
483 up_write(&NILFS_MDT(sufile)->mi_sem);
484 return ret;
485}
486
487/**
488 * nilfs_sufile_put_segment_usage - put a segment usage
489 * @sufile: inode of segment usage file
490 * @segnum: segment number
491 * @bh: buffer head
492 *
493 * Description: nilfs_sufile_put_segment_usage() releases the segment usage
494 * specified by @segnum. @bh must be the buffer head which have been returned
495 * by a previous call to nilfs_sufile_get_segment_usage() with @segnum.
496 */
497void nilfs_sufile_put_segment_usage(struct inode *sufile, __u64 segnum,
498 struct buffer_head *bh)
499{
500 kunmap(bh->b_page);
501 brelse(bh);
502}
503
504/**
505 * nilfs_sufile_mark_dirty - mark the buffer having a segment usage dirty 433 * nilfs_sufile_mark_dirty - mark the buffer having a segment usage dirty
506 * @sufile: inode of segment usage file 434 * @sufile: inode of segment usage file
507 * @segnum: segment number 435 * @segnum: segment number
diff --git a/fs/nilfs2/sufile.h b/fs/nilfs2/sufile.h
index e1186bf3b964..15163b8aff7d 100644
--- a/fs/nilfs2/sufile.h
+++ b/fs/nilfs2/sufile.h
@@ -37,11 +37,6 @@ static inline unsigned long nilfs_sufile_get_nsegments(struct inode *sufile)
37unsigned long nilfs_sufile_get_ncleansegs(struct inode *sufile); 37unsigned long nilfs_sufile_get_ncleansegs(struct inode *sufile);
38 38
39int nilfs_sufile_alloc(struct inode *, __u64 *); 39int nilfs_sufile_alloc(struct inode *, __u64 *);
40int nilfs_sufile_get_segment_usage(struct inode *, __u64,
41 struct nilfs_segment_usage **,
42 struct buffer_head **);
43void nilfs_sufile_put_segment_usage(struct inode *, __u64,
44 struct buffer_head *);
45int nilfs_sufile_mark_dirty(struct inode *sufile, __u64 segnum); 40int nilfs_sufile_mark_dirty(struct inode *sufile, __u64 segnum);
46int nilfs_sufile_set_segment_usage(struct inode *sufile, __u64 segnum, 41int nilfs_sufile_set_segment_usage(struct inode *sufile, __u64 segnum,
47 unsigned long nblocks, time_t modtime); 42 unsigned long nblocks, time_t modtime);