diff options
author | Kent Overstreet <kmo@daterainc.com> | 2014-02-19 22:48:26 -0500 |
---|---|---|
committer | Kent Overstreet <kmo@daterainc.com> | 2014-02-25 21:42:49 -0500 |
commit | dabb44334060b4b84051b34c58573e57cc7432b2 (patch) | |
tree | 7372c3f3d4d6309c4ee4214494f93c6e7fcc3d58 | |
parent | 1b4eaf3d3809a658c85911e92d9ff64086931efa (diff) |
bcache: Fix a shutdown bug
Shutdown wasn't cancelling/waiting on journal_write_work()
Signed-off-by: Kent Overstreet <kmo@daterainc.com>
-rw-r--r-- | drivers/md/bcache/journal.c | 9 | ||||
-rw-r--r-- | drivers/md/bcache/journal.h | 1 | ||||
-rw-r--r-- | drivers/md/bcache/super.c | 4 |
3 files changed, 12 insertions, 2 deletions
diff --git a/drivers/md/bcache/journal.c b/drivers/md/bcache/journal.c index 18039affc306..e38c5997bf12 100644 --- a/drivers/md/bcache/journal.c +++ b/drivers/md/bcache/journal.c | |||
@@ -536,6 +536,7 @@ void bch_journal_next(struct journal *j) | |||
536 | atomic_set(&fifo_back(&j->pin), 1); | 536 | atomic_set(&fifo_back(&j->pin), 1); |
537 | 537 | ||
538 | j->cur->data->seq = ++j->seq; | 538 | j->cur->data->seq = ++j->seq; |
539 | j->cur->dirty = false; | ||
539 | j->cur->need_write = false; | 540 | j->cur->need_write = false; |
540 | j->cur->data->keys = 0; | 541 | j->cur->data->keys = 0; |
541 | 542 | ||
@@ -731,7 +732,10 @@ static void journal_write_work(struct work_struct *work) | |||
731 | struct cache_set, | 732 | struct cache_set, |
732 | journal.work); | 733 | journal.work); |
733 | spin_lock(&c->journal.lock); | 734 | spin_lock(&c->journal.lock); |
734 | journal_try_write(c); | 735 | if (c->journal.cur->dirty) |
736 | journal_try_write(c); | ||
737 | else | ||
738 | spin_unlock(&c->journal.lock); | ||
735 | } | 739 | } |
736 | 740 | ||
737 | /* | 741 | /* |
@@ -761,7 +765,8 @@ atomic_t *bch_journal(struct cache_set *c, | |||
761 | if (parent) { | 765 | if (parent) { |
762 | closure_wait(&w->wait, parent); | 766 | closure_wait(&w->wait, parent); |
763 | journal_try_write(c); | 767 | journal_try_write(c); |
764 | } else if (!w->need_write) { | 768 | } else if (!w->dirty) { |
769 | w->dirty = true; | ||
765 | schedule_delayed_work(&c->journal.work, | 770 | schedule_delayed_work(&c->journal.work, |
766 | msecs_to_jiffies(c->journal_delay_ms)); | 771 | msecs_to_jiffies(c->journal_delay_ms)); |
767 | spin_unlock(&c->journal.lock); | 772 | spin_unlock(&c->journal.lock); |
diff --git a/drivers/md/bcache/journal.h b/drivers/md/bcache/journal.h index 9180c4465075..e3c39457afbb 100644 --- a/drivers/md/bcache/journal.h +++ b/drivers/md/bcache/journal.h | |||
@@ -95,6 +95,7 @@ struct journal_write { | |||
95 | 95 | ||
96 | struct cache_set *c; | 96 | struct cache_set *c; |
97 | struct closure_waitlist wait; | 97 | struct closure_waitlist wait; |
98 | bool dirty; | ||
98 | bool need_write; | 99 | bool need_write; |
99 | }; | 100 | }; |
100 | 101 | ||
diff --git a/drivers/md/bcache/super.c b/drivers/md/bcache/super.c index 24a3a1546caa..c70521fe57a6 100644 --- a/drivers/md/bcache/super.c +++ b/drivers/md/bcache/super.c | |||
@@ -1403,6 +1403,10 @@ static void cache_set_flush(struct closure *cl) | |||
1403 | if (ca->alloc_thread) | 1403 | if (ca->alloc_thread) |
1404 | kthread_stop(ca->alloc_thread); | 1404 | kthread_stop(ca->alloc_thread); |
1405 | 1405 | ||
1406 | cancel_delayed_work_sync(&c->journal.work); | ||
1407 | /* flush last journal entry if needed */ | ||
1408 | c->journal.work.work.func(&c->journal.work.work); | ||
1409 | |||
1406 | closure_return(cl); | 1410 | closure_return(cl); |
1407 | } | 1411 | } |
1408 | 1412 | ||