2005-04-17 06:20:36 +08:00
|
|
|
/*
|
|
|
|
* fs/fs-writeback.c
|
|
|
|
*
|
|
|
|
* Copyright (C) 2002, Linus Torvalds.
|
|
|
|
*
|
|
|
|
* Contains all the functions related to writing back and waiting
|
|
|
|
* upon dirty inodes against superblocks, and writing back dirty
|
|
|
|
* pages against inodes. ie: data writeback. Writeout of the
|
|
|
|
* inode itself is not handled here.
|
|
|
|
*
|
2008-10-16 13:01:59 +08:00
|
|
|
* 10Apr2002 Andrew Morton
|
2005-04-17 06:20:36 +08:00
|
|
|
* Split out of fs/inode.c
|
|
|
|
* Additions for address_space-based writeback
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/kernel.h>
|
2007-09-21 15:19:54 +08:00
|
|
|
#include <linux/module.h>
|
2005-04-17 06:20:36 +08:00
|
|
|
#include <linux/spinlock.h>
|
|
|
|
#include <linux/sched.h>
|
|
|
|
#include <linux/fs.h>
|
|
|
|
#include <linux/mm.h>
|
2009-09-09 15:08:54 +08:00
|
|
|
#include <linux/kthread.h>
|
|
|
|
#include <linux/freezer.h>
|
2005-04-17 06:20:36 +08:00
|
|
|
#include <linux/writeback.h>
|
|
|
|
#include <linux/blkdev.h>
|
|
|
|
#include <linux/backing-dev.h>
|
|
|
|
#include <linux/buffer_head.h>
|
2006-10-01 02:52:18 +08:00
|
|
|
#include "internal.h"
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-02 15:19:46 +08:00
|
|
|
#define inode_to_bdi(inode) ((inode)->i_mapping->backing_dev_info)
|
2008-04-29 15:58:56 +08:00
|
|
|
|
2009-05-18 14:20:32 +08:00
|
|
|
/*
|
|
|
|
* We don't actually have pdflush, but this one is exported though /proc...
|
|
|
|
*/
|
|
|
|
int nr_pdflush_threads;
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
/*
|
|
|
|
* Work items for the bdi_writeback threads
|
2008-04-29 15:58:56 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
struct bdi_work {
|
|
|
|
struct list_head list;
|
|
|
|
struct list_head wait_list;
|
|
|
|
struct rcu_head rcu_head;
|
|
|
|
|
|
|
|
unsigned long seen;
|
|
|
|
atomic_t pending;
|
|
|
|
|
|
|
|
struct super_block *sb;
|
|
|
|
unsigned long nr_pages;
|
|
|
|
enum writeback_sync_modes sync_mode;
|
|
|
|
|
|
|
|
unsigned long state;
|
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
|
|
|
WS_USED_B = 0,
|
|
|
|
WS_ONSTACK_B,
|
|
|
|
};
|
|
|
|
|
|
|
|
#define WS_USED (1 << WS_USED_B)
|
|
|
|
#define WS_ONSTACK (1 << WS_ONSTACK_B)
|
|
|
|
|
|
|
|
static inline bool bdi_work_on_stack(struct bdi_work *work)
|
|
|
|
{
|
|
|
|
return test_bit(WS_ONSTACK_B, &work->state);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void bdi_work_init(struct bdi_work *work,
|
|
|
|
struct writeback_control *wbc)
|
|
|
|
{
|
|
|
|
INIT_RCU_HEAD(&work->rcu_head);
|
|
|
|
work->sb = wbc->sb;
|
|
|
|
work->nr_pages = wbc->nr_to_write;
|
|
|
|
work->sync_mode = wbc->sync_mode;
|
|
|
|
work->state = WS_USED;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void bdi_work_init_on_stack(struct bdi_work *work,
|
|
|
|
struct writeback_control *wbc)
|
2008-04-29 15:58:56 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
bdi_work_init(work, wbc);
|
|
|
|
work->state |= WS_ONSTACK;
|
2008-04-29 15:58:56 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* writeback_in_progress - determine whether there is writeback in progress
|
|
|
|
* @bdi: the device's backing_dev_info structure.
|
|
|
|
*
|
2009-09-09 15:08:54 +08:00
|
|
|
* Determine whether there is writeback waiting to be handled against a
|
|
|
|
* backing device.
|
2008-04-29 15:58:56 +08:00
|
|
|
*/
|
|
|
|
int writeback_in_progress(struct backing_dev_info *bdi)
|
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
return !list_empty(&bdi->work_list);
|
2008-04-29 15:58:56 +08:00
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
static void bdi_work_clear(struct bdi_work *work)
|
2008-04-29 15:58:56 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
clear_bit(WS_USED_B, &work->state);
|
|
|
|
smp_mb__after_clear_bit();
|
|
|
|
wake_up_bit(&work->state, WS_USED_B);
|
2008-04-29 15:58:56 +08:00
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
static void bdi_work_free(struct rcu_head *head)
|
2009-05-28 15:01:15 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
struct bdi_work *work = container_of(head, struct bdi_work, rcu_head);
|
2009-05-28 15:01:15 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
if (!bdi_work_on_stack(work))
|
|
|
|
kfree(work);
|
|
|
|
else
|
|
|
|
bdi_work_clear(work);
|
2009-05-28 15:01:15 +08:00
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
static void wb_work_complete(struct bdi_work *work)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
const enum writeback_sync_modes sync_mode = work->sync_mode;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/*
|
2009-09-09 15:08:54 +08:00
|
|
|
* For allocated work, we can clear the done/seen bit right here.
|
|
|
|
* For on-stack work, we need to postpone both the clear and free
|
|
|
|
* to after the RCU grace period, since the stack could be invalidated
|
|
|
|
* as soon as bdi_work_clear() has done the wakeup.
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
if (!bdi_work_on_stack(work))
|
|
|
|
bdi_work_clear(work);
|
|
|
|
if (sync_mode == WB_SYNC_NONE || bdi_work_on_stack(work))
|
|
|
|
call_rcu(&work->rcu_head, bdi_work_free);
|
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
static void wb_clear_pending(struct bdi_writeback *wb, struct bdi_work *work)
|
|
|
|
{
|
2005-04-17 06:20:36 +08:00
|
|
|
/*
|
2009-09-09 15:08:54 +08:00
|
|
|
* The caller has retrieved the work arguments from this work,
|
|
|
|
* drop our reference. If this is the last ref, delete and free it
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
if (atomic_dec_and_test(&work->pending)) {
|
|
|
|
struct backing_dev_info *bdi = wb->bdi;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
spin_lock(&bdi->wb_lock);
|
|
|
|
list_del_rcu(&work->list);
|
|
|
|
spin_unlock(&bdi->wb_lock);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
wb_work_complete(work);
|
|
|
|
}
|
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
static void bdi_queue_work(struct backing_dev_info *bdi, struct bdi_work *work)
|
|
|
|
{
|
|
|
|
if (work) {
|
|
|
|
work->seen = bdi->wb_mask;
|
|
|
|
BUG_ON(!work->seen);
|
|
|
|
atomic_set(&work->pending, bdi->wb_cnt);
|
|
|
|
BUG_ON(!bdi->wb_cnt);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/*
|
2009-09-09 15:08:54 +08:00
|
|
|
* Make sure stores are seen before it appears on the list
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
smp_mb();
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
spin_lock(&bdi->wb_lock);
|
|
|
|
list_add_tail_rcu(&work->list, &bdi->work_list);
|
|
|
|
spin_unlock(&bdi->wb_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If the default thread isn't there, make sure we add it. When
|
|
|
|
* it gets created and wakes up, we'll run this work.
|
|
|
|
*/
|
|
|
|
if (unlikely(list_empty_careful(&bdi->wb_list)))
|
|
|
|
wake_up_process(default_backing_dev_info.wb.task);
|
|
|
|
else {
|
|
|
|
struct bdi_writeback *wb = &bdi->wb;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/*
|
2009-09-09 15:08:54 +08:00
|
|
|
* If we failed allocating the bdi work item, wake up the wb
|
|
|
|
* thread always. As a safety precaution, it'll flush out
|
|
|
|
* everything
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
if (!wb_has_dirty_io(wb)) {
|
|
|
|
if (work)
|
|
|
|
wb_clear_pending(wb, work);
|
|
|
|
} else if (wb->task)
|
|
|
|
wake_up_process(wb->task);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
/*
|
|
|
|
* Used for on-stack allocated work items. The caller needs to wait until
|
|
|
|
* the wb threads have acked the work before it's safe to continue.
|
|
|
|
*/
|
|
|
|
static void bdi_wait_on_work_clear(struct bdi_work *work)
|
|
|
|
{
|
|
|
|
wait_on_bit(&work->state, WS_USED_B, bdi_sched_wait,
|
|
|
|
TASK_UNINTERRUPTIBLE);
|
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
static struct bdi_work *bdi_alloc_work(struct writeback_control *wbc)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
struct bdi_work *work;
|
|
|
|
|
|
|
|
work = kmalloc(sizeof(*work), GFP_ATOMIC);
|
|
|
|
if (work)
|
|
|
|
bdi_work_init(work, wbc);
|
|
|
|
|
|
|
|
return work;
|
|
|
|
}
|
|
|
|
|
|
|
|
void bdi_start_writeback(struct writeback_control *wbc)
|
|
|
|
{
|
|
|
|
const bool must_wait = wbc->sync_mode == WB_SYNC_ALL;
|
|
|
|
struct bdi_work work_stack, *work = NULL;
|
|
|
|
|
|
|
|
if (!must_wait)
|
|
|
|
work = bdi_alloc_work(wbc);
|
|
|
|
|
|
|
|
if (!work) {
|
|
|
|
work = &work_stack;
|
|
|
|
bdi_work_init_on_stack(work, wbc);
|
|
|
|
}
|
|
|
|
|
|
|
|
bdi_queue_work(wbc->bdi, work);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If the sync mode is WB_SYNC_ALL, block waiting for the work to
|
|
|
|
* complete. If not, we only need to wait for the work to be started,
|
|
|
|
* if we allocated it on-stack. We use the same mechanism, if the
|
|
|
|
* wait bit is set in the bdi_work struct, then threads will not
|
|
|
|
* clear pending until after they are done.
|
|
|
|
*
|
|
|
|
* Note that work == &work_stack if must_wait is true, so we don't
|
|
|
|
* need to do call_rcu() here ever, since the completion path will
|
|
|
|
* have done that for us.
|
|
|
|
*/
|
|
|
|
if (must_wait || work == &work_stack) {
|
|
|
|
bdi_wait_on_work_clear(work);
|
|
|
|
if (work != &work_stack)
|
|
|
|
call_rcu(&work->rcu_head, bdi_work_free);
|
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
2007-10-17 14:30:32 +08:00
|
|
|
/*
|
|
|
|
* Redirty an inode: set its when-it-was dirtied timestamp and move it to the
|
|
|
|
* furthest end of its superblock's dirty-inode list.
|
|
|
|
*
|
|
|
|
* Before stamping the inode's ->dirtied_when, we check to see whether it is
|
2009-09-02 15:19:46 +08:00
|
|
|
* already the most-recently-dirtied inode on the b_dirty list. If that is
|
2007-10-17 14:30:32 +08:00
|
|
|
* the case then the inode must have been redirtied while it was being written
|
|
|
|
* out and we don't reset its dirtied_when.
|
|
|
|
*/
|
|
|
|
static void redirty_tail(struct inode *inode)
|
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
struct bdi_writeback *wb = &inode_to_bdi(inode)->wb;
|
2007-10-17 14:30:32 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
if (!list_empty(&wb->b_dirty)) {
|
2009-09-02 15:19:46 +08:00
|
|
|
struct inode *tail;
|
2007-10-17 14:30:32 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
tail = list_entry(wb->b_dirty.next, struct inode, i_list);
|
2009-09-02 15:19:46 +08:00
|
|
|
if (time_before(inode->dirtied_when, tail->dirtied_when))
|
2007-10-17 14:30:32 +08:00
|
|
|
inode->dirtied_when = jiffies;
|
|
|
|
}
|
2009-09-09 15:08:54 +08:00
|
|
|
list_move(&inode->i_list, &wb->b_dirty);
|
2007-10-17 14:30:32 +08:00
|
|
|
}
|
|
|
|
|
2007-10-17 14:30:34 +08:00
|
|
|
/*
|
2009-09-02 15:19:46 +08:00
|
|
|
* requeue inode for re-scanning after bdi->b_io list is exhausted.
|
2007-10-17 14:30:34 +08:00
|
|
|
*/
|
2007-10-17 14:30:38 +08:00
|
|
|
static void requeue_io(struct inode *inode)
|
2007-10-17 14:30:34 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
struct bdi_writeback *wb = &inode_to_bdi(inode)->wb;
|
|
|
|
|
|
|
|
list_move(&inode->i_list, &wb->b_more_io);
|
2007-10-17 14:30:34 +08:00
|
|
|
}
|
|
|
|
|
2007-10-17 14:30:44 +08:00
|
|
|
static void inode_sync_complete(struct inode *inode)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* Prevent speculative execution through spin_unlock(&inode_lock);
|
|
|
|
*/
|
|
|
|
smp_mb();
|
|
|
|
wake_up_bit(&inode->i_state, __I_SYNC);
|
|
|
|
}
|
|
|
|
|
2009-04-03 07:56:37 +08:00
|
|
|
static bool inode_dirtied_after(struct inode *inode, unsigned long t)
|
|
|
|
{
|
|
|
|
bool ret = time_after(inode->dirtied_when, t);
|
|
|
|
#ifndef CONFIG_64BIT
|
|
|
|
/*
|
|
|
|
* For inodes being constantly redirtied, dirtied_when can get stuck.
|
|
|
|
* It _appears_ to be in the future, but is actually in distant past.
|
|
|
|
* This test is necessary to prevent such wrapped-around relative times
|
|
|
|
* from permanently stopping the whole pdflush writeback.
|
|
|
|
*/
|
|
|
|
ret = ret && time_before_eq(inode->dirtied_when, jiffies);
|
|
|
|
#endif
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2007-10-17 14:30:39 +08:00
|
|
|
/*
|
|
|
|
* Move expired dirty inodes from @delaying_queue to @dispatch_queue.
|
|
|
|
*/
|
|
|
|
static void move_expired_inodes(struct list_head *delaying_queue,
|
|
|
|
struct list_head *dispatch_queue,
|
|
|
|
unsigned long *older_than_this)
|
|
|
|
{
|
|
|
|
while (!list_empty(delaying_queue)) {
|
|
|
|
struct inode *inode = list_entry(delaying_queue->prev,
|
|
|
|
struct inode, i_list);
|
|
|
|
if (older_than_this &&
|
2009-04-03 07:56:37 +08:00
|
|
|
inode_dirtied_after(inode, *older_than_this))
|
2007-10-17 14:30:39 +08:00
|
|
|
break;
|
|
|
|
list_move(&inode->i_list, dispatch_queue);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Queue all expired dirty inodes for io, eldest first.
|
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
static void queue_io(struct bdi_writeback *wb, unsigned long *older_than_this)
|
2009-09-02 15:19:46 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
list_splice_init(&wb->b_more_io, wb->b_io.prev);
|
|
|
|
move_expired_inodes(&wb->b_dirty, &wb->b_io, older_than_this);
|
2009-09-02 15:19:46 +08:00
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
static int write_inode(struct inode *inode, int sync)
|
2007-10-17 14:30:39 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
if (inode->i_sb->s_op->write_inode && !is_bad_inode(inode))
|
|
|
|
return inode->i_sb->s_op->write_inode(inode, sync);
|
|
|
|
return 0;
|
2007-10-17 14:30:39 +08:00
|
|
|
}
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
/*
|
2009-06-08 19:35:40 +08:00
|
|
|
* Wait for writeback on an inode to complete.
|
|
|
|
*/
|
|
|
|
static void inode_wait_for_writeback(struct inode *inode)
|
|
|
|
{
|
|
|
|
DEFINE_WAIT_BIT(wq, &inode->i_state, __I_SYNC);
|
|
|
|
wait_queue_head_t *wqh;
|
|
|
|
|
|
|
|
wqh = bit_waitqueue(&inode->i_state, __I_SYNC);
|
|
|
|
do {
|
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
__wait_on_bit(wqh, &wq, inode_wait, TASK_UNINTERRUPTIBLE);
|
|
|
|
spin_lock(&inode_lock);
|
|
|
|
} while (inode->i_state & I_SYNC);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Write out an inode's dirty pages. Called under inode_lock. Either the
|
|
|
|
* caller has ref on the inode (either via __iget or via syscall against an fd)
|
|
|
|
* or the inode has I_WILL_FREE set (via generic_forget_inode)
|
|
|
|
*
|
2005-04-17 06:20:36 +08:00
|
|
|
* If `wait' is set, wait on the writeout.
|
|
|
|
*
|
|
|
|
* The whole writeout design is quite complex and fragile. We want to avoid
|
|
|
|
* starvation of particular inodes when others are being redirtied, prevent
|
|
|
|
* livelocks, etc.
|
|
|
|
*
|
|
|
|
* Called under inode_lock.
|
|
|
|
*/
|
|
|
|
static int
|
2009-06-08 19:35:40 +08:00
|
|
|
writeback_single_inode(struct inode *inode, struct writeback_control *wbc)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
|
|
|
struct address_space *mapping = inode->i_mapping;
|
|
|
|
int wait = wbc->sync_mode == WB_SYNC_ALL;
|
2009-06-08 19:35:40 +08:00
|
|
|
unsigned dirty;
|
2005-04-17 06:20:36 +08:00
|
|
|
int ret;
|
|
|
|
|
2009-06-08 19:35:40 +08:00
|
|
|
if (!atomic_read(&inode->i_count))
|
|
|
|
WARN_ON(!(inode->i_state & (I_WILL_FREE|I_FREEING)));
|
|
|
|
else
|
|
|
|
WARN_ON(inode->i_state & I_WILL_FREE);
|
|
|
|
|
|
|
|
if (inode->i_state & I_SYNC) {
|
|
|
|
/*
|
|
|
|
* If this inode is locked for writeback and we are not doing
|
2009-09-02 15:19:46 +08:00
|
|
|
* writeback-for-data-integrity, move it to b_more_io so that
|
2009-06-08 19:35:40 +08:00
|
|
|
* writeback can proceed with the other inodes on s_io.
|
|
|
|
*
|
|
|
|
* We'll have another go at writing back this inode when we
|
2009-09-02 15:19:46 +08:00
|
|
|
* completed a full scan of b_io.
|
2009-06-08 19:35:40 +08:00
|
|
|
*/
|
|
|
|
if (!wait) {
|
|
|
|
requeue_io(inode);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* It's a data-integrity sync. We must wait.
|
|
|
|
*/
|
|
|
|
inode_wait_for_writeback(inode);
|
|
|
|
}
|
|
|
|
|
2007-10-17 14:30:44 +08:00
|
|
|
BUG_ON(inode->i_state & I_SYNC);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2007-10-17 14:30:44 +08:00
|
|
|
/* Set I_SYNC, reset I_DIRTY */
|
2005-04-17 06:20:36 +08:00
|
|
|
dirty = inode->i_state & I_DIRTY;
|
2007-10-17 14:30:44 +08:00
|
|
|
inode->i_state |= I_SYNC;
|
2005-04-17 06:20:36 +08:00
|
|
|
inode->i_state &= ~I_DIRTY;
|
|
|
|
|
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
|
|
|
|
ret = do_writepages(mapping, wbc);
|
|
|
|
|
|
|
|
/* Don't write the inode if only I_DIRTY_PAGES was set */
|
|
|
|
if (dirty & (I_DIRTY_SYNC | I_DIRTY_DATASYNC)) {
|
|
|
|
int err = write_inode(inode, wait);
|
|
|
|
if (ret == 0)
|
|
|
|
ret = err;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (wait) {
|
|
|
|
int err = filemap_fdatawait(mapping);
|
|
|
|
if (ret == 0)
|
|
|
|
ret = err;
|
|
|
|
}
|
|
|
|
|
|
|
|
spin_lock(&inode_lock);
|
2007-10-17 14:30:44 +08:00
|
|
|
inode->i_state &= ~I_SYNC;
|
2009-06-17 06:33:17 +08:00
|
|
|
if (!(inode->i_state & (I_FREEING | I_CLEAR))) {
|
2005-04-17 06:20:36 +08:00
|
|
|
if (!(inode->i_state & I_DIRTY) &&
|
|
|
|
mapping_tagged(mapping, PAGECACHE_TAG_DIRTY)) {
|
|
|
|
/*
|
|
|
|
* We didn't write back all the pages. nfs_writepages()
|
|
|
|
* sometimes bales out without doing anything. Redirty
|
2009-09-02 15:19:46 +08:00
|
|
|
* the inode; Move it from b_io onto b_more_io/b_dirty.
|
2007-10-17 14:30:35 +08:00
|
|
|
*/
|
|
|
|
/*
|
|
|
|
* akpm: if the caller was the kupdate function we put
|
2009-09-02 15:19:46 +08:00
|
|
|
* this inode at the head of b_dirty so it gets first
|
2007-10-17 14:30:35 +08:00
|
|
|
* consideration. Otherwise, move it to the tail, for
|
|
|
|
* the reasons described there. I'm not really sure
|
|
|
|
* how much sense this makes. Presumably I had a good
|
|
|
|
* reasons for doing it this way, and I'd rather not
|
|
|
|
* muck with it at present.
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
|
|
|
if (wbc->for_kupdate) {
|
|
|
|
/*
|
2007-10-17 14:30:39 +08:00
|
|
|
* For the kupdate function we move the inode
|
2009-09-02 15:19:46 +08:00
|
|
|
* to b_more_io so it will get more writeout as
|
2007-10-17 14:30:39 +08:00
|
|
|
* soon as the queue becomes uncongested.
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
|
|
|
inode->i_state |= I_DIRTY_PAGES;
|
writeback: speed up writeback of big dirty files
After making dirty a 100M file, the normal behavior is to start the
writeback for all data after 30s delays. But sometimes the following
happens instead:
- after 30s: ~4M
- after 5s: ~4M
- after 5s: all remaining 92M
Some analyze shows that the internal io dispatch queues goes like this:
s_io s_more_io
-------------------------
1) 100M,1K 0
2) 1K 96M
3) 0 96M
1) initial state with a 100M file and a 1K file
2) 4M written, nr_to_write <= 0, so write more
3) 1K written, nr_to_write > 0, no more writes(BUG)
nr_to_write > 0 in (3) fools the upper layer to think that data have all
been written out. The big dirty file is actually still sitting in
s_more_io. We cannot simply splice s_more_io back to s_io as soon as s_io
becomes empty, and let the loop in generic_sync_sb_inodes() continue: this
may starve newly expired inodes in s_dirty. It is also not an option to
draw inodes from both s_more_io and s_dirty, an let the loop go on: this
might lead to live locks, and might also starve other superblocks in sync
time(well kupdate may still starve some superblocks, that's another bug).
We have to return when a full scan of s_io completes. So nr_to_write > 0
does not necessarily mean that "all data are written". This patch
introduces a flag writeback_control.more_io to indicate that more io should
be done. With it the big dirty file no longer has to wait for the next
kupdate invokation 5s later.
In sync_sb_inodes() we only set more_io on super_blocks we actually
visited. This avoids the interaction between two pdflush deamons.
Also in __sync_single_inode() we don't blindly keep requeuing the io if the
filesystem cannot progress. Failing to do so may lead to 100% iowait.
Tested-by: Mike Snitzer <snitzer@gmail.com>
Signed-off-by: Fengguang Wu <wfg@mail.ustc.edu.cn>
Cc: Michael Rubin <mrubin@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-02-05 14:29:36 +08:00
|
|
|
if (wbc->nr_to_write <= 0) {
|
|
|
|
/*
|
|
|
|
* slice used up: queue for next turn
|
|
|
|
*/
|
|
|
|
requeue_io(inode);
|
|
|
|
} else {
|
|
|
|
/*
|
|
|
|
* somehow blocked: retry later
|
|
|
|
*/
|
|
|
|
redirty_tail(inode);
|
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
} else {
|
|
|
|
/*
|
|
|
|
* Otherwise fully redirty the inode so that
|
|
|
|
* other inodes on this superblock will get some
|
|
|
|
* writeout. Otherwise heavy writing to one
|
|
|
|
* file would indefinitely suspend writeout of
|
|
|
|
* all the other files.
|
|
|
|
*/
|
|
|
|
inode->i_state |= I_DIRTY_PAGES;
|
2007-10-17 14:30:35 +08:00
|
|
|
redirty_tail(inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
} else if (inode->i_state & I_DIRTY) {
|
|
|
|
/*
|
|
|
|
* Someone redirtied the inode while were writing back
|
|
|
|
* the pages.
|
|
|
|
*/
|
2007-10-17 14:30:32 +08:00
|
|
|
redirty_tail(inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
} else if (atomic_read(&inode->i_count)) {
|
|
|
|
/*
|
|
|
|
* The inode is clean, inuse
|
|
|
|
*/
|
|
|
|
list_move(&inode->i_list, &inode_in_use);
|
|
|
|
} else {
|
|
|
|
/*
|
|
|
|
* The inode is clean, unused
|
|
|
|
*/
|
|
|
|
list_move(&inode->i_list, &inode_unused);
|
|
|
|
}
|
|
|
|
}
|
2007-10-17 14:30:44 +08:00
|
|
|
inode_sync_complete(inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
/*
|
|
|
|
* For WB_SYNC_NONE writeback, the caller does not have the sb pinned
|
|
|
|
* before calling writeback. So make sure that we do pin it, so it doesn't
|
|
|
|
* go away while we are writing inodes from it.
|
|
|
|
*
|
|
|
|
* Returns 0 if the super was successfully pinned (or pinning wasn't needed),
|
|
|
|
* 1 if we failed.
|
|
|
|
*/
|
|
|
|
static int pin_sb_for_writeback(struct writeback_control *wbc,
|
|
|
|
struct inode *inode)
|
|
|
|
{
|
|
|
|
struct super_block *sb = inode->i_sb;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Caller must already hold the ref for this
|
|
|
|
*/
|
|
|
|
if (wbc->sync_mode == WB_SYNC_ALL) {
|
|
|
|
WARN_ON(!rwsem_is_locked(&sb->s_umount));
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
spin_lock(&sb_lock);
|
|
|
|
sb->s_count++;
|
|
|
|
if (down_read_trylock(&sb->s_umount)) {
|
|
|
|
if (sb->s_root) {
|
|
|
|
spin_unlock(&sb_lock);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
* umounted, drop rwsem again and fall through to failure
|
|
|
|
*/
|
|
|
|
up_read(&sb->s_umount);
|
|
|
|
}
|
|
|
|
|
|
|
|
sb->s_count--;
|
|
|
|
spin_unlock(&sb_lock);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void unpin_sb_for_writeback(struct writeback_control *wbc,
|
|
|
|
struct inode *inode)
|
|
|
|
{
|
|
|
|
struct super_block *sb = inode->i_sb;
|
|
|
|
|
|
|
|
if (wbc->sync_mode == WB_SYNC_ALL)
|
|
|
|
return;
|
|
|
|
|
|
|
|
up_read(&sb->s_umount);
|
|
|
|
put_super(sb);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void writeback_inodes_wb(struct bdi_writeback *wb,
|
|
|
|
struct writeback_control *wbc)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
struct super_block *sb = wbc->sb;
|
2009-09-02 15:19:46 +08:00
|
|
|
const int is_blkdev_sb = sb_is_blkdev_sb(sb);
|
2005-04-17 06:20:36 +08:00
|
|
|
const unsigned long start = jiffies; /* livelock avoidance */
|
|
|
|
|
2008-05-07 20:48:57 +08:00
|
|
|
spin_lock(&inode_lock);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
if (!wbc->for_kupdate || list_empty(&wb->b_io))
|
|
|
|
queue_io(wb, wbc->older_than_this);
|
2009-09-02 15:19:46 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
while (!list_empty(&wb->b_io)) {
|
|
|
|
struct inode *inode = list_entry(wb->b_io.prev,
|
2005-04-17 06:20:36 +08:00
|
|
|
struct inode, i_list);
|
|
|
|
long pages_skipped;
|
|
|
|
|
2009-09-02 15:19:46 +08:00
|
|
|
/*
|
|
|
|
* super block given and doesn't match, skip this inode
|
|
|
|
*/
|
|
|
|
if (sb && sb != inode->i_sb) {
|
|
|
|
redirty_tail(inode);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
if (!bdi_cap_writeback_dirty(wb->bdi)) {
|
2007-10-17 14:30:33 +08:00
|
|
|
redirty_tail(inode);
|
2009-09-02 15:19:46 +08:00
|
|
|
if (is_blkdev_sb) {
|
2005-04-17 06:20:36 +08:00
|
|
|
/*
|
|
|
|
* Dirty memory-backed blockdev: the ramdisk
|
|
|
|
* driver does this. Skip just this inode
|
|
|
|
*/
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
* Dirty memory-backed inode against a filesystem other
|
|
|
|
* than the kernel-internal bdev filesystem. Skip the
|
|
|
|
* entire superblock.
|
|
|
|
*/
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2009-06-17 06:33:17 +08:00
|
|
|
if (inode->i_state & (I_NEW | I_WILL_FREE)) {
|
fs: new inode i_state corruption fix
There was a report of a data corruption
http://lkml.org/lkml/2008/11/14/121. There is a script included to
reproduce the problem.
During testing, I encountered a number of strange things with ext3, so I
tried ext2 to attempt to reduce complexity of the problem. I found that
fsstress would quickly hang in wait_on_inode, waiting for I_LOCK to be
cleared, even though instrumentation showed that unlock_new_inode had
already been called for that inode. This points to memory scribble, or
synchronisation problme.
i_state of I_NEW inodes is not protected by inode_lock because other
processes are not supposed to touch them until I_LOCK (and I_NEW) is
cleared. Adding WARN_ON(inode->i_state & I_NEW) to sites where we modify
i_state revealed that generic_sync_sb_inodes is picking up new inodes from
the inode lists and passing them to __writeback_single_inode without
waiting for I_NEW. Subsequently modifying i_state causes corruption. In
my case it would look like this:
CPU0 CPU1
unlock_new_inode() __sync_single_inode()
reg <- inode->i_state
reg -> reg & ~(I_LOCK|I_NEW) reg <- inode->i_state
reg -> inode->i_state reg -> reg | I_SYNC
reg -> inode->i_state
Non-atomic RMW on CPU1 overwrites CPU0 store and sets I_LOCK|I_NEW again.
Fix for this is rather than wait for I_NEW inodes, just skip over them:
inodes concurrently being created are not subject to data integrity
operations, and should not significantly contribute to dirty memory
either.
After this change, I'm unable to reproduce any of the added warnings or
hangs after ~1hour of running. Previously, the new warnings would start
immediately and hang would happen in under 5 minutes.
I'm also testing on ext3 now, and so far no problems there either. I
don't know whether this fixes the problem reported above, but it fixes a
real problem for me.
Cc: "Jorge Boncompte [DTI2]" <jorge@dti2.net>
Reported-by: Adrian Hunter <ext-adrian.hunter@nokia.com>
Cc: Jan Kara <jack@suse.cz>
Cc: <stable@kernel.org>
Signed-off-by: Nick Piggin <npiggin@suse.de>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2009-03-13 05:31:38 +08:00
|
|
|
requeue_io(inode);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
if (wbc->nonblocking && bdi_write_congested(wb->bdi)) {
|
2005-04-17 06:20:36 +08:00
|
|
|
wbc->encountered_congestion = 1;
|
2009-09-02 15:19:46 +08:00
|
|
|
if (!is_blkdev_sb)
|
2005-04-17 06:20:36 +08:00
|
|
|
break; /* Skip a congested fs */
|
2007-10-17 14:30:38 +08:00
|
|
|
requeue_io(inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
continue; /* Skip a congested blockdev */
|
|
|
|
}
|
|
|
|
|
2009-04-03 07:56:37 +08:00
|
|
|
/*
|
|
|
|
* Was this inode dirtied after sync_sb_inodes was called?
|
|
|
|
* This keeps sync from extra jobs and livelock.
|
|
|
|
*/
|
|
|
|
if (inode_dirtied_after(inode, start))
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
if (pin_sb_for_writeback(wbc, inode)) {
|
|
|
|
requeue_io(inode);
|
|
|
|
continue;
|
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-06-17 06:33:17 +08:00
|
|
|
BUG_ON(inode->i_state & (I_FREEING | I_CLEAR));
|
2005-04-17 06:20:36 +08:00
|
|
|
__iget(inode);
|
|
|
|
pages_skipped = wbc->pages_skipped;
|
2009-06-08 19:35:40 +08:00
|
|
|
writeback_single_inode(inode, wbc);
|
2009-09-09 15:08:54 +08:00
|
|
|
unpin_sb_for_writeback(wbc, inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
if (wbc->pages_skipped != pages_skipped) {
|
|
|
|
/*
|
|
|
|
* writeback is not making progress due to locked
|
|
|
|
* buffers. Skip this inode for now.
|
|
|
|
*/
|
writeback: fix time ordering of the per superblock dirty inode lists 3
While writeback is working against a dirty inode it does a check after trying
to write some of the inode's pages:
"did the lower layers skip some of the inode's dirty pages because they were
locked (or under writeback, or whatever)"
If this turns out to be true, we must move the inode back onto s_dirty and
redirty it. The reason for doing this is that fsync() and friends only check
the s_dirty list, and those functions want to know about those pages which
were locked, so they can be waited upon and, if necessary, rewritten.
Problem is, that redirtying was putting the inode onto the tail of s_dirty
without updating its timestamp. This causes a violation of s_dirty ordering.
Fix this by updating inode->dirtied_when when moving the inode onto s_dirty.
But the code is still a bit buggy? If the inode was _already_ dirty then we
don't need to move it at all. Oh well, hopefully it doesn't matter too much,
as that was a redirtying, which was very recent anwyay.
Cc: Mike Waychison <mikew@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2007-10-17 14:30:34 +08:00
|
|
|
redirty_tail(inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
iput(inode);
|
2006-03-25 19:07:44 +08:00
|
|
|
cond_resched();
|
2005-04-17 06:20:36 +08:00
|
|
|
spin_lock(&inode_lock);
|
writeback: speed up writeback of big dirty files
After making dirty a 100M file, the normal behavior is to start the
writeback for all data after 30s delays. But sometimes the following
happens instead:
- after 30s: ~4M
- after 5s: ~4M
- after 5s: all remaining 92M
Some analyze shows that the internal io dispatch queues goes like this:
s_io s_more_io
-------------------------
1) 100M,1K 0
2) 1K 96M
3) 0 96M
1) initial state with a 100M file and a 1K file
2) 4M written, nr_to_write <= 0, so write more
3) 1K written, nr_to_write > 0, no more writes(BUG)
nr_to_write > 0 in (3) fools the upper layer to think that data have all
been written out. The big dirty file is actually still sitting in
s_more_io. We cannot simply splice s_more_io back to s_io as soon as s_io
becomes empty, and let the loop in generic_sync_sb_inodes() continue: this
may starve newly expired inodes in s_dirty. It is also not an option to
draw inodes from both s_more_io and s_dirty, an let the loop go on: this
might lead to live locks, and might also starve other superblocks in sync
time(well kupdate may still starve some superblocks, that's another bug).
We have to return when a full scan of s_io completes. So nr_to_write > 0
does not necessarily mean that "all data are written". This patch
introduces a flag writeback_control.more_io to indicate that more io should
be done. With it the big dirty file no longer has to wait for the next
kupdate invokation 5s later.
In sync_sb_inodes() we only set more_io on super_blocks we actually
visited. This avoids the interaction between two pdflush deamons.
Also in __sync_single_inode() we don't blindly keep requeuing the io if the
filesystem cannot progress. Failing to do so may lead to 100% iowait.
Tested-by: Mike Snitzer <snitzer@gmail.com>
Signed-off-by: Fengguang Wu <wfg@mail.ustc.edu.cn>
Cc: Michael Rubin <mrubin@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-02-05 14:29:36 +08:00
|
|
|
if (wbc->nr_to_write <= 0) {
|
|
|
|
wbc->more_io = 1;
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
writeback: speed up writeback of big dirty files
After making dirty a 100M file, the normal behavior is to start the
writeback for all data after 30s delays. But sometimes the following
happens instead:
- after 30s: ~4M
- after 5s: ~4M
- after 5s: all remaining 92M
Some analyze shows that the internal io dispatch queues goes like this:
s_io s_more_io
-------------------------
1) 100M,1K 0
2) 1K 96M
3) 0 96M
1) initial state with a 100M file and a 1K file
2) 4M written, nr_to_write <= 0, so write more
3) 1K written, nr_to_write > 0, no more writes(BUG)
nr_to_write > 0 in (3) fools the upper layer to think that data have all
been written out. The big dirty file is actually still sitting in
s_more_io. We cannot simply splice s_more_io back to s_io as soon as s_io
becomes empty, and let the loop in generic_sync_sb_inodes() continue: this
may starve newly expired inodes in s_dirty. It is also not an option to
draw inodes from both s_more_io and s_dirty, an let the loop go on: this
might lead to live locks, and might also starve other superblocks in sync
time(well kupdate may still starve some superblocks, that's another bug).
We have to return when a full scan of s_io completes. So nr_to_write > 0
does not necessarily mean that "all data are written". This patch
introduces a flag writeback_control.more_io to indicate that more io should
be done. With it the big dirty file no longer has to wait for the next
kupdate invokation 5s later.
In sync_sb_inodes() we only set more_io on super_blocks we actually
visited. This avoids the interaction between two pdflush deamons.
Also in __sync_single_inode() we don't blindly keep requeuing the io if the
filesystem cannot progress. Failing to do so may lead to 100% iowait.
Tested-by: Mike Snitzer <snitzer@gmail.com>
Signed-off-by: Fengguang Wu <wfg@mail.ustc.edu.cn>
Cc: Michael Rubin <mrubin@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-02-05 14:29:36 +08:00
|
|
|
}
|
2009-09-09 15:08:54 +08:00
|
|
|
if (!list_empty(&wb->b_more_io))
|
writeback: speed up writeback of big dirty files
After making dirty a 100M file, the normal behavior is to start the
writeback for all data after 30s delays. But sometimes the following
happens instead:
- after 30s: ~4M
- after 5s: ~4M
- after 5s: all remaining 92M
Some analyze shows that the internal io dispatch queues goes like this:
s_io s_more_io
-------------------------
1) 100M,1K 0
2) 1K 96M
3) 0 96M
1) initial state with a 100M file and a 1K file
2) 4M written, nr_to_write <= 0, so write more
3) 1K written, nr_to_write > 0, no more writes(BUG)
nr_to_write > 0 in (3) fools the upper layer to think that data have all
been written out. The big dirty file is actually still sitting in
s_more_io. We cannot simply splice s_more_io back to s_io as soon as s_io
becomes empty, and let the loop in generic_sync_sb_inodes() continue: this
may starve newly expired inodes in s_dirty. It is also not an option to
draw inodes from both s_more_io and s_dirty, an let the loop go on: this
might lead to live locks, and might also starve other superblocks in sync
time(well kupdate may still starve some superblocks, that's another bug).
We have to return when a full scan of s_io completes. So nr_to_write > 0
does not necessarily mean that "all data are written". This patch
introduces a flag writeback_control.more_io to indicate that more io should
be done. With it the big dirty file no longer has to wait for the next
kupdate invokation 5s later.
In sync_sb_inodes() we only set more_io on super_blocks we actually
visited. This avoids the interaction between two pdflush deamons.
Also in __sync_single_inode() we don't blindly keep requeuing the io if the
filesystem cannot progress. Failing to do so may lead to 100% iowait.
Tested-by: Mike Snitzer <snitzer@gmail.com>
Signed-off-by: Fengguang Wu <wfg@mail.ustc.edu.cn>
Cc: Michael Rubin <mrubin@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
2008-02-05 14:29:36 +08:00
|
|
|
wbc->more_io = 1;
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
2009-01-07 06:40:25 +08:00
|
|
|
|
2009-09-02 15:19:46 +08:00
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
/* Leave any unwritten inodes on b_io */
|
|
|
|
}
|
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
void writeback_inodes_wbc(struct writeback_control *wbc)
|
|
|
|
{
|
|
|
|
struct backing_dev_info *bdi = wbc->bdi;
|
|
|
|
|
|
|
|
writeback_inodes_wb(&bdi->wb, wbc);
|
|
|
|
}
|
|
|
|
|
2009-09-02 15:19:46 +08:00
|
|
|
/*
|
2009-09-09 15:08:54 +08:00
|
|
|
* The maximum number of pages to writeout in a single bdi flush/kupdate
|
|
|
|
* operation. We do this so we don't hold I_SYNC against an inode for
|
|
|
|
* enormous amounts of time, which would block a userspace task which has
|
|
|
|
* been forced to throttle against that inode. Also, the code reevaluates
|
|
|
|
* the dirty each time it has written this many pages.
|
|
|
|
*/
|
|
|
|
#define MAX_WRITEBACK_PAGES 1024
|
|
|
|
|
|
|
|
static inline bool over_bground_thresh(void)
|
|
|
|
{
|
|
|
|
unsigned long background_thresh, dirty_thresh;
|
|
|
|
|
|
|
|
get_dirty_limits(&background_thresh, &dirty_thresh, NULL, NULL);
|
|
|
|
|
|
|
|
return (global_page_state(NR_FILE_DIRTY) +
|
|
|
|
global_page_state(NR_UNSTABLE_NFS) >= background_thresh);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Explicit flushing or periodic writeback of "old" data.
|
2009-09-02 15:19:46 +08:00
|
|
|
*
|
2009-09-09 15:08:54 +08:00
|
|
|
* Define "old": the first time one of an inode's pages is dirtied, we mark the
|
|
|
|
* dirtying-time in the inode's address_space. So this periodic writeback code
|
|
|
|
* just walks the superblock inode list, writing back any inodes which are
|
|
|
|
* older than a specific point in time.
|
2009-09-02 15:19:46 +08:00
|
|
|
*
|
2009-09-09 15:08:54 +08:00
|
|
|
* Try to run once per dirty_writeback_interval. But if a writeback event
|
|
|
|
* takes longer than a dirty_writeback_interval interval, then leave a
|
|
|
|
* one-second gap.
|
2009-09-02 15:19:46 +08:00
|
|
|
*
|
2009-09-09 15:08:54 +08:00
|
|
|
* older_than_this takes precedence over nr_to_write. So we'll only write back
|
|
|
|
* all dirty pages if they are all attached to "old" mappings.
|
2009-09-02 15:19:46 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
static long wb_writeback(struct bdi_writeback *wb, long nr_pages,
|
|
|
|
struct super_block *sb,
|
|
|
|
enum writeback_sync_modes sync_mode, int for_kupdate)
|
2009-09-02 15:19:46 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
struct writeback_control wbc = {
|
|
|
|
.bdi = wb->bdi,
|
|
|
|
.sb = sb,
|
|
|
|
.sync_mode = sync_mode,
|
|
|
|
.older_than_this = NULL,
|
|
|
|
.for_kupdate = for_kupdate,
|
|
|
|
.range_cyclic = 1,
|
|
|
|
};
|
|
|
|
unsigned long oldest_jif;
|
|
|
|
long wrote = 0;
|
2009-09-02 15:19:46 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
if (wbc.for_kupdate) {
|
|
|
|
wbc.older_than_this = &oldest_jif;
|
|
|
|
oldest_jif = jiffies -
|
|
|
|
msecs_to_jiffies(dirty_expire_interval * 10);
|
|
|
|
}
|
2009-01-07 06:40:25 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
for (;;) {
|
|
|
|
/*
|
|
|
|
* Don't flush anything for non-integrity writeback where
|
|
|
|
* no nr_pages was given
|
|
|
|
*/
|
|
|
|
if (!for_kupdate && nr_pages <= 0 && sync_mode == WB_SYNC_NONE)
|
|
|
|
break;
|
2009-09-02 15:19:46 +08:00
|
|
|
|
2009-01-07 06:40:25 +08:00
|
|
|
/*
|
2009-09-09 15:08:54 +08:00
|
|
|
* If no specific pages were given and this is just a
|
|
|
|
* periodic background writeout and we are below the
|
|
|
|
* background dirty threshold, don't do anything
|
2009-01-07 06:40:25 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
if (for_kupdate && nr_pages <= 0 && !over_bground_thresh())
|
|
|
|
break;
|
2009-01-07 06:40:25 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
wbc.more_io = 0;
|
|
|
|
wbc.encountered_congestion = 0;
|
|
|
|
wbc.nr_to_write = MAX_WRITEBACK_PAGES;
|
|
|
|
wbc.pages_skipped = 0;
|
|
|
|
writeback_inodes_wb(wb, &wbc);
|
|
|
|
nr_pages -= MAX_WRITEBACK_PAGES - wbc.nr_to_write;
|
|
|
|
wrote += MAX_WRITEBACK_PAGES - wbc.nr_to_write;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If we ran out of stuff to write, bail unless more_io got set
|
|
|
|
*/
|
|
|
|
if (wbc.nr_to_write > 0 || wbc.pages_skipped > 0) {
|
|
|
|
if (wbc.more_io && !wbc.for_kupdate)
|
2009-01-07 06:40:25 +08:00
|
|
|
continue;
|
2009-09-09 15:08:54 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return wrote;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Return the next bdi_work struct that hasn't been processed by this
|
|
|
|
* wb thread yet
|
|
|
|
*/
|
|
|
|
static struct bdi_work *get_next_work_item(struct backing_dev_info *bdi,
|
|
|
|
struct bdi_writeback *wb)
|
|
|
|
{
|
|
|
|
struct bdi_work *work, *ret = NULL;
|
|
|
|
|
|
|
|
rcu_read_lock();
|
|
|
|
|
|
|
|
list_for_each_entry_rcu(work, &bdi->work_list, list) {
|
|
|
|
if (!test_and_clear_bit(wb->nr, &work->seen))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
ret = work;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
rcu_read_unlock();
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
static long wb_check_old_data_flush(struct bdi_writeback *wb)
|
|
|
|
{
|
|
|
|
unsigned long expired;
|
|
|
|
long nr_pages;
|
|
|
|
|
|
|
|
expired = wb->last_old_flush +
|
|
|
|
msecs_to_jiffies(dirty_writeback_interval * 10);
|
|
|
|
if (time_before(jiffies, expired))
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
wb->last_old_flush = jiffies;
|
|
|
|
nr_pages = global_page_state(NR_FILE_DIRTY) +
|
|
|
|
global_page_state(NR_UNSTABLE_NFS) +
|
|
|
|
(inodes_stat.nr_inodes - inodes_stat.nr_unused);
|
|
|
|
|
|
|
|
if (nr_pages)
|
|
|
|
return wb_writeback(wb, nr_pages, NULL, WB_SYNC_NONE, 1);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Retrieve work items and do the writeback they describe
|
|
|
|
*/
|
|
|
|
long wb_do_writeback(struct bdi_writeback *wb, int force_wait)
|
|
|
|
{
|
|
|
|
struct backing_dev_info *bdi = wb->bdi;
|
|
|
|
struct bdi_work *work;
|
|
|
|
long nr_pages, wrote = 0;
|
|
|
|
|
|
|
|
while ((work = get_next_work_item(bdi, wb)) != NULL) {
|
|
|
|
enum writeback_sync_modes sync_mode;
|
|
|
|
|
|
|
|
nr_pages = work->nr_pages;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Override sync mode, in case we must wait for completion
|
|
|
|
*/
|
|
|
|
if (force_wait)
|
|
|
|
work->sync_mode = sync_mode = WB_SYNC_ALL;
|
|
|
|
else
|
|
|
|
sync_mode = work->sync_mode;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If this isn't a data integrity operation, just notify
|
|
|
|
* that we have seen this work and we are now starting it.
|
|
|
|
*/
|
|
|
|
if (sync_mode == WB_SYNC_NONE)
|
|
|
|
wb_clear_pending(wb, work);
|
|
|
|
|
|
|
|
wrote += wb_writeback(wb, nr_pages, work->sb, sync_mode, 0);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is a data integrity writeback, so only do the
|
|
|
|
* notification when we have completed the work.
|
|
|
|
*/
|
|
|
|
if (sync_mode == WB_SYNC_ALL)
|
|
|
|
wb_clear_pending(wb, work);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Check for periodic writeback, kupdated() style
|
|
|
|
*/
|
|
|
|
wrote += wb_check_old_data_flush(wb);
|
|
|
|
|
|
|
|
return wrote;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Handle writeback of dirty data for the device backed by this bdi. Also
|
|
|
|
* wakes up periodically and does kupdated style flushing.
|
|
|
|
*/
|
|
|
|
int bdi_writeback_task(struct bdi_writeback *wb)
|
|
|
|
{
|
|
|
|
unsigned long last_active = jiffies;
|
|
|
|
unsigned long wait_jiffies = -1UL;
|
|
|
|
long pages_written;
|
|
|
|
|
|
|
|
while (!kthread_should_stop()) {
|
|
|
|
pages_written = wb_do_writeback(wb, 0);
|
|
|
|
|
|
|
|
if (pages_written)
|
|
|
|
last_active = jiffies;
|
|
|
|
else if (wait_jiffies != -1UL) {
|
|
|
|
unsigned long max_idle;
|
|
|
|
|
2009-01-07 06:40:25 +08:00
|
|
|
/*
|
2009-09-09 15:08:54 +08:00
|
|
|
* Longest period of inactivity that we tolerate. If we
|
|
|
|
* see dirty data again later, the task will get
|
|
|
|
* recreated automatically.
|
2009-01-07 06:40:25 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
max_idle = max(5UL * 60 * HZ, wait_jiffies);
|
|
|
|
if (time_after(jiffies, max_idle + last_active))
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
wait_jiffies = msecs_to_jiffies(dirty_writeback_interval * 10);
|
|
|
|
set_current_state(TASK_INTERRUPTIBLE);
|
|
|
|
schedule_timeout(wait_jiffies);
|
|
|
|
try_to_freeze();
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Schedule writeback for all backing devices. Expensive! If this is a data
|
|
|
|
* integrity operation, writeback will be complete when this returns. If
|
|
|
|
* we are simply called for WB_SYNC_NONE, then writeback will merely be
|
|
|
|
* scheduled to run.
|
|
|
|
*/
|
|
|
|
static void bdi_writeback_all(struct writeback_control *wbc)
|
|
|
|
{
|
|
|
|
const bool must_wait = wbc->sync_mode == WB_SYNC_ALL;
|
|
|
|
struct backing_dev_info *bdi;
|
|
|
|
struct bdi_work *work;
|
|
|
|
LIST_HEAD(list);
|
|
|
|
|
|
|
|
restart:
|
|
|
|
spin_lock(&bdi_lock);
|
|
|
|
|
|
|
|
list_for_each_entry(bdi, &bdi_list, bdi_list) {
|
|
|
|
struct bdi_work *work;
|
|
|
|
|
|
|
|
if (!bdi_has_dirty_io(bdi))
|
|
|
|
continue;
|
2009-01-07 06:40:25 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
/*
|
|
|
|
* If work allocation fails, do the writes inline. We drop
|
|
|
|
* the lock and restart the list writeout. This should be OK,
|
|
|
|
* since this happens rarely and because the writeout should
|
|
|
|
* eventually make more free memory available.
|
|
|
|
*/
|
|
|
|
work = bdi_alloc_work(wbc);
|
|
|
|
if (!work) {
|
|
|
|
struct writeback_control __wbc;
|
2009-01-07 06:40:25 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
/*
|
|
|
|
* Not a data integrity writeout, just continue
|
|
|
|
*/
|
|
|
|
if (!must_wait)
|
|
|
|
continue;
|
2009-01-07 06:40:25 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
spin_unlock(&bdi_lock);
|
|
|
|
__wbc = *wbc;
|
|
|
|
__wbc.bdi = bdi;
|
|
|
|
writeback_inodes_wbc(&__wbc);
|
|
|
|
goto restart;
|
2009-01-07 06:40:25 +08:00
|
|
|
}
|
2009-09-09 15:08:54 +08:00
|
|
|
if (must_wait)
|
|
|
|
list_add_tail(&work->wait_list, &list);
|
|
|
|
|
|
|
|
bdi_queue_work(bdi, work);
|
|
|
|
}
|
|
|
|
|
|
|
|
spin_unlock(&bdi_lock);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If this is for WB_SYNC_ALL, wait for pending work to complete
|
|
|
|
* before returning.
|
|
|
|
*/
|
|
|
|
while (!list_empty(&list)) {
|
|
|
|
work = list_entry(list.next, struct bdi_work, wait_list);
|
|
|
|
list_del(&work->wait_list);
|
|
|
|
bdi_wait_on_work_clear(work);
|
|
|
|
call_rcu(&work->rcu_head, bdi_work_free);
|
2009-09-02 15:19:46 +08:00
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2009-09-09 15:08:54 +08:00
|
|
|
* Start writeback of `nr_pages' pages. If `nr_pages' is zero, write back
|
|
|
|
* the whole world.
|
|
|
|
*/
|
|
|
|
void wakeup_flusher_threads(long nr_pages)
|
|
|
|
{
|
|
|
|
struct writeback_control wbc = {
|
|
|
|
.sync_mode = WB_SYNC_NONE,
|
|
|
|
.older_than_this = NULL,
|
|
|
|
.range_cyclic = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
if (nr_pages == 0)
|
|
|
|
nr_pages = global_page_state(NR_FILE_DIRTY) +
|
|
|
|
global_page_state(NR_UNSTABLE_NFS);
|
|
|
|
wbc.nr_to_write = nr_pages;
|
|
|
|
bdi_writeback_all(&wbc);
|
|
|
|
}
|
|
|
|
|
|
|
|
static noinline void block_dump___mark_inode_dirty(struct inode *inode)
|
|
|
|
{
|
|
|
|
if (inode->i_ino || strcmp(inode->i_sb->s_id, "bdev")) {
|
|
|
|
struct dentry *dentry;
|
|
|
|
const char *name = "?";
|
|
|
|
|
|
|
|
dentry = d_find_alias(inode);
|
|
|
|
if (dentry) {
|
|
|
|
spin_lock(&dentry->d_lock);
|
|
|
|
name = (const char *) dentry->d_name.name;
|
|
|
|
}
|
|
|
|
printk(KERN_DEBUG
|
|
|
|
"%s(%d): dirtied inode %lu (%s) on %s\n",
|
|
|
|
current->comm, task_pid_nr(current), inode->i_ino,
|
|
|
|
name, inode->i_sb->s_id);
|
|
|
|
if (dentry) {
|
|
|
|
spin_unlock(&dentry->d_lock);
|
|
|
|
dput(dentry);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* __mark_inode_dirty - internal function
|
|
|
|
* @inode: inode to mark
|
|
|
|
* @flags: what kind of dirty (i.e. I_DIRTY_SYNC)
|
|
|
|
* Mark an inode as dirty. Callers should use mark_inode_dirty or
|
|
|
|
* mark_inode_dirty_sync.
|
2005-04-17 06:20:36 +08:00
|
|
|
*
|
2009-09-09 15:08:54 +08:00
|
|
|
* Put the inode on the super block's dirty list.
|
|
|
|
*
|
|
|
|
* CAREFUL! We mark it dirty unconditionally, but move it onto the
|
|
|
|
* dirty list only if it is hashed or if it refers to a blockdev.
|
|
|
|
* If it was not hashed, it will never be added to the dirty list
|
|
|
|
* even if it is later hashed, as it will have been marked dirty already.
|
|
|
|
*
|
|
|
|
* In short, make sure you hash any inodes _before_ you start marking
|
|
|
|
* them dirty.
|
2005-04-17 06:20:36 +08:00
|
|
|
*
|
2009-09-09 15:08:54 +08:00
|
|
|
* This function *must* be atomic for the I_DIRTY_PAGES case -
|
|
|
|
* set_page_dirty() is called under spinlock in several places.
|
2005-04-17 06:20:36 +08:00
|
|
|
*
|
2009-09-09 15:08:54 +08:00
|
|
|
* Note that for blockdevs, inode->dirtied_when represents the dirtying time of
|
|
|
|
* the block-special inode (/dev/hda1) itself. And the ->dirtied_when field of
|
|
|
|
* the kernel-internal blockdev inode represents the dirtying time of the
|
|
|
|
* blockdev's pages. This is why for I_DIRTY_PAGES we always use
|
|
|
|
* page->mapping->host, so the page-dirtying time is recorded in the internal
|
|
|
|
* blockdev inode.
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
2009-09-09 15:08:54 +08:00
|
|
|
void __mark_inode_dirty(struct inode *inode, int flags)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2009-09-09 15:08:54 +08:00
|
|
|
struct super_block *sb = inode->i_sb;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-09 15:08:54 +08:00
|
|
|
/*
|
|
|
|
* Don't do this for I_DIRTY_PAGES - that doesn't actually
|
|
|
|
* dirty the inode itself
|
|
|
|
*/
|
|
|
|
if (flags & (I_DIRTY_SYNC | I_DIRTY_DATASYNC)) {
|
|
|
|
if (sb->s_op->dirty_inode)
|
|
|
|
sb->s_op->dirty_inode(inode);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* make sure that changes are seen by all cpus before we test i_state
|
|
|
|
* -- mikulas
|
|
|
|
*/
|
|
|
|
smp_mb();
|
|
|
|
|
|
|
|
/* avoid the locking if we can */
|
|
|
|
if ((inode->i_state & flags) == flags)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (unlikely(block_dump))
|
|
|
|
block_dump___mark_inode_dirty(inode);
|
|
|
|
|
|
|
|
spin_lock(&inode_lock);
|
|
|
|
if ((inode->i_state & flags) != flags) {
|
|
|
|
const int was_dirty = inode->i_state & I_DIRTY;
|
|
|
|
|
|
|
|
inode->i_state |= flags;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If the inode is being synced, just update its dirty state.
|
|
|
|
* The unlocker will place the inode on the appropriate
|
|
|
|
* superblock list, based upon its state.
|
|
|
|
*/
|
|
|
|
if (inode->i_state & I_SYNC)
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Only add valid (hashed) inodes to the superblock's
|
|
|
|
* dirty list. Add blockdev inodes as well.
|
|
|
|
*/
|
|
|
|
if (!S_ISBLK(inode->i_mode)) {
|
|
|
|
if (hlist_unhashed(&inode->i_hash))
|
|
|
|
goto out;
|
|
|
|
}
|
|
|
|
if (inode->i_state & (I_FREEING|I_CLEAR))
|
|
|
|
goto out;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If the inode was already on b_dirty/b_io/b_more_io, don't
|
|
|
|
* reposition it (that would break b_dirty time-ordering).
|
|
|
|
*/
|
|
|
|
if (!was_dirty) {
|
|
|
|
struct bdi_writeback *wb = &inode_to_bdi(inode)->wb;
|
2009-09-09 15:10:25 +08:00
|
|
|
struct backing_dev_info *bdi = wb->bdi;
|
|
|
|
|
|
|
|
if (bdi_cap_writeback_dirty(bdi) &&
|
|
|
|
!test_bit(BDI_registered, &bdi->state)) {
|
|
|
|
WARN_ON(1);
|
|
|
|
printk(KERN_ERR "bdi-%s not registered\n",
|
|
|
|
bdi->name);
|
|
|
|
}
|
2009-09-09 15:08:54 +08:00
|
|
|
|
|
|
|
inode->dirtied_when = jiffies;
|
|
|
|
list_move(&inode->i_list, &wb->b_dirty);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
}
|
2009-09-09 15:08:54 +08:00
|
|
|
out:
|
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(__mark_inode_dirty);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Write out a superblock's list of dirty inodes. A wait will be performed
|
|
|
|
* upon no inodes, all inodes or the final one, depending upon sync_mode.
|
|
|
|
*
|
|
|
|
* If older_than_this is non-NULL, then only write out inodes which
|
|
|
|
* had their first dirtying at a time earlier than *older_than_this.
|
|
|
|
*
|
|
|
|
* If we're a pdlfush thread, then implement pdflush collision avoidance
|
|
|
|
* against the entire list.
|
|
|
|
*
|
|
|
|
* If `bdi' is non-zero then we're being asked to writeback a specific queue.
|
|
|
|
* This function assumes that the blockdev superblock's inodes are backed by
|
|
|
|
* a variety of queues, so all inodes are searched. For other superblocks,
|
|
|
|
* assume that all inodes are backed by the same queue.
|
|
|
|
*
|
|
|
|
* The inodes to be written are parked on bdi->b_io. They are moved back onto
|
|
|
|
* bdi->b_dirty as they are selected for writing. This way, none can be missed
|
|
|
|
* on the writer throttling path, and we get decent balancing between many
|
|
|
|
* throttled threads: we don't want them all piling up on inode_sync_wait.
|
|
|
|
*/
|
|
|
|
static void wait_sb_inodes(struct writeback_control *wbc)
|
|
|
|
{
|
|
|
|
struct inode *inode, *old_inode = NULL;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* We need to be protected against the filesystem going from
|
|
|
|
* r/o to r/w or vice versa.
|
|
|
|
*/
|
|
|
|
WARN_ON(!rwsem_is_locked(&wbc->sb->s_umount));
|
|
|
|
|
|
|
|
spin_lock(&inode_lock);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Data integrity sync. Must wait for all pages under writeback,
|
|
|
|
* because there may have been pages dirtied before our sync
|
|
|
|
* call, but which had writeout started before we write it out.
|
|
|
|
* In which case, the inode may not be on the dirty list, but
|
|
|
|
* we still have to wait for that writeout.
|
|
|
|
*/
|
|
|
|
list_for_each_entry(inode, &wbc->sb->s_inodes, i_sb_list) {
|
|
|
|
struct address_space *mapping;
|
|
|
|
|
|
|
|
if (inode->i_state & (I_FREEING|I_CLEAR|I_WILL_FREE|I_NEW))
|
|
|
|
continue;
|
|
|
|
mapping = inode->i_mapping;
|
|
|
|
if (mapping->nrpages == 0)
|
|
|
|
continue;
|
|
|
|
__iget(inode);
|
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
/*
|
|
|
|
* We hold a reference to 'inode' so it couldn't have
|
|
|
|
* been removed from s_inodes list while we dropped the
|
|
|
|
* inode_lock. We cannot iput the inode now as we can
|
|
|
|
* be holding the last reference and we cannot iput it
|
|
|
|
* under inode_lock. So we keep the reference and iput
|
|
|
|
* it later.
|
|
|
|
*/
|
|
|
|
iput(old_inode);
|
|
|
|
old_inode = inode;
|
|
|
|
|
|
|
|
filemap_fdatawait(mapping);
|
|
|
|
|
|
|
|
cond_resched();
|
|
|
|
|
|
|
|
spin_lock(&inode_lock);
|
|
|
|
}
|
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
iput(old_inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
2009-09-02 18:34:32 +08:00
|
|
|
/**
|
|
|
|
* writeback_inodes_sb - writeback dirty inodes from given super_block
|
|
|
|
* @sb: the superblock
|
2005-04-17 06:20:36 +08:00
|
|
|
*
|
2009-09-02 18:34:32 +08:00
|
|
|
* Start writeback on some inodes on this super_block. No guarantees are made
|
|
|
|
* on how many (if any) will be written, and this function does not wait
|
|
|
|
* for IO completion of submitted IO. The number of pages submitted is
|
|
|
|
* returned.
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
2009-09-02 18:34:32 +08:00
|
|
|
long writeback_inodes_sb(struct super_block *sb)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
|
|
|
struct writeback_control wbc = {
|
2009-09-09 15:08:54 +08:00
|
|
|
.sb = sb,
|
2009-09-02 18:34:32 +08:00
|
|
|
.sync_mode = WB_SYNC_NONE,
|
[PATCH] writeback: fix range handling
When a writeback_control's `start' and `end' fields are used to
indicate a one-byte-range starting at file offset zero, the required
values of .start=0,.end=0 mean that the ->writepages() implementation
has no way of telling that it is being asked to perform a range
request. Because we're currently overloading (start == 0 && end == 0)
to mean "this is not a write-a-range request".
To make all this sane, the patch changes range of writeback_control.
So caller does: If it is calling ->writepages() to write pages, it
sets range (range_start/end or range_cyclic) always.
And if range_cyclic is true, ->writepages() thinks the range is
cyclic, otherwise it just uses range_start and range_end.
This patch does,
- Add LLONG_MAX, LLONG_MIN, ULLONG_MAX to include/linux/kernel.h
-1 is usually ok for range_end (type is long long). But, if someone did,
range_end += val; range_end is "val - 1"
u64val = range_end >> bits; u64val is "~(0ULL)"
or something, they are wrong. So, this adds LLONG_MAX to avoid nasty
things, and uses LLONG_MAX for range_end.
- All callers of ->writepages() sets range_start/end or range_cyclic.
- Fix updates of ->writeback_index. It seems already bit strange.
If it starts at 0 and ended by check of nr_to_write, this last
index may reduce chance to scan end of file. So, this updates
->writeback_index only if range_cyclic is true or whole-file is
scanned.
Signed-off-by: OGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
Cc: Nathan Scott <nathans@sgi.com>
Cc: Anton Altaparmakov <aia21@cantab.net>
Cc: Steven French <sfrench@us.ibm.com>
Cc: "Vladimir V. Saveliev" <vs@namesys.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
2006-06-23 17:03:26 +08:00
|
|
|
.range_start = 0,
|
|
|
|
.range_end = LLONG_MAX,
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
2009-09-02 18:34:32 +08:00
|
|
|
unsigned long nr_dirty = global_page_state(NR_FILE_DIRTY);
|
|
|
|
unsigned long nr_unstable = global_page_state(NR_UNSTABLE_NFS);
|
|
|
|
long nr_to_write;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2009-09-02 18:34:32 +08:00
|
|
|
nr_to_write = nr_dirty + nr_unstable +
|
2009-01-07 06:40:25 +08:00
|
|
|
(inodes_stat.nr_inodes - inodes_stat.nr_unused);
|
|
|
|
|
2009-09-02 18:34:32 +08:00
|
|
|
wbc.nr_to_write = nr_to_write;
|
2009-09-09 15:08:54 +08:00
|
|
|
bdi_writeback_all(&wbc);
|
2009-09-02 18:34:32 +08:00
|
|
|
return nr_to_write - wbc.nr_to_write;
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(writeback_inodes_sb);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* sync_inodes_sb - sync sb inode pages
|
|
|
|
* @sb: the superblock
|
|
|
|
*
|
|
|
|
* This function writes and waits on any dirty inode belonging to this
|
|
|
|
* super_block. The number of pages synced is returned.
|
|
|
|
*/
|
|
|
|
long sync_inodes_sb(struct super_block *sb)
|
|
|
|
{
|
|
|
|
struct writeback_control wbc = {
|
2009-09-09 15:08:54 +08:00
|
|
|
.sb = sb,
|
2009-09-02 18:34:32 +08:00
|
|
|
.sync_mode = WB_SYNC_ALL,
|
|
|
|
.range_start = 0,
|
|
|
|
.range_end = LLONG_MAX,
|
|
|
|
};
|
|
|
|
long nr_to_write = LONG_MAX; /* doesn't actually matter */
|
|
|
|
|
|
|
|
wbc.nr_to_write = nr_to_write;
|
2009-09-09 15:08:54 +08:00
|
|
|
bdi_writeback_all(&wbc);
|
|
|
|
wait_sb_inodes(&wbc);
|
2009-09-02 18:34:32 +08:00
|
|
|
return nr_to_write - wbc.nr_to_write;
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
2009-09-02 18:34:32 +08:00
|
|
|
EXPORT_SYMBOL(sync_inodes_sb);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/**
|
[PATCH] fix nr_unused accounting, and avoid recursing in iput with I_WILL_FREE set
list_move(&inode->i_list, &inode_in_use);
} else {
list_move(&inode->i_list, &inode_unused);
+ inodes_stat.nr_unused++;
}
}
wake_up_inode(inode);
Are you sure the above diff is correct? It was added somewhere between
2.6.5 and 2.6.8. I think it's wrong.
The only way I can imagine the i_count to be zero in the above path, is
that I_WILL_FREE is set. And if I_WILL_FREE is set, then we must not
increase nr_unused. So I believe the above change is buggy and it will
definitely overstate the number of unused inodes and it should be backed
out.
Note that __writeback_single_inode before calling __sync_single_inode, can
drop the spinlock and we can have both the dirty and locked bitflags clear
here:
spin_unlock(&inode_lock);
__wait_on_inode(inode);
iput(inode);
XXXXXXX
spin_lock(&inode_lock);
}
use inode again here
a construct like the above makes zero sense from a reference counting
standpoint.
Either we don't ever use the inode again after the iput, or the
inode_lock should be taken _before_ executing the iput (i.e. a __iput
would be required). Taking the inode_lock after iput means the iget was
useless if we keep using the inode after the iput.
So the only chance the 2.6 was safe to call __writeback_single_inode
with the i_count == 0, is that I_WILL_FREE is set (I_WILL_FREE will
prevent the VM to free the inode in XXXXX).
Potentially calling the above iput with I_WILL_FREE was also wrong
because it would recurse in iput_final (the second mainline bug).
The below (untested) patch fixes the nr_unused accounting, avoids recursing
in iput when I_WILL_FREE is set and makes sure (with the BUG_ON) that we
don't corrupt memory and that all holders that don't set I_WILL_FREE, keeps
a reference on the inode!
Signed-off-by: Andrea Arcangeli <andrea@suse.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
2005-10-31 07:03:05 +08:00
|
|
|
* write_inode_now - write an inode to disk
|
|
|
|
* @inode: inode to write to disk
|
|
|
|
* @sync: whether the write should be synchronous or not
|
|
|
|
*
|
|
|
|
* This function commits an inode to disk immediately if it is dirty. This is
|
|
|
|
* primarily needed by knfsd.
|
2005-04-17 06:20:36 +08:00
|
|
|
*
|
[PATCH] fix nr_unused accounting, and avoid recursing in iput with I_WILL_FREE set
list_move(&inode->i_list, &inode_in_use);
} else {
list_move(&inode->i_list, &inode_unused);
+ inodes_stat.nr_unused++;
}
}
wake_up_inode(inode);
Are you sure the above diff is correct? It was added somewhere between
2.6.5 and 2.6.8. I think it's wrong.
The only way I can imagine the i_count to be zero in the above path, is
that I_WILL_FREE is set. And if I_WILL_FREE is set, then we must not
increase nr_unused. So I believe the above change is buggy and it will
definitely overstate the number of unused inodes and it should be backed
out.
Note that __writeback_single_inode before calling __sync_single_inode, can
drop the spinlock and we can have both the dirty and locked bitflags clear
here:
spin_unlock(&inode_lock);
__wait_on_inode(inode);
iput(inode);
XXXXXXX
spin_lock(&inode_lock);
}
use inode again here
a construct like the above makes zero sense from a reference counting
standpoint.
Either we don't ever use the inode again after the iput, or the
inode_lock should be taken _before_ executing the iput (i.e. a __iput
would be required). Taking the inode_lock after iput means the iget was
useless if we keep using the inode after the iput.
So the only chance the 2.6 was safe to call __writeback_single_inode
with the i_count == 0, is that I_WILL_FREE is set (I_WILL_FREE will
prevent the VM to free the inode in XXXXX).
Potentially calling the above iput with I_WILL_FREE was also wrong
because it would recurse in iput_final (the second mainline bug).
The below (untested) patch fixes the nr_unused accounting, avoids recursing
in iput when I_WILL_FREE is set and makes sure (with the BUG_ON) that we
don't corrupt memory and that all holders that don't set I_WILL_FREE, keeps
a reference on the inode!
Signed-off-by: Andrea Arcangeli <andrea@suse.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
2005-10-31 07:03:05 +08:00
|
|
|
* The caller must either have a ref on the inode or must have set I_WILL_FREE.
|
2005-04-17 06:20:36 +08:00
|
|
|
*/
|
|
|
|
int write_inode_now(struct inode *inode, int sync)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct writeback_control wbc = {
|
|
|
|
.nr_to_write = LONG_MAX,
|
2008-02-08 20:20:23 +08:00
|
|
|
.sync_mode = sync ? WB_SYNC_ALL : WB_SYNC_NONE,
|
[PATCH] writeback: fix range handling
When a writeback_control's `start' and `end' fields are used to
indicate a one-byte-range starting at file offset zero, the required
values of .start=0,.end=0 mean that the ->writepages() implementation
has no way of telling that it is being asked to perform a range
request. Because we're currently overloading (start == 0 && end == 0)
to mean "this is not a write-a-range request".
To make all this sane, the patch changes range of writeback_control.
So caller does: If it is calling ->writepages() to write pages, it
sets range (range_start/end or range_cyclic) always.
And if range_cyclic is true, ->writepages() thinks the range is
cyclic, otherwise it just uses range_start and range_end.
This patch does,
- Add LLONG_MAX, LLONG_MIN, ULLONG_MAX to include/linux/kernel.h
-1 is usually ok for range_end (type is long long). But, if someone did,
range_end += val; range_end is "val - 1"
u64val = range_end >> bits; u64val is "~(0ULL)"
or something, they are wrong. So, this adds LLONG_MAX to avoid nasty
things, and uses LLONG_MAX for range_end.
- All callers of ->writepages() sets range_start/end or range_cyclic.
- Fix updates of ->writeback_index. It seems already bit strange.
If it starts at 0 and ended by check of nr_to_write, this last
index may reduce chance to scan end of file. So, this updates
->writeback_index only if range_cyclic is true or whole-file is
scanned.
Signed-off-by: OGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
Cc: Nathan Scott <nathans@sgi.com>
Cc: Anton Altaparmakov <aia21@cantab.net>
Cc: Steven French <sfrench@us.ibm.com>
Cc: "Vladimir V. Saveliev" <vs@namesys.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
2006-06-23 17:03:26 +08:00
|
|
|
.range_start = 0,
|
|
|
|
.range_end = LLONG_MAX,
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
if (!mapping_cap_writeback_dirty(inode->i_mapping))
|
2005-11-07 16:59:15 +08:00
|
|
|
wbc.nr_to_write = 0;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
might_sleep();
|
|
|
|
spin_lock(&inode_lock);
|
2009-06-08 19:35:40 +08:00
|
|
|
ret = writeback_single_inode(inode, &wbc);
|
2005-04-17 06:20:36 +08:00
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
if (sync)
|
2007-10-17 14:30:44 +08:00
|
|
|
inode_sync_wait(inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(write_inode_now);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* sync_inode - write an inode and its pages to disk.
|
|
|
|
* @inode: the inode to sync
|
|
|
|
* @wbc: controls the writeback mode
|
|
|
|
*
|
|
|
|
* sync_inode() will write an inode and its pages to disk. It will also
|
|
|
|
* correctly update the inode on its superblock's dirty inode lists and will
|
|
|
|
* update inode->i_state.
|
|
|
|
*
|
|
|
|
* The caller must have a ref on the inode.
|
|
|
|
*/
|
|
|
|
int sync_inode(struct inode *inode, struct writeback_control *wbc)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
spin_lock(&inode_lock);
|
2009-06-08 19:35:40 +08:00
|
|
|
ret = writeback_single_inode(inode, wbc);
|
2005-04-17 06:20:36 +08:00
|
|
|
spin_unlock(&inode_lock);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(sync_inode);
|