diff options
| author | Joe Thornber <ejt@redhat.com> | 2015-01-23 10:16:16 +0000 | 
|---|---|---|
| committer | Mike Snitzer <snitzer@redhat.com> | 2015-01-23 11:06:08 -0500 | 
| commit | a59db67656021fa212e9b95a583f13c34eb67cd9 (patch) | |
| tree | 6a9d52eb5cb2fc1db677636431e56e1797859a6c /lib/mpi/mpiutil.c | |
| parent | 9b1cc9f251affdd27f29fe46d0989ba76c33faf6 (diff) | |
dm cache: fix problematic dual use of a single migration count variable
Introduce a new variable to count the number of allocated migration
structures.  The existing variable cache->nr_migrations became
overloaded.  It was used to:
 i) track of the number of migrations in flight for the purposes of
    quiescing during suspend.
 ii) to estimate the amount of background IO occuring.
Recent discard changes meant that REQ_DISCARD bios are processed with
a migration.  Discards are not background IO so nr_migrations was not
incremented.  However this could cause quiescing to complete early.
(i) is now handled with a new variable cache->nr_allocated_migrations.
cache->nr_migrations has been renamed cache->nr_io_migrations.
cleanup_migration() is now called free_io_migration(), since it
decrements that variable.
Also, remove the unused cache->next_migration variable that got replaced
with with prealloc_structs a while ago.
Signed-off-by: Joe Thornber <ejt@redhat.com>
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Cc: stable@vger.kernel.org
Diffstat (limited to 'lib/mpi/mpiutil.c')
0 files changed, 0 insertions, 0 deletions
