2  * Copyright (C) Sistina Software, Inc.  1997-2003 All rights reserved.
 
   3  * Copyright (C) 2004-2007 Red Hat, Inc.  All rights reserved.
 
   5  * This copyrighted material is made available to anyone wishing to use,
 
   6  * modify, copy, or redistribute it subject to the terms and conditions
 
   7  * of the GNU General Public License version 2.
 
  10 #include <linux/sched.h>
 
  11 #include <linux/slab.h>
 
  12 #include <linux/spinlock.h>
 
  13 #include <linux/completion.h>
 
  14 #include <linux/buffer_head.h>
 
  15 #include <linux/gfs2_ondisk.h>
 
  16 #include <linux/crc32.h>
 
  17 #include <linux/lm_interface.h>
 
  18 #include <linux/delay.h>
 
  19 #include <linux/kthread.h>
 
  20 #include <linux/freezer.h>
 
  35  * gfs2_struct2blk - compute stuff
 
  36  * @sdp: the filesystem
 
  37  * @nstruct: the number of structures
 
  38  * @ssize: the size of the structures
 
  40  * Compute the number of log descriptor blocks needed to hold a certain number
 
  41  * of structures of a certain size.
 
  43  * Returns: the number of blocks needed (minimum is always 1)
 
  46 unsigned int gfs2_struct2blk(struct gfs2_sbd *sdp, unsigned int nstruct,
 
  50         unsigned int first, second;
 
  53         first = (sdp->sd_sb.sb_bsize - sizeof(struct gfs2_log_descriptor)) / ssize;
 
  55         if (nstruct > first) {
 
  56                 second = (sdp->sd_sb.sb_bsize -
 
  57                           sizeof(struct gfs2_meta_header)) / ssize;
 
  58                 blks += DIV_ROUND_UP(nstruct - first, second);
 
  65  * gfs2_remove_from_ail - Remove an entry from the ail lists, updating counters
 
  66  * @mapping: The associated mapping (maybe NULL)
 
  67  * @bd: The gfs2_bufdata to remove
 
  69  * The log lock _must_ be held when calling this function
 
  73 void gfs2_remove_from_ail(struct gfs2_bufdata *bd)
 
  76         list_del_init(&bd->bd_ail_st_list);
 
  77         list_del_init(&bd->bd_ail_gl_list);
 
  78         atomic_dec(&bd->bd_gl->gl_ail_count);
 
  83  * gfs2_ail1_start_one - Start I/O on a part of the AIL
 
  84  * @sdp: the filesystem
 
  85  * @tr: the part of the AIL
 
  89 static void gfs2_ail1_start_one(struct gfs2_sbd *sdp, struct gfs2_ail *ai)
 
  90 __releases(&sdp->sd_log_lock)
 
  91 __acquires(&sdp->sd_log_lock)
 
  93         struct gfs2_bufdata *bd, *s;
 
  94         struct buffer_head *bh;
 
 100                 list_for_each_entry_safe_reverse(bd, s, &ai->ai_ail1_list,
 
 104                         gfs2_assert(sdp, bd->bd_ail == ai);
 
 106                         if (!buffer_busy(bh)) {
 
 107                                 if (!buffer_uptodate(bh))
 
 108                                         gfs2_io_error_bh(sdp, bh);
 
 109                                 list_move(&bd->bd_ail_st_list, &ai->ai_ail2_list);
 
 113                         if (!buffer_dirty(bh))
 
 116                         list_move(&bd->bd_ail_st_list, &ai->ai_ail1_list);
 
 119                         gfs2_log_unlock(sdp);
 
 121                         if (test_clear_buffer_dirty(bh)) {
 
 122                                 bh->b_end_io = end_buffer_write_sync;
 
 123                                 submit_bh(WRITE, bh);
 
 137  * gfs2_ail1_empty_one - Check whether or not a trans in the AIL has been synced
 
 138  * @sdp: the filesystem
 
 143 static int gfs2_ail1_empty_one(struct gfs2_sbd *sdp, struct gfs2_ail *ai, int flags)
 
 145         struct gfs2_bufdata *bd, *s;
 
 146         struct buffer_head *bh;
 
 148         list_for_each_entry_safe_reverse(bd, s, &ai->ai_ail1_list,
 
 152                 gfs2_assert(sdp, bd->bd_ail == ai);
 
 154                 if (buffer_busy(bh)) {
 
 161                 if (!buffer_uptodate(bh))
 
 162                         gfs2_io_error_bh(sdp, bh);
 
 164                 list_move(&bd->bd_ail_st_list, &ai->ai_ail2_list);
 
 167         return list_empty(&ai->ai_ail1_list);
 
 170 static void gfs2_ail1_start(struct gfs2_sbd *sdp, int flags)
 
 172         struct list_head *head;
 
 174         struct list_head *first;
 
 175         struct gfs2_ail *first_ai, *ai, *tmp;
 
 179         head = &sdp->sd_ail1_list;
 
 180         if (list_empty(head)) {
 
 181                 gfs2_log_unlock(sdp);
 
 184         sync_gen = sdp->sd_ail_sync_gen++;
 
 187         first_ai = list_entry(first, struct gfs2_ail, ai_list);
 
 188         first_ai->ai_sync_gen = sync_gen;
 
 189         gfs2_ail1_start_one(sdp, first_ai); /* This may drop log lock */
 
 195                 if (first && (head->prev != first ||
 
 196                               gfs2_ail1_empty_one(sdp, first_ai, 0)))
 
 200                 list_for_each_entry_safe_reverse(ai, tmp, head, ai_list) {
 
 201                         if (ai->ai_sync_gen >= sync_gen)
 
 203                         ai->ai_sync_gen = sync_gen;
 
 204                         gfs2_ail1_start_one(sdp, ai); /* This may drop log lock */
 
 210         gfs2_log_unlock(sdp);
 
 213 static int gfs2_ail1_empty(struct gfs2_sbd *sdp, int flags)
 
 215         struct gfs2_ail *ai, *s;
 
 220         list_for_each_entry_safe_reverse(ai, s, &sdp->sd_ail1_list, ai_list) {
 
 221                 if (gfs2_ail1_empty_one(sdp, ai, flags))
 
 222                         list_move(&ai->ai_list, &sdp->sd_ail2_list);
 
 223                 else if (!(flags & DIO_ALL))
 
 227         ret = list_empty(&sdp->sd_ail1_list);
 
 229         gfs2_log_unlock(sdp);
 
 236  * gfs2_ail2_empty_one - Check whether or not a trans in the AIL has been synced
 
 237  * @sdp: the filesystem
 
 242 static void gfs2_ail2_empty_one(struct gfs2_sbd *sdp, struct gfs2_ail *ai)
 
 244         struct list_head *head = &ai->ai_ail2_list;
 
 245         struct gfs2_bufdata *bd;
 
 247         while (!list_empty(head)) {
 
 248                 bd = list_entry(head->prev, struct gfs2_bufdata,
 
 250                 gfs2_assert(sdp, bd->bd_ail == ai);
 
 251                 gfs2_remove_from_ail(bd);
 
 255 static void ail2_empty(struct gfs2_sbd *sdp, unsigned int new_tail)
 
 257         struct gfs2_ail *ai, *safe;
 
 258         unsigned int old_tail = sdp->sd_log_tail;
 
 259         int wrap = (new_tail < old_tail);
 
 264         list_for_each_entry_safe(ai, safe, &sdp->sd_ail2_list, ai_list) {
 
 265                 a = (old_tail <= ai->ai_first);
 
 266                 b = (ai->ai_first < new_tail);
 
 267                 rm = (wrap) ? (a || b) : (a && b);
 
 271                 gfs2_ail2_empty_one(sdp, ai);
 
 272                 list_del(&ai->ai_list);
 
 273                 gfs2_assert_warn(sdp, list_empty(&ai->ai_ail1_list));
 
 274                 gfs2_assert_warn(sdp, list_empty(&ai->ai_ail2_list));
 
 278         gfs2_log_unlock(sdp);
 
 282  * gfs2_log_reserve - Make a log reservation
 
 283  * @sdp: The GFS2 superblock
 
 284  * @blks: The number of blocks to reserve
 
 286  * Note that we never give out the last few blocks of the journal. Thats
 
 287  * due to the fact that there is a small number of header blocks
 
 288  * associated with each log flush. The exact number can't be known until
 
 289  * flush time, so we ensure that we have just enough free blocks at all
 
 290  * times to avoid running out during a log flush.
 
 295 int gfs2_log_reserve(struct gfs2_sbd *sdp, unsigned int blks)
 
 297         unsigned int try = 0;
 
 298         unsigned reserved_blks = 6 * (4096 / sdp->sd_vfs->s_blocksize);
 
 300         if (gfs2_assert_warn(sdp, blks) ||
 
 301             gfs2_assert_warn(sdp, blks <= sdp->sd_jdesc->jd_blocks))
 
 304         mutex_lock(&sdp->sd_log_reserve_mutex);
 
 306         while(atomic_read(&sdp->sd_log_blks_free) <= (blks + reserved_blks)) {
 
 307                 gfs2_log_unlock(sdp);
 
 308                 gfs2_ail1_empty(sdp, 0);
 
 309                 gfs2_log_flush(sdp, NULL);
 
 312                         gfs2_ail1_start(sdp, 0);
 
 315         atomic_sub(blks, &sdp->sd_log_blks_free);
 
 316         gfs2_log_unlock(sdp);
 
 317         mutex_unlock(&sdp->sd_log_reserve_mutex);
 
 319         down_read(&sdp->sd_log_flush_lock);
 
 325  * gfs2_log_release - Release a given number of log blocks
 
 326  * @sdp: The GFS2 superblock
 
 327  * @blks: The number of blocks
 
 331 void gfs2_log_release(struct gfs2_sbd *sdp, unsigned int blks)
 
 335         atomic_add(blks, &sdp->sd_log_blks_free);
 
 336         gfs2_assert_withdraw(sdp,
 
 337                              atomic_read(&sdp->sd_log_blks_free) <= sdp->sd_jdesc->jd_blocks);
 
 338         gfs2_log_unlock(sdp);
 
 339         up_read(&sdp->sd_log_flush_lock);
 
 342 static u64 log_bmap(struct gfs2_sbd *sdp, unsigned int lbn)
 
 344         struct gfs2_journal_extent *je;
 
 346         list_for_each_entry(je, &sdp->sd_jdesc->extent_list, extent_list) {
 
 347                 if (lbn >= je->lblock && lbn < je->lblock + je->blocks)
 
 348                         return je->dblock + lbn - je->lblock;
 
 355  * log_distance - Compute distance between two journal blocks
 
 356  * @sdp: The GFS2 superblock
 
 357  * @newer: The most recent journal block of the pair
 
 358  * @older: The older journal block of the pair
 
 360  *   Compute the distance (in the journal direction) between two
 
 361  *   blocks in the journal
 
 363  * Returns: the distance in blocks
 
 366 static inline unsigned int log_distance(struct gfs2_sbd *sdp, unsigned int newer,
 
 371         dist = newer - older;
 
 373                 dist += sdp->sd_jdesc->jd_blocks;
 
 379  * calc_reserved - Calculate the number of blocks to reserve when
 
 380  *                 refunding a transaction's unused buffers.
 
 381  * @sdp: The GFS2 superblock
 
 383  * This is complex.  We need to reserve room for all our currently used
 
 384  * metadata buffers (e.g. normal file I/O rewriting file time stamps) and 
 
 385  * all our journaled data buffers for journaled files (e.g. files in the 
 
 386  * meta_fs like rindex, or files for which chattr +j was done.)
 
 387  * If we don't reserve enough space, gfs2_log_refund and gfs2_log_flush
 
 388  * will count it as free space (sd_log_blks_free) and corruption will follow.
 
 390  * We can have metadata bufs and jdata bufs in the same journal.  So each
 
 391  * type gets its own log header, for which we need to reserve a block.
 
 392  * In fact, each type has the potential for needing more than one header 
 
 393  * in cases where we have more buffers than will fit on a journal page.
 
 394  * Metadata journal entries take up half the space of journaled buffer entries.
 
 395  * Thus, metadata entries have buf_limit (502) and journaled buffers have
 
 396  * databuf_limit (251) before they cause a wrap around.
 
 398  * Also, we need to reserve blocks for revoke journal entries and one for an
 
 399  * overall header for the lot.
 
 401  * Returns: the number of blocks reserved
 
 403 static unsigned int calc_reserved(struct gfs2_sbd *sdp)
 
 405         unsigned int reserved = 0;
 
 406         unsigned int mbuf_limit, metabufhdrs_needed;
 
 407         unsigned int dbuf_limit, databufhdrs_needed;
 
 408         unsigned int revokes = 0;
 
 410         mbuf_limit = buf_limit(sdp);
 
 411         metabufhdrs_needed = (sdp->sd_log_commited_buf +
 
 412                               (mbuf_limit - 1)) / mbuf_limit;
 
 413         dbuf_limit = databuf_limit(sdp);
 
 414         databufhdrs_needed = (sdp->sd_log_commited_databuf +
 
 415                               (dbuf_limit - 1)) / dbuf_limit;
 
 417         if (sdp->sd_log_commited_revoke)
 
 418                 revokes = gfs2_struct2blk(sdp, sdp->sd_log_commited_revoke,
 
 421         reserved = sdp->sd_log_commited_buf + metabufhdrs_needed +
 
 422                 sdp->sd_log_commited_databuf + databufhdrs_needed +
 
 424         /* One for the overall header */
 
 430 static unsigned int current_tail(struct gfs2_sbd *sdp)
 
 437         if (list_empty(&sdp->sd_ail1_list)) {
 
 438                 tail = sdp->sd_log_head;
 
 440                 ai = list_entry(sdp->sd_ail1_list.prev, struct gfs2_ail, ai_list);
 
 444         gfs2_log_unlock(sdp);
 
 449 void gfs2_log_incr_head(struct gfs2_sbd *sdp)
 
 451         if (sdp->sd_log_flush_head == sdp->sd_log_tail)
 
 452                 BUG_ON(sdp->sd_log_flush_head != sdp->sd_log_head);
 
 454         if (++sdp->sd_log_flush_head == sdp->sd_jdesc->jd_blocks) {
 
 455                 sdp->sd_log_flush_head = 0;
 
 456                 sdp->sd_log_flush_wrapped = 1;
 
 461  * gfs2_log_write_endio - End of I/O for a log buffer
 
 462  * @bh: The buffer head
 
 463  * @uptodate: I/O Status
 
 467 static void gfs2_log_write_endio(struct buffer_head *bh, int uptodate)
 
 469         struct gfs2_sbd *sdp = bh->b_private;
 
 470         bh->b_private = NULL;
 
 472         end_buffer_write_sync(bh, uptodate);
 
 473         if (atomic_dec_and_test(&sdp->sd_log_in_flight))
 
 474                 wake_up(&sdp->sd_log_flush_wait);
 
 478  * gfs2_log_get_buf - Get and initialize a buffer to use for log control data
 
 479  * @sdp: The GFS2 superblock
 
 481  * Returns: the buffer_head
 
 484 struct buffer_head *gfs2_log_get_buf(struct gfs2_sbd *sdp)
 
 486         u64 blkno = log_bmap(sdp, sdp->sd_log_flush_head);
 
 487         struct buffer_head *bh;
 
 489         bh = sb_getblk(sdp->sd_vfs, blkno);
 
 491         memset(bh->b_data, 0, bh->b_size);
 
 492         set_buffer_uptodate(bh);
 
 493         clear_buffer_dirty(bh);
 
 494         gfs2_log_incr_head(sdp);
 
 495         atomic_inc(&sdp->sd_log_in_flight);
 
 497         bh->b_end_io = gfs2_log_write_endio;
 
 503  * gfs2_fake_write_endio - 
 
 504  * @bh: The buffer head
 
 505  * @uptodate: The I/O Status
 
 509 static void gfs2_fake_write_endio(struct buffer_head *bh, int uptodate)
 
 511         struct buffer_head *real_bh = bh->b_private;
 
 512         struct gfs2_bufdata *bd = real_bh->b_private;
 
 513         struct gfs2_sbd *sdp = bd->bd_gl->gl_sbd;
 
 515         end_buffer_write_sync(bh, uptodate);
 
 516         free_buffer_head(bh);
 
 517         unlock_buffer(real_bh);
 
 519         if (atomic_dec_and_test(&sdp->sd_log_in_flight))
 
 520                 wake_up(&sdp->sd_log_flush_wait);
 
 524  * gfs2_log_fake_buf - Build a fake buffer head to write metadata buffer to log
 
 525  * @sdp: the filesystem
 
 526  * @data: the data the buffer_head should point to
 
 528  * Returns: the log buffer descriptor
 
 531 struct buffer_head *gfs2_log_fake_buf(struct gfs2_sbd *sdp,
 
 532                                       struct buffer_head *real)
 
 534         u64 blkno = log_bmap(sdp, sdp->sd_log_flush_head);
 
 535         struct buffer_head *bh;
 
 537         bh = alloc_buffer_head(GFP_NOFS | __GFP_NOFAIL);
 
 538         atomic_set(&bh->b_count, 1);
 
 539         bh->b_state = (1 << BH_Mapped) | (1 << BH_Uptodate) | (1 << BH_Lock);
 
 540         set_bh_page(bh, real->b_page, bh_offset(real));
 
 541         bh->b_blocknr = blkno;
 
 542         bh->b_size = sdp->sd_sb.sb_bsize;
 
 543         bh->b_bdev = sdp->sd_vfs->s_bdev;
 
 544         bh->b_private = real;
 
 545         bh->b_end_io = gfs2_fake_write_endio;
 
 547         gfs2_log_incr_head(sdp);
 
 548         atomic_inc(&sdp->sd_log_in_flight);
 
 553 static void log_pull_tail(struct gfs2_sbd *sdp, unsigned int new_tail)
 
 555         unsigned int dist = log_distance(sdp, new_tail, sdp->sd_log_tail);
 
 557         ail2_empty(sdp, new_tail);
 
 560         atomic_add(dist, &sdp->sd_log_blks_free);
 
 561         gfs2_assert_withdraw(sdp, atomic_read(&sdp->sd_log_blks_free) <= sdp->sd_jdesc->jd_blocks);
 
 562         gfs2_log_unlock(sdp);
 
 564         sdp->sd_log_tail = new_tail;
 
 568  * log_write_header - Get and initialize a journal header buffer
 
 569  * @sdp: The GFS2 superblock
 
 571  * Returns: the initialized log buffer descriptor
 
 574 static void log_write_header(struct gfs2_sbd *sdp, u32 flags, int pull)
 
 576         u64 blkno = log_bmap(sdp, sdp->sd_log_flush_head);
 
 577         struct buffer_head *bh;
 
 578         struct gfs2_log_header *lh;
 
 582         bh = sb_getblk(sdp->sd_vfs, blkno);
 
 584         memset(bh->b_data, 0, bh->b_size);
 
 585         set_buffer_uptodate(bh);
 
 586         clear_buffer_dirty(bh);
 
 589         gfs2_ail1_empty(sdp, 0);
 
 590         tail = current_tail(sdp);
 
 592         lh = (struct gfs2_log_header *)bh->b_data;
 
 593         memset(lh, 0, sizeof(struct gfs2_log_header));
 
 594         lh->lh_header.mh_magic = cpu_to_be32(GFS2_MAGIC);
 
 595         lh->lh_header.mh_type = cpu_to_be32(GFS2_METATYPE_LH);
 
 596         lh->lh_header.mh_format = cpu_to_be32(GFS2_FORMAT_LH);
 
 597         lh->lh_sequence = cpu_to_be64(sdp->sd_log_sequence++);
 
 598         lh->lh_flags = cpu_to_be32(flags);
 
 599         lh->lh_tail = cpu_to_be32(tail);
 
 600         lh->lh_blkno = cpu_to_be32(sdp->sd_log_flush_head);
 
 601         hash = gfs2_disk_hash(bh->b_data, sizeof(struct gfs2_log_header));
 
 602         lh->lh_hash = cpu_to_be32(hash);
 
 604         set_buffer_dirty(bh);
 
 605         if (sync_dirty_buffer(bh))
 
 606                 gfs2_io_error_bh(sdp, bh);
 
 609         if (sdp->sd_log_tail != tail)
 
 610                 log_pull_tail(sdp, tail);
 
 612                 gfs2_assert_withdraw(sdp, !pull);
 
 614         sdp->sd_log_idle = (tail == sdp->sd_log_flush_head);
 
 615         gfs2_log_incr_head(sdp);
 
 618 static void log_flush_commit(struct gfs2_sbd *sdp)
 
 622         if (atomic_read(&sdp->sd_log_in_flight)) {
 
 624                         prepare_to_wait(&sdp->sd_log_flush_wait, &wait,
 
 625                                         TASK_UNINTERRUPTIBLE);
 
 626                         if (atomic_read(&sdp->sd_log_in_flight))
 
 628                 } while(atomic_read(&sdp->sd_log_in_flight));
 
 629                 finish_wait(&sdp->sd_log_flush_wait, &wait);
 
 632         log_write_header(sdp, 0, 0);
 
 635 static void gfs2_ordered_write(struct gfs2_sbd *sdp)
 
 637         struct gfs2_bufdata *bd;
 
 638         struct buffer_head *bh;
 
 642         while (!list_empty(&sdp->sd_log_le_ordered)) {
 
 643                 bd = list_entry(sdp->sd_log_le_ordered.next, struct gfs2_bufdata, bd_le.le_list);
 
 644                 list_move(&bd->bd_le.le_list, &written);
 
 646                 if (!buffer_dirty(bh))
 
 649                 gfs2_log_unlock(sdp);
 
 651                 if (buffer_mapped(bh) && test_clear_buffer_dirty(bh)) {
 
 652                         bh->b_end_io = end_buffer_write_sync;
 
 653                         submit_bh(WRITE, bh);
 
 660         list_splice(&written, &sdp->sd_log_le_ordered);
 
 661         gfs2_log_unlock(sdp);
 
 664 static void gfs2_ordered_wait(struct gfs2_sbd *sdp)
 
 666         struct gfs2_bufdata *bd;
 
 667         struct buffer_head *bh;
 
 670         while (!list_empty(&sdp->sd_log_le_ordered)) {
 
 671                 bd = list_entry(sdp->sd_log_le_ordered.prev, struct gfs2_bufdata, bd_le.le_list);
 
 673                 if (buffer_locked(bh)) {
 
 675                         gfs2_log_unlock(sdp);
 
 681                 list_del_init(&bd->bd_le.le_list);
 
 683         gfs2_log_unlock(sdp);
 
 687  * gfs2_log_flush - flush incore transaction(s)
 
 688  * @sdp: the filesystem
 
 689  * @gl: The glock structure to flush.  If NULL, flush the whole incore log
 
 693 void __gfs2_log_flush(struct gfs2_sbd *sdp, struct gfs2_glock *gl)
 
 697         down_write(&sdp->sd_log_flush_lock);
 
 699         /* Log might have been flushed while we waited for the flush lock */
 
 700         if (gl && !test_bit(GLF_LFLUSH, &gl->gl_flags)) {
 
 701                 up_write(&sdp->sd_log_flush_lock);
 
 705         ai = kzalloc(sizeof(struct gfs2_ail), GFP_NOFS | __GFP_NOFAIL);
 
 706         INIT_LIST_HEAD(&ai->ai_ail1_list);
 
 707         INIT_LIST_HEAD(&ai->ai_ail2_list);
 
 709         if (sdp->sd_log_num_buf != sdp->sd_log_commited_buf) {
 
 710                 printk(KERN_INFO "GFS2: log buf %u %u\n", sdp->sd_log_num_buf,
 
 711                        sdp->sd_log_commited_buf);
 
 712                 gfs2_assert_withdraw(sdp, 0);
 
 714         if (sdp->sd_log_num_databuf != sdp->sd_log_commited_databuf) {
 
 715                 printk(KERN_INFO "GFS2: log databuf %u %u\n",
 
 716                        sdp->sd_log_num_databuf, sdp->sd_log_commited_databuf);
 
 717                 gfs2_assert_withdraw(sdp, 0);
 
 719         gfs2_assert_withdraw(sdp,
 
 720                         sdp->sd_log_num_revoke == sdp->sd_log_commited_revoke);
 
 722         sdp->sd_log_flush_head = sdp->sd_log_head;
 
 723         sdp->sd_log_flush_wrapped = 0;
 
 724         ai->ai_first = sdp->sd_log_flush_head;
 
 726         gfs2_ordered_write(sdp);
 
 727         lops_before_commit(sdp);
 
 728         gfs2_ordered_wait(sdp);
 
 730         if (sdp->sd_log_head != sdp->sd_log_flush_head)
 
 731                 log_flush_commit(sdp);
 
 732         else if (sdp->sd_log_tail != current_tail(sdp) && !sdp->sd_log_idle){
 
 734                 atomic_dec(&sdp->sd_log_blks_free); /* Adjust for unreserved buffer */
 
 735                 gfs2_log_unlock(sdp);
 
 736                 log_write_header(sdp, 0, PULL);
 
 738         lops_after_commit(sdp, ai);
 
 741         sdp->sd_log_head = sdp->sd_log_flush_head;
 
 742         sdp->sd_log_blks_reserved = 0;
 
 743         sdp->sd_log_commited_buf = 0;
 
 744         sdp->sd_log_commited_databuf = 0;
 
 745         sdp->sd_log_commited_revoke = 0;
 
 747         if (!list_empty(&ai->ai_ail1_list)) {
 
 748                 list_add(&ai->ai_list, &sdp->sd_ail1_list);
 
 751         gfs2_log_unlock(sdp);
 
 753         sdp->sd_vfs->s_dirt = 0;
 
 754         up_write(&sdp->sd_log_flush_lock);
 
 759 static void log_refund(struct gfs2_sbd *sdp, struct gfs2_trans *tr)
 
 761         unsigned int reserved;
 
 766         sdp->sd_log_commited_buf += tr->tr_num_buf_new - tr->tr_num_buf_rm;
 
 767         sdp->sd_log_commited_databuf += tr->tr_num_databuf_new -
 
 768                 tr->tr_num_databuf_rm;
 
 769         gfs2_assert_withdraw(sdp, (((int)sdp->sd_log_commited_buf) >= 0) ||
 
 770                              (((int)sdp->sd_log_commited_databuf) >= 0));
 
 771         sdp->sd_log_commited_revoke += tr->tr_num_revoke - tr->tr_num_revoke_rm;
 
 772         gfs2_assert_withdraw(sdp, ((int)sdp->sd_log_commited_revoke) >= 0);
 
 773         reserved = calc_reserved(sdp);
 
 774         gfs2_assert_withdraw(sdp, sdp->sd_log_blks_reserved + tr->tr_reserved >= reserved);
 
 775         unused = sdp->sd_log_blks_reserved - reserved + tr->tr_reserved;
 
 776         atomic_add(unused, &sdp->sd_log_blks_free);
 
 777         gfs2_assert_withdraw(sdp, atomic_read(&sdp->sd_log_blks_free) <=
 
 778                              sdp->sd_jdesc->jd_blocks);
 
 779         sdp->sd_log_blks_reserved = reserved;
 
 781         gfs2_log_unlock(sdp);
 
 784 static void buf_lo_incore_commit(struct gfs2_sbd *sdp, struct gfs2_trans *tr)
 
 786         struct list_head *head = &tr->tr_list_buf;
 
 787         struct gfs2_bufdata *bd;
 
 790         while (!list_empty(head)) {
 
 791                 bd = list_entry(head->next, struct gfs2_bufdata, bd_list_tr);
 
 792                 list_del_init(&bd->bd_list_tr);
 
 795         gfs2_log_unlock(sdp);
 
 796         gfs2_assert_warn(sdp, !tr->tr_num_buf);
 
 800  * gfs2_log_commit - Commit a transaction to the log
 
 801  * @sdp: the filesystem
 
 802  * @tr: the transaction
 
 807 void gfs2_log_commit(struct gfs2_sbd *sdp, struct gfs2_trans *tr)
 
 810         buf_lo_incore_commit(sdp, tr);
 
 812         sdp->sd_vfs->s_dirt = 1;
 
 813         up_read(&sdp->sd_log_flush_lock);
 
 816         if (sdp->sd_log_num_buf > gfs2_tune_get(sdp, gt_incore_log_blocks))
 
 817                 wake_up_process(sdp->sd_logd_process);
 
 818         gfs2_log_unlock(sdp);
 
 822  * gfs2_log_shutdown - write a shutdown header into a journal
 
 823  * @sdp: the filesystem
 
 827 void gfs2_log_shutdown(struct gfs2_sbd *sdp)
 
 829         down_write(&sdp->sd_log_flush_lock);
 
 831         gfs2_assert_withdraw(sdp, !sdp->sd_log_blks_reserved);
 
 832         gfs2_assert_withdraw(sdp, !sdp->sd_log_num_buf);
 
 833         gfs2_assert_withdraw(sdp, !sdp->sd_log_num_revoke);
 
 834         gfs2_assert_withdraw(sdp, !sdp->sd_log_num_rg);
 
 835         gfs2_assert_withdraw(sdp, !sdp->sd_log_num_databuf);
 
 836         gfs2_assert_withdraw(sdp, list_empty(&sdp->sd_ail1_list));
 
 838         sdp->sd_log_flush_head = sdp->sd_log_head;
 
 839         sdp->sd_log_flush_wrapped = 0;
 
 841         log_write_header(sdp, GFS2_LOG_HEAD_UNMOUNT,
 
 842                          (sdp->sd_log_tail == current_tail(sdp)) ? 0 : PULL);
 
 844         gfs2_assert_warn(sdp, atomic_read(&sdp->sd_log_blks_free) == sdp->sd_jdesc->jd_blocks);
 
 845         gfs2_assert_warn(sdp, sdp->sd_log_head == sdp->sd_log_tail);
 
 846         gfs2_assert_warn(sdp, list_empty(&sdp->sd_ail2_list));
 
 848         sdp->sd_log_head = sdp->sd_log_flush_head;
 
 849         sdp->sd_log_tail = sdp->sd_log_head;
 
 851         up_write(&sdp->sd_log_flush_lock);
 
 856  * gfs2_meta_syncfs - sync all the buffers in a filesystem
 
 857  * @sdp: the filesystem
 
 861 void gfs2_meta_syncfs(struct gfs2_sbd *sdp)
 
 863         gfs2_log_flush(sdp, NULL);
 
 865                 gfs2_ail1_start(sdp, DIO_ALL);
 
 866                 if (gfs2_ail1_empty(sdp, DIO_ALL))
 
 874  * gfs2_logd - Update log tail as Active Items get flushed to in-place blocks
 
 875  * @sdp: Pointer to GFS2 superblock
 
 877  * Also, periodically check to make sure that we're using the most recent
 
 881 int gfs2_logd(void *data)
 
 883         struct gfs2_sbd *sdp = data;
 
 887         while (!kthread_should_stop()) {
 
 888                 /* Advance the log tail */
 
 890                 t = sdp->sd_log_flush_time +
 
 891                     gfs2_tune_get(sdp, gt_log_flush_secs) * HZ;
 
 893                 gfs2_ail1_empty(sdp, DIO_ALL);
 
 895                 need_flush = sdp->sd_log_num_buf > gfs2_tune_get(sdp, gt_incore_log_blocks);
 
 896                 gfs2_log_unlock(sdp);
 
 897                 if (need_flush || time_after_eq(jiffies, t)) {
 
 898                         gfs2_log_flush(sdp, NULL);
 
 899                         sdp->sd_log_flush_time = jiffies;
 
 902                 t = gfs2_tune_get(sdp, gt_logd_secs) * HZ;
 
 903                 if (freezing(current))
 
 905                 schedule_timeout_interruptible(t);