4  * Copyright (C) 2001-2002 Sistina Software (UK) Limited.
 
   6  * This file is released under the GPL.
 
   9 #include <linux/blkdev.h>
 
  10 #include <linux/ctype.h>
 
  11 #include <linux/device-mapper.h>
 
  13 #include <linux/init.h>
 
  14 #include <linux/kdev_t.h>
 
  15 #include <linux/list.h>
 
  16 #include <linux/mempool.h>
 
  17 #include <linux/module.h>
 
  18 #include <linux/slab.h>
 
  19 #include <linux/vmalloc.h>
 
  20 #include <linux/log2.h>
 
  21 #include <linux/dm-kcopyd.h>
 
  24 #include "dm-bio-list.h"
 
  26 #define DM_MSG_PREFIX "snapshots"
 
  29  * The percentage increment we will wake up users at
 
  31 #define WAKE_UP_PERCENT 5
 
  34  * kcopyd priority of snapshot operations
 
  36 #define SNAPSHOT_COPY_PRIORITY 2
 
  39  * Reserve 1MB for each snapshot initially (with minimum of 1 page).
 
  41 #define SNAPSHOT_PAGES (((1UL << 20) >> PAGE_SHIFT) ? : 1)
 
  44  * The size of the mempool used to track chunks in use.
 
  48 static struct workqueue_struct *ksnapd;
 
  49 static void flush_queued_bios(struct work_struct *work);
 
  51 struct dm_snap_pending_exception {
 
  52         struct dm_snap_exception e;
 
  55          * Origin buffers waiting for this to complete are held
 
  58         struct bio_list origin_bios;
 
  59         struct bio_list snapshot_bios;
 
  62          * Short-term queue of pending exceptions prior to submission.
 
  64         struct list_head list;
 
  67          * The primary pending_exception is the one that holds
 
  68          * the ref_count and the list of origin_bios for a
 
  69          * group of pending_exceptions.  It is always last to get freed.
 
  70          * These fields get set up when writing to the origin.
 
  72         struct dm_snap_pending_exception *primary_pe;
 
  75          * Number of pending_exceptions processing this chunk.
 
  76          * When this drops to zero we must complete the origin bios.
 
  77          * If incrementing or decrementing this, hold pe->snap->lock for
 
  78          * the sibling concerned and not pe->primary_pe->snap->lock unless
 
  83         /* Pointer back to snapshot context */
 
  84         struct dm_snapshot *snap;
 
  87          * 1 indicates the exception has already been sent to
 
  94  * Hash table mapping origin volumes to lists of snapshots and
 
  95  * a lock to protect it
 
  97 static struct kmem_cache *exception_cache;
 
  98 static struct kmem_cache *pending_cache;
 
 100 struct dm_snap_tracked_chunk {
 
 101         struct hlist_node node;
 
 105 static struct kmem_cache *tracked_chunk_cache;
 
 107 static struct dm_snap_tracked_chunk *track_chunk(struct dm_snapshot *s,
 
 110         struct dm_snap_tracked_chunk *c = mempool_alloc(s->tracked_chunk_pool,
 
 116         spin_lock_irqsave(&s->tracked_chunk_lock, flags);
 
 117         hlist_add_head(&c->node,
 
 118                        &s->tracked_chunk_hash[DM_TRACKED_CHUNK_HASH(chunk)]);
 
 119         spin_unlock_irqrestore(&s->tracked_chunk_lock, flags);
 
 124 static void stop_tracking_chunk(struct dm_snapshot *s,
 
 125                                 struct dm_snap_tracked_chunk *c)
 
 129         spin_lock_irqsave(&s->tracked_chunk_lock, flags);
 
 131         spin_unlock_irqrestore(&s->tracked_chunk_lock, flags);
 
 133         mempool_free(c, s->tracked_chunk_pool);
 
 136 static int __chunk_is_tracked(struct dm_snapshot *s, chunk_t chunk)
 
 138         struct dm_snap_tracked_chunk *c;
 
 139         struct hlist_node *hn;
 
 142         spin_lock_irq(&s->tracked_chunk_lock);
 
 144         hlist_for_each_entry(c, hn,
 
 145             &s->tracked_chunk_hash[DM_TRACKED_CHUNK_HASH(chunk)], node) {
 
 146                 if (c->chunk == chunk) {
 
 152         spin_unlock_irq(&s->tracked_chunk_lock);
 
 158  * One of these per registered origin, held in the snapshot_origins hash
 
 161         /* The origin device */
 
 162         struct block_device *bdev;
 
 164         struct list_head hash_list;
 
 166         /* List of snapshots for this origin */
 
 167         struct list_head snapshots;
 
 171  * Size of the hash table for origin volumes. If we make this
 
 172  * the size of the minors list then it should be nearly perfect
 
 174 #define ORIGIN_HASH_SIZE 256
 
 175 #define ORIGIN_MASK      0xFF
 
 176 static struct list_head *_origins;
 
 177 static struct rw_semaphore _origins_lock;
 
 179 static int init_origin_hash(void)
 
 183         _origins = kmalloc(ORIGIN_HASH_SIZE * sizeof(struct list_head),
 
 186                 DMERR("unable to allocate memory");
 
 190         for (i = 0; i < ORIGIN_HASH_SIZE; i++)
 
 191                 INIT_LIST_HEAD(_origins + i);
 
 192         init_rwsem(&_origins_lock);
 
 197 static void exit_origin_hash(void)
 
 202 static unsigned origin_hash(struct block_device *bdev)
 
 204         return bdev->bd_dev & ORIGIN_MASK;
 
 207 static struct origin *__lookup_origin(struct block_device *origin)
 
 209         struct list_head *ol;
 
 212         ol = &_origins[origin_hash(origin)];
 
 213         list_for_each_entry (o, ol, hash_list)
 
 214                 if (bdev_equal(o->bdev, origin))
 
 220 static void __insert_origin(struct origin *o)
 
 222         struct list_head *sl = &_origins[origin_hash(o->bdev)];
 
 223         list_add_tail(&o->hash_list, sl);
 
 227  * Make a note of the snapshot and its origin so we can look it
 
 228  * up when the origin has a write on it.
 
 230 static int register_snapshot(struct dm_snapshot *snap)
 
 232         struct origin *o, *new_o;
 
 233         struct block_device *bdev = snap->origin->bdev;
 
 235         new_o = kmalloc(sizeof(*new_o), GFP_KERNEL);
 
 239         down_write(&_origins_lock);
 
 240         o = __lookup_origin(bdev);
 
 248                 /* Initialise the struct */
 
 249                 INIT_LIST_HEAD(&o->snapshots);
 
 255         list_add_tail(&snap->list, &o->snapshots);
 
 257         up_write(&_origins_lock);
 
 261 static void unregister_snapshot(struct dm_snapshot *s)
 
 265         down_write(&_origins_lock);
 
 266         o = __lookup_origin(s->origin->bdev);
 
 269         if (list_empty(&o->snapshots)) {
 
 270                 list_del(&o->hash_list);
 
 274         up_write(&_origins_lock);
 
 278  * Implementation of the exception hash tables.
 
 279  * The lowest hash_shift bits of the chunk number are ignored, allowing
 
 280  * some consecutive chunks to be grouped together.
 
 282 static int init_exception_table(struct exception_table *et, uint32_t size,
 
 287         et->hash_shift = hash_shift;
 
 288         et->hash_mask = size - 1;
 
 289         et->table = dm_vcalloc(size, sizeof(struct list_head));
 
 293         for (i = 0; i < size; i++)
 
 294                 INIT_LIST_HEAD(et->table + i);
 
 299 static void exit_exception_table(struct exception_table *et, struct kmem_cache *mem)
 
 301         struct list_head *slot;
 
 302         struct dm_snap_exception *ex, *next;
 
 305         size = et->hash_mask + 1;
 
 306         for (i = 0; i < size; i++) {
 
 307                 slot = et->table + i;
 
 309                 list_for_each_entry_safe (ex, next, slot, hash_list)
 
 310                         kmem_cache_free(mem, ex);
 
 316 static uint32_t exception_hash(struct exception_table *et, chunk_t chunk)
 
 318         return (chunk >> et->hash_shift) & et->hash_mask;
 
 321 static void insert_exception(struct exception_table *eh,
 
 322                              struct dm_snap_exception *e)
 
 324         struct list_head *l = &eh->table[exception_hash(eh, e->old_chunk)];
 
 325         list_add(&e->hash_list, l);
 
 328 static void remove_exception(struct dm_snap_exception *e)
 
 330         list_del(&e->hash_list);
 
 334  * Return the exception data for a sector, or NULL if not
 
 337 static struct dm_snap_exception *lookup_exception(struct exception_table *et,
 
 340         struct list_head *slot;
 
 341         struct dm_snap_exception *e;
 
 343         slot = &et->table[exception_hash(et, chunk)];
 
 344         list_for_each_entry (e, slot, hash_list)
 
 345                 if (chunk >= e->old_chunk &&
 
 346                     chunk <= e->old_chunk + dm_consecutive_chunk_count(e))
 
 352 static struct dm_snap_exception *alloc_exception(void)
 
 354         struct dm_snap_exception *e;
 
 356         e = kmem_cache_alloc(exception_cache, GFP_NOIO);
 
 358                 e = kmem_cache_alloc(exception_cache, GFP_ATOMIC);
 
 363 static void free_exception(struct dm_snap_exception *e)
 
 365         kmem_cache_free(exception_cache, e);
 
 368 static struct dm_snap_pending_exception *alloc_pending_exception(struct dm_snapshot *s)
 
 370         struct dm_snap_pending_exception *pe = mempool_alloc(s->pending_pool,
 
 373         atomic_inc(&s->pending_exceptions_count);
 
 379 static void free_pending_exception(struct dm_snap_pending_exception *pe)
 
 381         struct dm_snapshot *s = pe->snap;
 
 383         mempool_free(pe, s->pending_pool);
 
 384         smp_mb__before_atomic_dec();
 
 385         atomic_dec(&s->pending_exceptions_count);
 
 388 static void insert_completed_exception(struct dm_snapshot *s,
 
 389                                        struct dm_snap_exception *new_e)
 
 391         struct exception_table *eh = &s->complete;
 
 393         struct dm_snap_exception *e = NULL;
 
 395         l = &eh->table[exception_hash(eh, new_e->old_chunk)];
 
 397         /* Add immediately if this table doesn't support consecutive chunks */
 
 401         /* List is ordered by old_chunk */
 
 402         list_for_each_entry_reverse(e, l, hash_list) {
 
 403                 /* Insert after an existing chunk? */
 
 404                 if (new_e->old_chunk == (e->old_chunk +
 
 405                                          dm_consecutive_chunk_count(e) + 1) &&
 
 406                     new_e->new_chunk == (dm_chunk_number(e->new_chunk) +
 
 407                                          dm_consecutive_chunk_count(e) + 1)) {
 
 408                         dm_consecutive_chunk_count_inc(e);
 
 409                         free_exception(new_e);
 
 413                 /* Insert before an existing chunk? */
 
 414                 if (new_e->old_chunk == (e->old_chunk - 1) &&
 
 415                     new_e->new_chunk == (dm_chunk_number(e->new_chunk) - 1)) {
 
 416                         dm_consecutive_chunk_count_inc(e);
 
 419                         free_exception(new_e);
 
 423                 if (new_e->old_chunk > e->old_chunk)
 
 428         list_add(&new_e->hash_list, e ? &e->hash_list : l);
 
 431 int dm_add_exception(struct dm_snapshot *s, chunk_t old, chunk_t new)
 
 433         struct dm_snap_exception *e;
 
 435         e = alloc_exception();
 
 441         /* Consecutive_count is implicitly initialised to zero */
 
 444         insert_completed_exception(s, e);
 
 452 static int calc_max_buckets(void)
 
 454         /* use a fixed size of 2MB */
 
 455         unsigned long mem = 2 * 1024 * 1024;
 
 456         mem /= sizeof(struct list_head);
 
 462  * Allocate room for a suitable hash table.
 
 464 static int init_hash_tables(struct dm_snapshot *s)
 
 466         sector_t hash_size, cow_dev_size, origin_dev_size, max_buckets;
 
 469          * Calculate based on the size of the original volume or
 
 472         cow_dev_size = get_dev_size(s->cow->bdev);
 
 473         origin_dev_size = get_dev_size(s->origin->bdev);
 
 474         max_buckets = calc_max_buckets();
 
 476         hash_size = min(origin_dev_size, cow_dev_size) >> s->chunk_shift;
 
 477         hash_size = min(hash_size, max_buckets);
 
 479         hash_size = rounddown_pow_of_two(hash_size);
 
 480         if (init_exception_table(&s->complete, hash_size,
 
 481                                  DM_CHUNK_CONSECUTIVE_BITS))
 
 485          * Allocate hash table for in-flight exceptions
 
 486          * Make this smaller than the real hash table
 
 492         if (init_exception_table(&s->pending, hash_size, 0)) {
 
 493                 exit_exception_table(&s->complete, exception_cache);
 
 501  * Round a number up to the nearest 'size' boundary.  size must
 
 504 static ulong round_up(ulong n, ulong size)
 
 507         return (n + size) & ~size;
 
 510 static int set_chunk_size(struct dm_snapshot *s, const char *chunk_size_arg,
 
 513         unsigned long chunk_size;
 
 516         chunk_size = simple_strtoul(chunk_size_arg, &value, 10);
 
 517         if (*chunk_size_arg == '\0' || *value != '\0') {
 
 518                 *error = "Invalid chunk size";
 
 523                 s->chunk_size = s->chunk_mask = s->chunk_shift = 0;
 
 528          * Chunk size must be multiple of page size.  Silently
 
 529          * round up if it's not.
 
 531         chunk_size = round_up(chunk_size, PAGE_SIZE >> 9);
 
 533         /* Check chunk_size is a power of 2 */
 
 534         if (!is_power_of_2(chunk_size)) {
 
 535                 *error = "Chunk size is not a power of 2";
 
 539         /* Validate the chunk size against the device block size */
 
 540         if (chunk_size % (bdev_hardsect_size(s->cow->bdev) >> 9)) {
 
 541                 *error = "Chunk size is not a multiple of device blocksize";
 
 545         s->chunk_size = chunk_size;
 
 546         s->chunk_mask = chunk_size - 1;
 
 547         s->chunk_shift = ffs(chunk_size) - 1;
 
 553  * Construct a snapshot mapping: <origin_dev> <COW-dev> <p/n> <chunk-size>
 
 555 static int snapshot_ctr(struct dm_target *ti, unsigned int argc, char **argv)
 
 557         struct dm_snapshot *s;
 
 565                 ti->error = "requires exactly 4 arguments";
 
 570         origin_path = argv[0];
 
 572         persistent = toupper(*argv[2]);
 
 574         if (persistent != 'P' && persistent != 'N') {
 
 575                 ti->error = "Persistent flag is not P or N";
 
 580         s = kmalloc(sizeof(*s), GFP_KERNEL);
 
 582                 ti->error = "Cannot allocate snapshot context private "
 
 588         r = dm_get_device(ti, origin_path, 0, ti->len, FMODE_READ, &s->origin);
 
 590                 ti->error = "Cannot get origin device";
 
 594         r = dm_get_device(ti, cow_path, 0, 0,
 
 595                           FMODE_READ | FMODE_WRITE, &s->cow);
 
 597                 dm_put_device(ti, s->origin);
 
 598                 ti->error = "Cannot get COW device";
 
 602         r = set_chunk_size(s, argv[3], &ti->error);
 
 606         s->type = persistent;
 
 610         atomic_set(&s->pending_exceptions_count, 0);
 
 611         init_rwsem(&s->lock);
 
 612         spin_lock_init(&s->pe_lock);
 
 615         /* Allocate hash table for COW data */
 
 616         if (init_hash_tables(s)) {
 
 617                 ti->error = "Unable to allocate hash table space";
 
 624         if (persistent == 'P')
 
 625                 r = dm_create_persistent(&s->store);
 
 627                 r = dm_create_transient(&s->store);
 
 630                 ti->error = "Couldn't create exception store";
 
 635         r = dm_kcopyd_client_create(SNAPSHOT_PAGES, &s->kcopyd_client);
 
 637                 ti->error = "Could not create kcopyd client";
 
 641         s->pending_pool = mempool_create_slab_pool(MIN_IOS, pending_cache);
 
 642         if (!s->pending_pool) {
 
 643                 ti->error = "Could not allocate mempool for pending exceptions";
 
 647         s->tracked_chunk_pool = mempool_create_slab_pool(MIN_IOS,
 
 648                                                          tracked_chunk_cache);
 
 649         if (!s->tracked_chunk_pool) {
 
 650                 ti->error = "Could not allocate tracked_chunk mempool for "
 
 652                 goto bad_tracked_chunk_pool;
 
 655         for (i = 0; i < DM_TRACKED_CHUNK_HASH_SIZE; i++)
 
 656                 INIT_HLIST_HEAD(&s->tracked_chunk_hash[i]);
 
 658         spin_lock_init(&s->tracked_chunk_lock);
 
 660         /* Metadata must only be loaded into one table at once */
 
 661         r = s->store.read_metadata(&s->store);
 
 663                 ti->error = "Failed to read snapshot metadata";
 
 664                 goto bad_load_and_register;
 
 667                 DMWARN("Snapshot is marked invalid.");
 
 670         bio_list_init(&s->queued_bios);
 
 671         INIT_WORK(&s->queued_bios_work, flush_queued_bios);
 
 673         /* Add snapshot to the list of snapshots for this origin */
 
 674         /* Exceptions aren't triggered till snapshot_resume() is called */
 
 675         if (register_snapshot(s)) {
 
 677                 ti->error = "Cannot register snapshot origin";
 
 678                 goto bad_load_and_register;
 
 682         ti->split_io = s->chunk_size;
 
 686  bad_load_and_register:
 
 687         mempool_destroy(s->tracked_chunk_pool);
 
 689  bad_tracked_chunk_pool:
 
 690         mempool_destroy(s->pending_pool);
 
 693         dm_kcopyd_client_destroy(s->kcopyd_client);
 
 696         s->store.destroy(&s->store);
 
 699         exit_exception_table(&s->pending, pending_cache);
 
 700         exit_exception_table(&s->complete, exception_cache);
 
 703         dm_put_device(ti, s->cow);
 
 704         dm_put_device(ti, s->origin);
 
 713 static void __free_exceptions(struct dm_snapshot *s)
 
 715         dm_kcopyd_client_destroy(s->kcopyd_client);
 
 716         s->kcopyd_client = NULL;
 
 718         exit_exception_table(&s->pending, pending_cache);
 
 719         exit_exception_table(&s->complete, exception_cache);
 
 721         s->store.destroy(&s->store);
 
 724 static void snapshot_dtr(struct dm_target *ti)
 
 726 #ifdef CONFIG_DM_DEBUG
 
 729         struct dm_snapshot *s = ti->private;
 
 731         flush_workqueue(ksnapd);
 
 733         /* Prevent further origin writes from using this snapshot. */
 
 734         /* After this returns there can be no new kcopyd jobs. */
 
 735         unregister_snapshot(s);
 
 737         while (atomic_read(&s->pending_exceptions_count))
 
 740          * Ensure instructions in mempool_destroy aren't reordered
 
 741          * before atomic_read.
 
 745 #ifdef CONFIG_DM_DEBUG
 
 746         for (i = 0; i < DM_TRACKED_CHUNK_HASH_SIZE; i++)
 
 747                 BUG_ON(!hlist_empty(&s->tracked_chunk_hash[i]));
 
 750         mempool_destroy(s->tracked_chunk_pool);
 
 752         __free_exceptions(s);
 
 754         mempool_destroy(s->pending_pool);
 
 756         dm_put_device(ti, s->origin);
 
 757         dm_put_device(ti, s->cow);
 
 763  * Flush a list of buffers.
 
 765 static void flush_bios(struct bio *bio)
 
 772                 generic_make_request(bio);
 
 777 static void flush_queued_bios(struct work_struct *work)
 
 779         struct dm_snapshot *s =
 
 780                 container_of(work, struct dm_snapshot, queued_bios_work);
 
 781         struct bio *queued_bios;
 
 784         spin_lock_irqsave(&s->pe_lock, flags);
 
 785         queued_bios = bio_list_get(&s->queued_bios);
 
 786         spin_unlock_irqrestore(&s->pe_lock, flags);
 
 788         flush_bios(queued_bios);
 
 792  * Error a list of buffers.
 
 794 static void error_bios(struct bio *bio)
 
 806 static void __invalidate_snapshot(struct dm_snapshot *s, int err)
 
 812                 DMERR("Invalidating snapshot: Error reading/writing.");
 
 813         else if (err == -ENOMEM)
 
 814                 DMERR("Invalidating snapshot: Unable to allocate exception.");
 
 816         if (s->store.drop_snapshot)
 
 817                 s->store.drop_snapshot(&s->store);
 
 821         dm_table_event(s->ti->table);
 
 824 static void get_pending_exception(struct dm_snap_pending_exception *pe)
 
 826         atomic_inc(&pe->ref_count);
 
 829 static struct bio *put_pending_exception(struct dm_snap_pending_exception *pe)
 
 831         struct dm_snap_pending_exception *primary_pe;
 
 832         struct bio *origin_bios = NULL;
 
 834         primary_pe = pe->primary_pe;
 
 837          * If this pe is involved in a write to the origin and
 
 838          * it is the last sibling to complete then release
 
 839          * the bios for the original write to the origin.
 
 842             atomic_dec_and_test(&primary_pe->ref_count)) {
 
 843                 origin_bios = bio_list_get(&primary_pe->origin_bios);
 
 844                 free_pending_exception(primary_pe);
 
 848          * Free the pe if it's not linked to an origin write or if
 
 849          * it's not itself a primary pe.
 
 851         if (!primary_pe || primary_pe != pe)
 
 852                 free_pending_exception(pe);
 
 857 static void pending_complete(struct dm_snap_pending_exception *pe, int success)
 
 859         struct dm_snap_exception *e;
 
 860         struct dm_snapshot *s = pe->snap;
 
 861         struct bio *origin_bios = NULL;
 
 862         struct bio *snapshot_bios = NULL;
 
 866                 /* Read/write error - snapshot is unusable */
 
 867                 down_write(&s->lock);
 
 868                 __invalidate_snapshot(s, -EIO);
 
 873         e = alloc_exception();
 
 875                 down_write(&s->lock);
 
 876                 __invalidate_snapshot(s, -ENOMEM);
 
 882         down_write(&s->lock);
 
 890          * Check for conflicting reads. This is extremely improbable,
 
 891          * so yield() is sufficient and there is no need for a wait queue.
 
 893         while (__chunk_is_tracked(s, pe->e.old_chunk))
 
 897          * Add a proper exception, and remove the
 
 898          * in-flight exception from the list.
 
 900         insert_completed_exception(s, e);
 
 903         remove_exception(&pe->e);
 
 904         snapshot_bios = bio_list_get(&pe->snapshot_bios);
 
 905         origin_bios = put_pending_exception(pe);
 
 909         /* Submit any pending write bios */
 
 911                 error_bios(snapshot_bios);
 
 913                 flush_bios(snapshot_bios);
 
 915         flush_bios(origin_bios);
 
 918 static void commit_callback(void *context, int success)
 
 920         struct dm_snap_pending_exception *pe = context;
 
 922         pending_complete(pe, success);
 
 926  * Called when the copy I/O has finished.  kcopyd actually runs
 
 927  * this code so don't block.
 
 929 static void copy_callback(int read_err, unsigned long write_err, void *context)
 
 931         struct dm_snap_pending_exception *pe = context;
 
 932         struct dm_snapshot *s = pe->snap;
 
 934         if (read_err || write_err)
 
 935                 pending_complete(pe, 0);
 
 938                 /* Update the metadata if we are persistent */
 
 939                 s->store.commit_exception(&s->store, &pe->e, commit_callback,
 
 944  * Dispatches the copy operation to kcopyd.
 
 946 static void start_copy(struct dm_snap_pending_exception *pe)
 
 948         struct dm_snapshot *s = pe->snap;
 
 949         struct dm_io_region src, dest;
 
 950         struct block_device *bdev = s->origin->bdev;
 
 953         dev_size = get_dev_size(bdev);
 
 956         src.sector = chunk_to_sector(s, pe->e.old_chunk);
 
 957         src.count = min(s->chunk_size, dev_size - src.sector);
 
 959         dest.bdev = s->cow->bdev;
 
 960         dest.sector = chunk_to_sector(s, pe->e.new_chunk);
 
 961         dest.count = src.count;
 
 963         /* Hand over to kcopyd */
 
 964         dm_kcopyd_copy(s->kcopyd_client,
 
 965                     &src, 1, &dest, 0, copy_callback, pe);
 
 969  * Looks to see if this snapshot already has a pending exception
 
 970  * for this chunk, otherwise it allocates a new one and inserts
 
 971  * it into the pending table.
 
 973  * NOTE: a write lock must be held on snap->lock before calling
 
 976 static struct dm_snap_pending_exception *
 
 977 __find_pending_exception(struct dm_snapshot *s, struct bio *bio)
 
 979         struct dm_snap_exception *e;
 
 980         struct dm_snap_pending_exception *pe;
 
 981         chunk_t chunk = sector_to_chunk(s, bio->bi_sector);
 
 984          * Is there a pending exception for this already ?
 
 986         e = lookup_exception(&s->pending, chunk);
 
 988                 /* cast the exception to a pending exception */
 
 989                 pe = container_of(e, struct dm_snap_pending_exception, e);
 
 994          * Create a new pending exception, we don't want
 
 995          * to hold the lock while we do this.
 
 998         pe = alloc_pending_exception(s);
 
 999         down_write(&s->lock);
 
1002                 free_pending_exception(pe);
 
1006         e = lookup_exception(&s->pending, chunk);
 
1008                 free_pending_exception(pe);
 
1009                 pe = container_of(e, struct dm_snap_pending_exception, e);
 
1013         pe->e.old_chunk = chunk;
 
1014         bio_list_init(&pe->origin_bios);
 
1015         bio_list_init(&pe->snapshot_bios);
 
1016         pe->primary_pe = NULL;
 
1017         atomic_set(&pe->ref_count, 0);
 
1020         if (s->store.prepare_exception(&s->store, &pe->e)) {
 
1021                 free_pending_exception(pe);
 
1025         get_pending_exception(pe);
 
1026         insert_exception(&s->pending, &pe->e);
 
1032 static void remap_exception(struct dm_snapshot *s, struct dm_snap_exception *e,
 
1033                             struct bio *bio, chunk_t chunk)
 
1035         bio->bi_bdev = s->cow->bdev;
 
1036         bio->bi_sector = chunk_to_sector(s, dm_chunk_number(e->new_chunk) +
 
1037                          (chunk - e->old_chunk)) +
 
1038                          (bio->bi_sector & s->chunk_mask);
 
1041 static int snapshot_map(struct dm_target *ti, struct bio *bio,
 
1042                         union map_info *map_context)
 
1044         struct dm_snap_exception *e;
 
1045         struct dm_snapshot *s = ti->private;
 
1046         int r = DM_MAPIO_REMAPPED;
 
1048         struct dm_snap_pending_exception *pe = NULL;
 
1050         chunk = sector_to_chunk(s, bio->bi_sector);
 
1052         /* Full snapshots are not usable */
 
1053         /* To get here the table must be live so s->active is always set. */
 
1057         /* FIXME: should only take write lock if we need
 
1058          * to copy an exception */
 
1059         down_write(&s->lock);
 
1066         /* If the block is already remapped - use that, else remap it */
 
1067         e = lookup_exception(&s->complete, chunk);
 
1069                 remap_exception(s, e, bio, chunk);
 
1074          * Write to snapshot - higher level takes care of RW/RO
 
1075          * flags so we should only get this if we are
 
1078         if (bio_rw(bio) == WRITE) {
 
1079                 pe = __find_pending_exception(s, bio);
 
1081                         __invalidate_snapshot(s, -ENOMEM);
 
1086                 remap_exception(s, &pe->e, bio, chunk);
 
1087                 bio_list_add(&pe->snapshot_bios, bio);
 
1089                 r = DM_MAPIO_SUBMITTED;
 
1092                         /* this is protected by snap->lock */
 
1099                 bio->bi_bdev = s->origin->bdev;
 
1100                 map_context->ptr = track_chunk(s, chunk);
 
1109 static int snapshot_end_io(struct dm_target *ti, struct bio *bio,
 
1110                            int error, union map_info *map_context)
 
1112         struct dm_snapshot *s = ti->private;
 
1113         struct dm_snap_tracked_chunk *c = map_context->ptr;
 
1116                 stop_tracking_chunk(s, c);
 
1121 static void snapshot_resume(struct dm_target *ti)
 
1123         struct dm_snapshot *s = ti->private;
 
1125         down_write(&s->lock);
 
1130 static int snapshot_status(struct dm_target *ti, status_type_t type,
 
1131                            char *result, unsigned int maxlen)
 
1133         struct dm_snapshot *snap = ti->private;
 
1136         case STATUSTYPE_INFO:
 
1138                         snprintf(result, maxlen, "Invalid");
 
1140                         if (snap->store.fraction_full) {
 
1141                                 sector_t numerator, denominator;
 
1142                                 snap->store.fraction_full(&snap->store,
 
1145                                 snprintf(result, maxlen, "%llu/%llu",
 
1146                                         (unsigned long long)numerator,
 
1147                                         (unsigned long long)denominator);
 
1150                                 snprintf(result, maxlen, "Unknown");
 
1154         case STATUSTYPE_TABLE:
 
1156                  * kdevname returns a static pointer so we need
 
1157                  * to make private copies if the output is to
 
1160                 snprintf(result, maxlen, "%s %s %c %llu",
 
1161                          snap->origin->name, snap->cow->name,
 
1163                          (unsigned long long)snap->chunk_size);
 
1170 /*-----------------------------------------------------------------
 
1172  *---------------------------------------------------------------*/
 
1173 static int __origin_write(struct list_head *snapshots, struct bio *bio)
 
1175         int r = DM_MAPIO_REMAPPED, first = 0;
 
1176         struct dm_snapshot *snap;
 
1177         struct dm_snap_exception *e;
 
1178         struct dm_snap_pending_exception *pe, *next_pe, *primary_pe = NULL;
 
1180         LIST_HEAD(pe_queue);
 
1182         /* Do all the snapshots on this origin */
 
1183         list_for_each_entry (snap, snapshots, list) {
 
1185                 down_write(&snap->lock);
 
1187                 /* Only deal with valid and active snapshots */
 
1188                 if (!snap->valid || !snap->active)
 
1191                 /* Nothing to do if writing beyond end of snapshot */
 
1192                 if (bio->bi_sector >= dm_table_get_size(snap->ti->table))
 
1196                  * Remember, different snapshots can have
 
1197                  * different chunk sizes.
 
1199                 chunk = sector_to_chunk(snap, bio->bi_sector);
 
1202                  * Check exception table to see if block
 
1203                  * is already remapped in this snapshot
 
1204                  * and trigger an exception if not.
 
1206                  * ref_count is initialised to 1 so pending_complete()
 
1207                  * won't destroy the primary_pe while we're inside this loop.
 
1209                 e = lookup_exception(&snap->complete, chunk);
 
1213                 pe = __find_pending_exception(snap, bio);
 
1215                         __invalidate_snapshot(snap, -ENOMEM);
 
1221                          * Either every pe here has same
 
1222                          * primary_pe or none has one yet.
 
1225                                 primary_pe = pe->primary_pe;
 
1231                         bio_list_add(&primary_pe->origin_bios, bio);
 
1233                         r = DM_MAPIO_SUBMITTED;
 
1236                 if (!pe->primary_pe) {
 
1237                         pe->primary_pe = primary_pe;
 
1238                         get_pending_exception(primary_pe);
 
1243                         list_add_tail(&pe->list, &pe_queue);
 
1247                 up_write(&snap->lock);
 
1254          * If this is the first time we're processing this chunk and
 
1255          * ref_count is now 1 it means all the pending exceptions
 
1256          * got completed while we were in the loop above, so it falls to
 
1257          * us here to remove the primary_pe and submit any origin_bios.
 
1260         if (first && atomic_dec_and_test(&primary_pe->ref_count)) {
 
1261                 flush_bios(bio_list_get(&primary_pe->origin_bios));
 
1262                 free_pending_exception(primary_pe);
 
1263                 /* If we got here, pe_queue is necessarily empty. */
 
1268          * Now that we have a complete pe list we can start the copying.
 
1270         list_for_each_entry_safe(pe, next_pe, &pe_queue, list)
 
1277  * Called on a write from the origin driver.
 
1279 static int do_origin(struct dm_dev *origin, struct bio *bio)
 
1282         int r = DM_MAPIO_REMAPPED;
 
1284         down_read(&_origins_lock);
 
1285         o = __lookup_origin(origin->bdev);
 
1287                 r = __origin_write(&o->snapshots, bio);
 
1288         up_read(&_origins_lock);
 
1294  * Origin: maps a linear range of a device, with hooks for snapshotting.
 
1298  * Construct an origin mapping: <dev_path>
 
1299  * The context for an origin is merely a 'struct dm_dev *'
 
1300  * pointing to the real device.
 
1302 static int origin_ctr(struct dm_target *ti, unsigned int argc, char **argv)
 
1308                 ti->error = "origin: incorrect number of arguments";
 
1312         r = dm_get_device(ti, argv[0], 0, ti->len,
 
1313                           dm_table_get_mode(ti->table), &dev);
 
1315                 ti->error = "Cannot get target device";
 
1323 static void origin_dtr(struct dm_target *ti)
 
1325         struct dm_dev *dev = ti->private;
 
1326         dm_put_device(ti, dev);
 
1329 static int origin_map(struct dm_target *ti, struct bio *bio,
 
1330                       union map_info *map_context)
 
1332         struct dm_dev *dev = ti->private;
 
1333         bio->bi_bdev = dev->bdev;
 
1335         /* Only tell snapshots if this is a write */
 
1336         return (bio_rw(bio) == WRITE) ? do_origin(dev, bio) : DM_MAPIO_REMAPPED;
 
1339 #define min_not_zero(l, r) (l == 0) ? r : ((r == 0) ? l : min(l, r))
 
1342  * Set the target "split_io" field to the minimum of all the snapshots'
 
1345 static void origin_resume(struct dm_target *ti)
 
1347         struct dm_dev *dev = ti->private;
 
1348         struct dm_snapshot *snap;
 
1350         chunk_t chunk_size = 0;
 
1352         down_read(&_origins_lock);
 
1353         o = __lookup_origin(dev->bdev);
 
1355                 list_for_each_entry (snap, &o->snapshots, list)
 
1356                         chunk_size = min_not_zero(chunk_size, snap->chunk_size);
 
1357         up_read(&_origins_lock);
 
1359         ti->split_io = chunk_size;
 
1362 static int origin_status(struct dm_target *ti, status_type_t type, char *result,
 
1363                          unsigned int maxlen)
 
1365         struct dm_dev *dev = ti->private;
 
1368         case STATUSTYPE_INFO:
 
1372         case STATUSTYPE_TABLE:
 
1373                 snprintf(result, maxlen, "%s", dev->name);
 
1380 static struct target_type origin_target = {
 
1381         .name    = "snapshot-origin",
 
1382         .version = {1, 6, 0},
 
1383         .module  = THIS_MODULE,
 
1387         .resume  = origin_resume,
 
1388         .status  = origin_status,
 
1391 static struct target_type snapshot_target = {
 
1393         .version = {1, 6, 0},
 
1394         .module  = THIS_MODULE,
 
1395         .ctr     = snapshot_ctr,
 
1396         .dtr     = snapshot_dtr,
 
1397         .map     = snapshot_map,
 
1398         .end_io  = snapshot_end_io,
 
1399         .resume  = snapshot_resume,
 
1400         .status  = snapshot_status,
 
1403 static int __init dm_snapshot_init(void)
 
1407         r = dm_register_target(&snapshot_target);
 
1409                 DMERR("snapshot target register failed %d", r);
 
1413         r = dm_register_target(&origin_target);
 
1415                 DMERR("Origin target register failed %d", r);
 
1419         r = init_origin_hash();
 
1421                 DMERR("init_origin_hash failed.");
 
1425         exception_cache = KMEM_CACHE(dm_snap_exception, 0);
 
1426         if (!exception_cache) {
 
1427                 DMERR("Couldn't create exception cache.");
 
1432         pending_cache = KMEM_CACHE(dm_snap_pending_exception, 0);
 
1433         if (!pending_cache) {
 
1434                 DMERR("Couldn't create pending cache.");
 
1439         tracked_chunk_cache = KMEM_CACHE(dm_snap_tracked_chunk, 0);
 
1440         if (!tracked_chunk_cache) {
 
1441                 DMERR("Couldn't create cache to track chunks in use.");
 
1446         ksnapd = create_singlethread_workqueue("ksnapd");
 
1448                 DMERR("Failed to create ksnapd workqueue.");
 
1450                 goto bad_pending_pool;
 
1456         kmem_cache_destroy(tracked_chunk_cache);
 
1458         kmem_cache_destroy(pending_cache);
 
1460         kmem_cache_destroy(exception_cache);
 
1464         dm_unregister_target(&origin_target);
 
1466         dm_unregister_target(&snapshot_target);
 
1470 static void __exit dm_snapshot_exit(void)
 
1474         destroy_workqueue(ksnapd);
 
1476         r = dm_unregister_target(&snapshot_target);
 
1478                 DMERR("snapshot unregister failed %d", r);
 
1480         r = dm_unregister_target(&origin_target);
 
1482                 DMERR("origin unregister failed %d", r);
 
1485         kmem_cache_destroy(pending_cache);
 
1486         kmem_cache_destroy(exception_cache);
 
1487         kmem_cache_destroy(tracked_chunk_cache);
 
1491 module_init(dm_snapshot_init);
 
1492 module_exit(dm_snapshot_exit);
 
1494 MODULE_DESCRIPTION(DM_NAME " snapshot target");
 
1495 MODULE_AUTHOR("Joe Thornber");
 
1496 MODULE_LICENSE("GPL");