1 /* 2 * dm-snapshot.c 3 * 4 * Copyright (C) 2001-2002 Sistina Software (UK) Limited. 5 * 6 * This file is released under the GPL. 7 */ 8 9 #include <linux/blkdev.h> 10 #include <linux/device-mapper.h> 11 #include <linux/delay.h> 12 #include <linux/fs.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> 22 23 #include "dm.h" 24 25 #include "dm-exception-store.h" 26 27 #define DM_MSG_PREFIX "snapshots" 28 29 static const char dm_snapshot_merge_target_name[] = "snapshot-merge"; 30 31 #define dm_target_is_snapshot_merge(ti) \ 32 ((ti)->type->name == dm_snapshot_merge_target_name) 33 34 /* 35 * The size of the mempool used to track chunks in use. 36 */ 37 #define MIN_IOS 256 38 39 #define DM_TRACKED_CHUNK_HASH_SIZE 16 40 #define DM_TRACKED_CHUNK_HASH(x) ((unsigned long)(x) & \ 41 (DM_TRACKED_CHUNK_HASH_SIZE - 1)) 42 43 struct dm_exception_table { 44 uint32_t hash_mask; 45 unsigned hash_shift; 46 struct list_head *table; 47 }; 48 49 struct dm_snapshot { 50 struct rw_semaphore lock; 51 52 struct dm_dev *origin; 53 struct dm_dev *cow; 54 55 struct dm_target *ti; 56 57 /* List of snapshots per Origin */ 58 struct list_head list; 59 60 /* 61 * You can't use a snapshot if this is 0 (e.g. if full). 62 * A snapshot-merge target never clears this. 63 */ 64 int valid; 65 66 /* 67 * The snapshot overflowed because of a write to the snapshot device. 68 * We don't have to invalidate the snapshot in this case, but we need 69 * to prevent further writes. 70 */ 71 int snapshot_overflowed; 72 73 /* Origin writes don't trigger exceptions until this is set */ 74 int active; 75 76 atomic_t pending_exceptions_count; 77 78 /* Protected by "lock" */ 79 sector_t exception_start_sequence; 80 81 /* Protected by kcopyd single-threaded callback */ 82 sector_t exception_complete_sequence; 83 84 /* 85 * A list of pending exceptions that completed out of order. 86 * Protected by kcopyd single-threaded callback. 87 */ 88 struct list_head out_of_order_list; 89 90 mempool_t *pending_pool; 91 92 struct dm_exception_table pending; 93 struct dm_exception_table complete; 94 95 /* 96 * pe_lock protects all pending_exception operations and access 97 * as well as the snapshot_bios list. 98 */ 99 spinlock_t pe_lock; 100 101 /* Chunks with outstanding reads */ 102 spinlock_t tracked_chunk_lock; 103 struct hlist_head tracked_chunk_hash[DM_TRACKED_CHUNK_HASH_SIZE]; 104 105 /* The on disk metadata handler */ 106 struct dm_exception_store *store; 107 108 struct dm_kcopyd_client *kcopyd_client; 109 110 /* Wait for events based on state_bits */ 111 unsigned long state_bits; 112 113 /* Range of chunks currently being merged. */ 114 chunk_t first_merging_chunk; 115 int num_merging_chunks; 116 117 /* 118 * The merge operation failed if this flag is set. 119 * Failure modes are handled as follows: 120 * - I/O error reading the header 121 * => don't load the target; abort. 122 * - Header does not have "valid" flag set 123 * => use the origin; forget about the snapshot. 124 * - I/O error when reading exceptions 125 * => don't load the target; abort. 126 * (We can't use the intermediate origin state.) 127 * - I/O error while merging 128 * => stop merging; set merge_failed; process I/O normally. 129 */ 130 int merge_failed; 131 132 /* 133 * Incoming bios that overlap with chunks being merged must wait 134 * for them to be committed. 135 */ 136 struct bio_list bios_queued_during_merge; 137 }; 138 139 /* 140 * state_bits: 141 * RUNNING_MERGE - Merge operation is in progress. 142 * SHUTDOWN_MERGE - Set to signal that merge needs to be stopped; 143 * cleared afterwards. 144 */ 145 #define RUNNING_MERGE 0 146 #define SHUTDOWN_MERGE 1 147 148 DECLARE_DM_KCOPYD_THROTTLE_WITH_MODULE_PARM(snapshot_copy_throttle, 149 "A percentage of time allocated for copy on write"); 150 151 struct dm_dev *dm_snap_origin(struct dm_snapshot *s) 152 { 153 return s->origin; 154 } 155 EXPORT_SYMBOL(dm_snap_origin); 156 157 struct dm_dev *dm_snap_cow(struct dm_snapshot *s) 158 { 159 return s->cow; 160 } 161 EXPORT_SYMBOL(dm_snap_cow); 162 163 static sector_t chunk_to_sector(struct dm_exception_store *store, 164 chunk_t chunk) 165 { 166 return chunk << store->chunk_shift; 167 } 168 169 static int bdev_equal(struct block_device *lhs, struct block_device *rhs) 170 { 171 /* 172 * There is only ever one instance of a particular block 173 * device so we can compare pointers safely. 174 */ 175 return lhs == rhs; 176 } 177 178 struct dm_snap_pending_exception { 179 struct dm_exception e; 180 181 /* 182 * Origin buffers waiting for this to complete are held 183 * in a bio list 184 */ 185 struct bio_list origin_bios; 186 struct bio_list snapshot_bios; 187 188 /* Pointer back to snapshot context */ 189 struct dm_snapshot *snap; 190 191 /* 192 * 1 indicates the exception has already been sent to 193 * kcopyd. 194 */ 195 int started; 196 197 /* There was copying error. */ 198 int copy_error; 199 200 /* A sequence number, it is used for in-order completion. */ 201 sector_t exception_sequence; 202 203 struct list_head out_of_order_entry; 204 205 /* 206 * For writing a complete chunk, bypassing the copy. 207 */ 208 struct bio *full_bio; 209 bio_end_io_t *full_bio_end_io; 210 void *full_bio_private; 211 }; 212 213 /* 214 * Hash table mapping origin volumes to lists of snapshots and 215 * a lock to protect it 216 */ 217 static struct kmem_cache *exception_cache; 218 static struct kmem_cache *pending_cache; 219 220 struct dm_snap_tracked_chunk { 221 struct hlist_node node; 222 chunk_t chunk; 223 }; 224 225 static void init_tracked_chunk(struct bio *bio) 226 { 227 struct dm_snap_tracked_chunk *c = dm_per_bio_data(bio, sizeof(struct dm_snap_tracked_chunk)); 228 INIT_HLIST_NODE(&c->node); 229 } 230 231 static bool is_bio_tracked(struct bio *bio) 232 { 233 struct dm_snap_tracked_chunk *c = dm_per_bio_data(bio, sizeof(struct dm_snap_tracked_chunk)); 234 return !hlist_unhashed(&c->node); 235 } 236 237 static void track_chunk(struct dm_snapshot *s, struct bio *bio, chunk_t chunk) 238 { 239 struct dm_snap_tracked_chunk *c = dm_per_bio_data(bio, sizeof(struct dm_snap_tracked_chunk)); 240 241 c->chunk = chunk; 242 243 spin_lock_irq(&s->tracked_chunk_lock); 244 hlist_add_head(&c->node, 245 &s->tracked_chunk_hash[DM_TRACKED_CHUNK_HASH(chunk)]); 246 spin_unlock_irq(&s->tracked_chunk_lock); 247 } 248 249 static void stop_tracking_chunk(struct dm_snapshot *s, struct bio *bio) 250 { 251 struct dm_snap_tracked_chunk *c = dm_per_bio_data(bio, sizeof(struct dm_snap_tracked_chunk)); 252 unsigned long flags; 253 254 spin_lock_irqsave(&s->tracked_chunk_lock, flags); 255 hlist_del(&c->node); 256 spin_unlock_irqrestore(&s->tracked_chunk_lock, flags); 257 } 258 259 static int __chunk_is_tracked(struct dm_snapshot *s, chunk_t chunk) 260 { 261 struct dm_snap_tracked_chunk *c; 262 int found = 0; 263 264 spin_lock_irq(&s->tracked_chunk_lock); 265 266 hlist_for_each_entry(c, 267 &s->tracked_chunk_hash[DM_TRACKED_CHUNK_HASH(chunk)], node) { 268 if (c->chunk == chunk) { 269 found = 1; 270 break; 271 } 272 } 273 274 spin_unlock_irq(&s->tracked_chunk_lock); 275 276 return found; 277 } 278 279 /* 280 * This conflicting I/O is extremely improbable in the caller, 281 * so msleep(1) is sufficient and there is no need for a wait queue. 282 */ 283 static void __check_for_conflicting_io(struct dm_snapshot *s, chunk_t chunk) 284 { 285 while (__chunk_is_tracked(s, chunk)) 286 msleep(1); 287 } 288 289 /* 290 * One of these per registered origin, held in the snapshot_origins hash 291 */ 292 struct origin { 293 /* The origin device */ 294 struct block_device *bdev; 295 296 struct list_head hash_list; 297 298 /* List of snapshots for this origin */ 299 struct list_head snapshots; 300 }; 301 302 /* 303 * This structure is allocated for each origin target 304 */ 305 struct dm_origin { 306 struct dm_dev *dev; 307 struct dm_target *ti; 308 unsigned split_boundary; 309 struct list_head hash_list; 310 }; 311 312 /* 313 * Size of the hash table for origin volumes. If we make this 314 * the size of the minors list then it should be nearly perfect 315 */ 316 #define ORIGIN_HASH_SIZE 256 317 #define ORIGIN_MASK 0xFF 318 static struct list_head *_origins; 319 static struct list_head *_dm_origins; 320 static struct rw_semaphore _origins_lock; 321 322 static DECLARE_WAIT_QUEUE_HEAD(_pending_exceptions_done); 323 static DEFINE_SPINLOCK(_pending_exceptions_done_spinlock); 324 static uint64_t _pending_exceptions_done_count; 325 326 static int init_origin_hash(void) 327 { 328 int i; 329 330 _origins = kmalloc(ORIGIN_HASH_SIZE * sizeof(struct list_head), 331 GFP_KERNEL); 332 if (!_origins) { 333 DMERR("unable to allocate memory for _origins"); 334 return -ENOMEM; 335 } 336 for (i = 0; i < ORIGIN_HASH_SIZE; i++) 337 INIT_LIST_HEAD(_origins + i); 338 339 _dm_origins = kmalloc(ORIGIN_HASH_SIZE * sizeof(struct list_head), 340 GFP_KERNEL); 341 if (!_dm_origins) { 342 DMERR("unable to allocate memory for _dm_origins"); 343 kfree(_origins); 344 return -ENOMEM; 345 } 346 for (i = 0; i < ORIGIN_HASH_SIZE; i++) 347 INIT_LIST_HEAD(_dm_origins + i); 348 349 init_rwsem(&_origins_lock); 350 351 return 0; 352 } 353 354 static void exit_origin_hash(void) 355 { 356 kfree(_origins); 357 kfree(_dm_origins); 358 } 359 360 static unsigned origin_hash(struct block_device *bdev) 361 { 362 return bdev->bd_dev & ORIGIN_MASK; 363 } 364 365 static struct origin *__lookup_origin(struct block_device *origin) 366 { 367 struct list_head *ol; 368 struct origin *o; 369 370 ol = &_origins[origin_hash(origin)]; 371 list_for_each_entry (o, ol, hash_list) 372 if (bdev_equal(o->bdev, origin)) 373 return o; 374 375 return NULL; 376 } 377 378 static void __insert_origin(struct origin *o) 379 { 380 struct list_head *sl = &_origins[origin_hash(o->bdev)]; 381 list_add_tail(&o->hash_list, sl); 382 } 383 384 static struct dm_origin *__lookup_dm_origin(struct block_device *origin) 385 { 386 struct list_head *ol; 387 struct dm_origin *o; 388 389 ol = &_dm_origins[origin_hash(origin)]; 390 list_for_each_entry (o, ol, hash_list) 391 if (bdev_equal(o->dev->bdev, origin)) 392 return o; 393 394 return NULL; 395 } 396 397 static void __insert_dm_origin(struct dm_origin *o) 398 { 399 struct list_head *sl = &_dm_origins[origin_hash(o->dev->bdev)]; 400 list_add_tail(&o->hash_list, sl); 401 } 402 403 static void __remove_dm_origin(struct dm_origin *o) 404 { 405 list_del(&o->hash_list); 406 } 407 408 /* 409 * _origins_lock must be held when calling this function. 410 * Returns number of snapshots registered using the supplied cow device, plus: 411 * snap_src - a snapshot suitable for use as a source of exception handover 412 * snap_dest - a snapshot capable of receiving exception handover. 413 * snap_merge - an existing snapshot-merge target linked to the same origin. 414 * There can be at most one snapshot-merge target. The parameter is optional. 415 * 416 * Possible return values and states of snap_src and snap_dest. 417 * 0: NULL, NULL - first new snapshot 418 * 1: snap_src, NULL - normal snapshot 419 * 2: snap_src, snap_dest - waiting for handover 420 * 2: snap_src, NULL - handed over, waiting for old to be deleted 421 * 1: NULL, snap_dest - source got destroyed without handover 422 */ 423 static int __find_snapshots_sharing_cow(struct dm_snapshot *snap, 424 struct dm_snapshot **snap_src, 425 struct dm_snapshot **snap_dest, 426 struct dm_snapshot **snap_merge) 427 { 428 struct dm_snapshot *s; 429 struct origin *o; 430 int count = 0; 431 int active; 432 433 o = __lookup_origin(snap->origin->bdev); 434 if (!o) 435 goto out; 436 437 list_for_each_entry(s, &o->snapshots, list) { 438 if (dm_target_is_snapshot_merge(s->ti) && snap_merge) 439 *snap_merge = s; 440 if (!bdev_equal(s->cow->bdev, snap->cow->bdev)) 441 continue; 442 443 down_read(&s->lock); 444 active = s->active; 445 up_read(&s->lock); 446 447 if (active) { 448 if (snap_src) 449 *snap_src = s; 450 } else if (snap_dest) 451 *snap_dest = s; 452 453 count++; 454 } 455 456 out: 457 return count; 458 } 459 460 /* 461 * On success, returns 1 if this snapshot is a handover destination, 462 * otherwise returns 0. 463 */ 464 static int __validate_exception_handover(struct dm_snapshot *snap) 465 { 466 struct dm_snapshot *snap_src = NULL, *snap_dest = NULL; 467 struct dm_snapshot *snap_merge = NULL; 468 469 /* Does snapshot need exceptions handed over to it? */ 470 if ((__find_snapshots_sharing_cow(snap, &snap_src, &snap_dest, 471 &snap_merge) == 2) || 472 snap_dest) { 473 snap->ti->error = "Snapshot cow pairing for exception " 474 "table handover failed"; 475 return -EINVAL; 476 } 477 478 /* 479 * If no snap_src was found, snap cannot become a handover 480 * destination. 481 */ 482 if (!snap_src) 483 return 0; 484 485 /* 486 * Non-snapshot-merge handover? 487 */ 488 if (!dm_target_is_snapshot_merge(snap->ti)) 489 return 1; 490 491 /* 492 * Do not allow more than one merging snapshot. 493 */ 494 if (snap_merge) { 495 snap->ti->error = "A snapshot is already merging."; 496 return -EINVAL; 497 } 498 499 if (!snap_src->store->type->prepare_merge || 500 !snap_src->store->type->commit_merge) { 501 snap->ti->error = "Snapshot exception store does not " 502 "support snapshot-merge."; 503 return -EINVAL; 504 } 505 506 return 1; 507 } 508 509 static void __insert_snapshot(struct origin *o, struct dm_snapshot *s) 510 { 511 struct dm_snapshot *l; 512 513 /* Sort the list according to chunk size, largest-first smallest-last */ 514 list_for_each_entry(l, &o->snapshots, list) 515 if (l->store->chunk_size < s->store->chunk_size) 516 break; 517 list_add_tail(&s->list, &l->list); 518 } 519 520 /* 521 * Make a note of the snapshot and its origin so we can look it 522 * up when the origin has a write on it. 523 * 524 * Also validate snapshot exception store handovers. 525 * On success, returns 1 if this registration is a handover destination, 526 * otherwise returns 0. 527 */ 528 static int register_snapshot(struct dm_snapshot *snap) 529 { 530 struct origin *o, *new_o = NULL; 531 struct block_device *bdev = snap->origin->bdev; 532 int r = 0; 533 534 new_o = kmalloc(sizeof(*new_o), GFP_KERNEL); 535 if (!new_o) 536 return -ENOMEM; 537 538 down_write(&_origins_lock); 539 540 r = __validate_exception_handover(snap); 541 if (r < 0) { 542 kfree(new_o); 543 goto out; 544 } 545 546 o = __lookup_origin(bdev); 547 if (o) 548 kfree(new_o); 549 else { 550 /* New origin */ 551 o = new_o; 552 553 /* Initialise the struct */ 554 INIT_LIST_HEAD(&o->snapshots); 555 o->bdev = bdev; 556 557 __insert_origin(o); 558 } 559 560 __insert_snapshot(o, snap); 561 562 out: 563 up_write(&_origins_lock); 564 565 return r; 566 } 567 568 /* 569 * Move snapshot to correct place in list according to chunk size. 570 */ 571 static void reregister_snapshot(struct dm_snapshot *s) 572 { 573 struct block_device *bdev = s->origin->bdev; 574 575 down_write(&_origins_lock); 576 577 list_del(&s->list); 578 __insert_snapshot(__lookup_origin(bdev), s); 579 580 up_write(&_origins_lock); 581 } 582 583 static void unregister_snapshot(struct dm_snapshot *s) 584 { 585 struct origin *o; 586 587 down_write(&_origins_lock); 588 o = __lookup_origin(s->origin->bdev); 589 590 list_del(&s->list); 591 if (o && list_empty(&o->snapshots)) { 592 list_del(&o->hash_list); 593 kfree(o); 594 } 595 596 up_write(&_origins_lock); 597 } 598 599 /* 600 * Implementation of the exception hash tables. 601 * The lowest hash_shift bits of the chunk number are ignored, allowing 602 * some consecutive chunks to be grouped together. 603 */ 604 static int dm_exception_table_init(struct dm_exception_table *et, 605 uint32_t size, unsigned hash_shift) 606 { 607 unsigned int i; 608 609 et->hash_shift = hash_shift; 610 et->hash_mask = size - 1; 611 et->table = dm_vcalloc(size, sizeof(struct list_head)); 612 if (!et->table) 613 return -ENOMEM; 614 615 for (i = 0; i < size; i++) 616 INIT_LIST_HEAD(et->table + i); 617 618 return 0; 619 } 620 621 static void dm_exception_table_exit(struct dm_exception_table *et, 622 struct kmem_cache *mem) 623 { 624 struct list_head *slot; 625 struct dm_exception *ex, *next; 626 int i, size; 627 628 size = et->hash_mask + 1; 629 for (i = 0; i < size; i++) { 630 slot = et->table + i; 631 632 list_for_each_entry_safe (ex, next, slot, hash_list) 633 kmem_cache_free(mem, ex); 634 } 635 636 vfree(et->table); 637 } 638 639 static uint32_t exception_hash(struct dm_exception_table *et, chunk_t chunk) 640 { 641 return (chunk >> et->hash_shift) & et->hash_mask; 642 } 643 644 static void dm_remove_exception(struct dm_exception *e) 645 { 646 list_del(&e->hash_list); 647 } 648 649 /* 650 * Return the exception data for a sector, or NULL if not 651 * remapped. 652 */ 653 static struct dm_exception *dm_lookup_exception(struct dm_exception_table *et, 654 chunk_t chunk) 655 { 656 struct list_head *slot; 657 struct dm_exception *e; 658 659 slot = &et->table[exception_hash(et, chunk)]; 660 list_for_each_entry (e, slot, hash_list) 661 if (chunk >= e->old_chunk && 662 chunk <= e->old_chunk + dm_consecutive_chunk_count(e)) 663 return e; 664 665 return NULL; 666 } 667 668 static struct dm_exception *alloc_completed_exception(gfp_t gfp) 669 { 670 struct dm_exception *e; 671 672 e = kmem_cache_alloc(exception_cache, gfp); 673 if (!e && gfp == GFP_NOIO) 674 e = kmem_cache_alloc(exception_cache, GFP_ATOMIC); 675 676 return e; 677 } 678 679 static void free_completed_exception(struct dm_exception *e) 680 { 681 kmem_cache_free(exception_cache, e); 682 } 683 684 static struct dm_snap_pending_exception *alloc_pending_exception(struct dm_snapshot *s) 685 { 686 struct dm_snap_pending_exception *pe = mempool_alloc(s->pending_pool, 687 GFP_NOIO); 688 689 atomic_inc(&s->pending_exceptions_count); 690 pe->snap = s; 691 692 return pe; 693 } 694 695 static void free_pending_exception(struct dm_snap_pending_exception *pe) 696 { 697 struct dm_snapshot *s = pe->snap; 698 699 mempool_free(pe, s->pending_pool); 700 smp_mb__before_atomic(); 701 atomic_dec(&s->pending_exceptions_count); 702 } 703 704 static void dm_insert_exception(struct dm_exception_table *eh, 705 struct dm_exception *new_e) 706 { 707 struct list_head *l; 708 struct dm_exception *e = NULL; 709 710 l = &eh->table[exception_hash(eh, new_e->old_chunk)]; 711 712 /* Add immediately if this table doesn't support consecutive chunks */ 713 if (!eh->hash_shift) 714 goto out; 715 716 /* List is ordered by old_chunk */ 717 list_for_each_entry_reverse(e, l, hash_list) { 718 /* Insert after an existing chunk? */ 719 if (new_e->old_chunk == (e->old_chunk + 720 dm_consecutive_chunk_count(e) + 1) && 721 new_e->new_chunk == (dm_chunk_number(e->new_chunk) + 722 dm_consecutive_chunk_count(e) + 1)) { 723 dm_consecutive_chunk_count_inc(e); 724 free_completed_exception(new_e); 725 return; 726 } 727 728 /* Insert before an existing chunk? */ 729 if (new_e->old_chunk == (e->old_chunk - 1) && 730 new_e->new_chunk == (dm_chunk_number(e->new_chunk) - 1)) { 731 dm_consecutive_chunk_count_inc(e); 732 e->old_chunk--; 733 e->new_chunk--; 734 free_completed_exception(new_e); 735 return; 736 } 737 738 if (new_e->old_chunk > e->old_chunk) 739 break; 740 } 741 742 out: 743 list_add(&new_e->hash_list, e ? &e->hash_list : l); 744 } 745 746 /* 747 * Callback used by the exception stores to load exceptions when 748 * initialising. 749 */ 750 static int dm_add_exception(void *context, chunk_t old, chunk_t new) 751 { 752 struct dm_snapshot *s = context; 753 struct dm_exception *e; 754 755 e = alloc_completed_exception(GFP_KERNEL); 756 if (!e) 757 return -ENOMEM; 758 759 e->old_chunk = old; 760 761 /* Consecutive_count is implicitly initialised to zero */ 762 e->new_chunk = new; 763 764 dm_insert_exception(&s->complete, e); 765 766 return 0; 767 } 768 769 /* 770 * Return a minimum chunk size of all snapshots that have the specified origin. 771 * Return zero if the origin has no snapshots. 772 */ 773 static uint32_t __minimum_chunk_size(struct origin *o) 774 { 775 struct dm_snapshot *snap; 776 unsigned chunk_size = 0; 777 778 if (o) 779 list_for_each_entry(snap, &o->snapshots, list) 780 chunk_size = min_not_zero(chunk_size, 781 snap->store->chunk_size); 782 783 return (uint32_t) chunk_size; 784 } 785 786 /* 787 * Hard coded magic. 788 */ 789 static int calc_max_buckets(void) 790 { 791 /* use a fixed size of 2MB */ 792 unsigned long mem = 2 * 1024 * 1024; 793 mem /= sizeof(struct list_head); 794 795 return mem; 796 } 797 798 /* 799 * Allocate room for a suitable hash table. 800 */ 801 static int init_hash_tables(struct dm_snapshot *s) 802 { 803 sector_t hash_size, cow_dev_size, max_buckets; 804 805 /* 806 * Calculate based on the size of the original volume or 807 * the COW volume... 808 */ 809 cow_dev_size = get_dev_size(s->cow->bdev); 810 max_buckets = calc_max_buckets(); 811 812 hash_size = cow_dev_size >> s->store->chunk_shift; 813 hash_size = min(hash_size, max_buckets); 814 815 if (hash_size < 64) 816 hash_size = 64; 817 hash_size = rounddown_pow_of_two(hash_size); 818 if (dm_exception_table_init(&s->complete, hash_size, 819 DM_CHUNK_CONSECUTIVE_BITS)) 820 return -ENOMEM; 821 822 /* 823 * Allocate hash table for in-flight exceptions 824 * Make this smaller than the real hash table 825 */ 826 hash_size >>= 3; 827 if (hash_size < 64) 828 hash_size = 64; 829 830 if (dm_exception_table_init(&s->pending, hash_size, 0)) { 831 dm_exception_table_exit(&s->complete, exception_cache); 832 return -ENOMEM; 833 } 834 835 return 0; 836 } 837 838 static void merge_shutdown(struct dm_snapshot *s) 839 { 840 clear_bit_unlock(RUNNING_MERGE, &s->state_bits); 841 smp_mb__after_atomic(); 842 wake_up_bit(&s->state_bits, RUNNING_MERGE); 843 } 844 845 static struct bio *__release_queued_bios_after_merge(struct dm_snapshot *s) 846 { 847 s->first_merging_chunk = 0; 848 s->num_merging_chunks = 0; 849 850 return bio_list_get(&s->bios_queued_during_merge); 851 } 852 853 /* 854 * Remove one chunk from the index of completed exceptions. 855 */ 856 static int __remove_single_exception_chunk(struct dm_snapshot *s, 857 chunk_t old_chunk) 858 { 859 struct dm_exception *e; 860 861 e = dm_lookup_exception(&s->complete, old_chunk); 862 if (!e) { 863 DMERR("Corruption detected: exception for block %llu is " 864 "on disk but not in memory", 865 (unsigned long long)old_chunk); 866 return -EINVAL; 867 } 868 869 /* 870 * If this is the only chunk using this exception, remove exception. 871 */ 872 if (!dm_consecutive_chunk_count(e)) { 873 dm_remove_exception(e); 874 free_completed_exception(e); 875 return 0; 876 } 877 878 /* 879 * The chunk may be either at the beginning or the end of a 880 * group of consecutive chunks - never in the middle. We are 881 * removing chunks in the opposite order to that in which they 882 * were added, so this should always be true. 883 * Decrement the consecutive chunk counter and adjust the 884 * starting point if necessary. 885 */ 886 if (old_chunk == e->old_chunk) { 887 e->old_chunk++; 888 e->new_chunk++; 889 } else if (old_chunk != e->old_chunk + 890 dm_consecutive_chunk_count(e)) { 891 DMERR("Attempt to merge block %llu from the " 892 "middle of a chunk range [%llu - %llu]", 893 (unsigned long long)old_chunk, 894 (unsigned long long)e->old_chunk, 895 (unsigned long long) 896 e->old_chunk + dm_consecutive_chunk_count(e)); 897 return -EINVAL; 898 } 899 900 dm_consecutive_chunk_count_dec(e); 901 902 return 0; 903 } 904 905 static void flush_bios(struct bio *bio); 906 907 static int remove_single_exception_chunk(struct dm_snapshot *s) 908 { 909 struct bio *b = NULL; 910 int r; 911 chunk_t old_chunk = s->first_merging_chunk + s->num_merging_chunks - 1; 912 913 down_write(&s->lock); 914 915 /* 916 * Process chunks (and associated exceptions) in reverse order 917 * so that dm_consecutive_chunk_count_dec() accounting works. 918 */ 919 do { 920 r = __remove_single_exception_chunk(s, old_chunk); 921 if (r) 922 goto out; 923 } while (old_chunk-- > s->first_merging_chunk); 924 925 b = __release_queued_bios_after_merge(s); 926 927 out: 928 up_write(&s->lock); 929 if (b) 930 flush_bios(b); 931 932 return r; 933 } 934 935 static int origin_write_extent(struct dm_snapshot *merging_snap, 936 sector_t sector, unsigned chunk_size); 937 938 static void merge_callback(int read_err, unsigned long write_err, 939 void *context); 940 941 static uint64_t read_pending_exceptions_done_count(void) 942 { 943 uint64_t pending_exceptions_done; 944 945 spin_lock(&_pending_exceptions_done_spinlock); 946 pending_exceptions_done = _pending_exceptions_done_count; 947 spin_unlock(&_pending_exceptions_done_spinlock); 948 949 return pending_exceptions_done; 950 } 951 952 static void increment_pending_exceptions_done_count(void) 953 { 954 spin_lock(&_pending_exceptions_done_spinlock); 955 _pending_exceptions_done_count++; 956 spin_unlock(&_pending_exceptions_done_spinlock); 957 958 wake_up_all(&_pending_exceptions_done); 959 } 960 961 static void snapshot_merge_next_chunks(struct dm_snapshot *s) 962 { 963 int i, linear_chunks; 964 chunk_t old_chunk, new_chunk; 965 struct dm_io_region src, dest; 966 sector_t io_size; 967 uint64_t previous_count; 968 969 BUG_ON(!test_bit(RUNNING_MERGE, &s->state_bits)); 970 if (unlikely(test_bit(SHUTDOWN_MERGE, &s->state_bits))) 971 goto shut; 972 973 /* 974 * valid flag never changes during merge, so no lock required. 975 */ 976 if (!s->valid) { 977 DMERR("Snapshot is invalid: can't merge"); 978 goto shut; 979 } 980 981 linear_chunks = s->store->type->prepare_merge(s->store, &old_chunk, 982 &new_chunk); 983 if (linear_chunks <= 0) { 984 if (linear_chunks < 0) { 985 DMERR("Read error in exception store: " 986 "shutting down merge"); 987 down_write(&s->lock); 988 s->merge_failed = 1; 989 up_write(&s->lock); 990 } 991 goto shut; 992 } 993 994 /* Adjust old_chunk and new_chunk to reflect start of linear region */ 995 old_chunk = old_chunk + 1 - linear_chunks; 996 new_chunk = new_chunk + 1 - linear_chunks; 997 998 /* 999 * Use one (potentially large) I/O to copy all 'linear_chunks' 1000 * from the exception store to the origin 1001 */ 1002 io_size = linear_chunks * s->store->chunk_size; 1003 1004 dest.bdev = s->origin->bdev; 1005 dest.sector = chunk_to_sector(s->store, old_chunk); 1006 dest.count = min(io_size, get_dev_size(dest.bdev) - dest.sector); 1007 1008 src.bdev = s->cow->bdev; 1009 src.sector = chunk_to_sector(s->store, new_chunk); 1010 src.count = dest.count; 1011 1012 /* 1013 * Reallocate any exceptions needed in other snapshots then 1014 * wait for the pending exceptions to complete. 1015 * Each time any pending exception (globally on the system) 1016 * completes we are woken and repeat the process to find out 1017 * if we can proceed. While this may not seem a particularly 1018 * efficient algorithm, it is not expected to have any 1019 * significant impact on performance. 1020 */ 1021 previous_count = read_pending_exceptions_done_count(); 1022 while (origin_write_extent(s, dest.sector, io_size)) { 1023 wait_event(_pending_exceptions_done, 1024 (read_pending_exceptions_done_count() != 1025 previous_count)); 1026 /* Retry after the wait, until all exceptions are done. */ 1027 previous_count = read_pending_exceptions_done_count(); 1028 } 1029 1030 down_write(&s->lock); 1031 s->first_merging_chunk = old_chunk; 1032 s->num_merging_chunks = linear_chunks; 1033 up_write(&s->lock); 1034 1035 /* Wait until writes to all 'linear_chunks' drain */ 1036 for (i = 0; i < linear_chunks; i++) 1037 __check_for_conflicting_io(s, old_chunk + i); 1038 1039 dm_kcopyd_copy(s->kcopyd_client, &src, 1, &dest, 0, merge_callback, s); 1040 return; 1041 1042 shut: 1043 merge_shutdown(s); 1044 } 1045 1046 static void error_bios(struct bio *bio); 1047 1048 static void merge_callback(int read_err, unsigned long write_err, void *context) 1049 { 1050 struct dm_snapshot *s = context; 1051 struct bio *b = NULL; 1052 1053 if (read_err || write_err) { 1054 if (read_err) 1055 DMERR("Read error: shutting down merge."); 1056 else 1057 DMERR("Write error: shutting down merge."); 1058 goto shut; 1059 } 1060 1061 if (s->store->type->commit_merge(s->store, 1062 s->num_merging_chunks) < 0) { 1063 DMERR("Write error in exception store: shutting down merge"); 1064 goto shut; 1065 } 1066 1067 if (remove_single_exception_chunk(s) < 0) 1068 goto shut; 1069 1070 snapshot_merge_next_chunks(s); 1071 1072 return; 1073 1074 shut: 1075 down_write(&s->lock); 1076 s->merge_failed = 1; 1077 b = __release_queued_bios_after_merge(s); 1078 up_write(&s->lock); 1079 error_bios(b); 1080 1081 merge_shutdown(s); 1082 } 1083 1084 static void start_merge(struct dm_snapshot *s) 1085 { 1086 if (!test_and_set_bit(RUNNING_MERGE, &s->state_bits)) 1087 snapshot_merge_next_chunks(s); 1088 } 1089 1090 /* 1091 * Stop the merging process and wait until it finishes. 1092 */ 1093 static void stop_merge(struct dm_snapshot *s) 1094 { 1095 set_bit(SHUTDOWN_MERGE, &s->state_bits); 1096 wait_on_bit(&s->state_bits, RUNNING_MERGE, TASK_UNINTERRUPTIBLE); 1097 clear_bit(SHUTDOWN_MERGE, &s->state_bits); 1098 } 1099 1100 /* 1101 * Construct a snapshot mapping: <origin_dev> <COW-dev> <p/n> <chunk-size> 1102 */ 1103 static int snapshot_ctr(struct dm_target *ti, unsigned int argc, char **argv) 1104 { 1105 struct dm_snapshot *s; 1106 int i; 1107 int r = -EINVAL; 1108 char *origin_path, *cow_path; 1109 unsigned args_used, num_flush_bios = 1; 1110 fmode_t origin_mode = FMODE_READ; 1111 1112 if (argc != 4) { 1113 ti->error = "requires exactly 4 arguments"; 1114 r = -EINVAL; 1115 goto bad; 1116 } 1117 1118 if (dm_target_is_snapshot_merge(ti)) { 1119 num_flush_bios = 2; 1120 origin_mode = FMODE_WRITE; 1121 } 1122 1123 s = kmalloc(sizeof(*s), GFP_KERNEL); 1124 if (!s) { 1125 ti->error = "Cannot allocate private snapshot structure"; 1126 r = -ENOMEM; 1127 goto bad; 1128 } 1129 1130 origin_path = argv[0]; 1131 argv++; 1132 argc--; 1133 1134 r = dm_get_device(ti, origin_path, origin_mode, &s->origin); 1135 if (r) { 1136 ti->error = "Cannot get origin device"; 1137 goto bad_origin; 1138 } 1139 1140 cow_path = argv[0]; 1141 argv++; 1142 argc--; 1143 1144 r = dm_get_device(ti, cow_path, dm_table_get_mode(ti->table), &s->cow); 1145 if (r) { 1146 ti->error = "Cannot get COW device"; 1147 goto bad_cow; 1148 } 1149 1150 r = dm_exception_store_create(ti, argc, argv, s, &args_used, &s->store); 1151 if (r) { 1152 ti->error = "Couldn't create exception store"; 1153 r = -EINVAL; 1154 goto bad_store; 1155 } 1156 1157 argv += args_used; 1158 argc -= args_used; 1159 1160 s->ti = ti; 1161 s->valid = 1; 1162 s->snapshot_overflowed = 0; 1163 s->active = 0; 1164 atomic_set(&s->pending_exceptions_count, 0); 1165 s->exception_start_sequence = 0; 1166 s->exception_complete_sequence = 0; 1167 INIT_LIST_HEAD(&s->out_of_order_list); 1168 init_rwsem(&s->lock); 1169 INIT_LIST_HEAD(&s->list); 1170 spin_lock_init(&s->pe_lock); 1171 s->state_bits = 0; 1172 s->merge_failed = 0; 1173 s->first_merging_chunk = 0; 1174 s->num_merging_chunks = 0; 1175 bio_list_init(&s->bios_queued_during_merge); 1176 1177 /* Allocate hash table for COW data */ 1178 if (init_hash_tables(s)) { 1179 ti->error = "Unable to allocate hash table space"; 1180 r = -ENOMEM; 1181 goto bad_hash_tables; 1182 } 1183 1184 s->kcopyd_client = dm_kcopyd_client_create(&dm_kcopyd_throttle); 1185 if (IS_ERR(s->kcopyd_client)) { 1186 r = PTR_ERR(s->kcopyd_client); 1187 ti->error = "Could not create kcopyd client"; 1188 goto bad_kcopyd; 1189 } 1190 1191 s->pending_pool = mempool_create_slab_pool(MIN_IOS, pending_cache); 1192 if (!s->pending_pool) { 1193 ti->error = "Could not allocate mempool for pending exceptions"; 1194 r = -ENOMEM; 1195 goto bad_pending_pool; 1196 } 1197 1198 for (i = 0; i < DM_TRACKED_CHUNK_HASH_SIZE; i++) 1199 INIT_HLIST_HEAD(&s->tracked_chunk_hash[i]); 1200 1201 spin_lock_init(&s->tracked_chunk_lock); 1202 1203 ti->private = s; 1204 ti->num_flush_bios = num_flush_bios; 1205 ti->per_bio_data_size = sizeof(struct dm_snap_tracked_chunk); 1206 1207 /* Add snapshot to the list of snapshots for this origin */ 1208 /* Exceptions aren't triggered till snapshot_resume() is called */ 1209 r = register_snapshot(s); 1210 if (r == -ENOMEM) { 1211 ti->error = "Snapshot origin struct allocation failed"; 1212 goto bad_load_and_register; 1213 } else if (r < 0) { 1214 /* invalid handover, register_snapshot has set ti->error */ 1215 goto bad_load_and_register; 1216 } 1217 1218 /* 1219 * Metadata must only be loaded into one table at once, so skip this 1220 * if metadata will be handed over during resume. 1221 * Chunk size will be set during the handover - set it to zero to 1222 * ensure it's ignored. 1223 */ 1224 if (r > 0) { 1225 s->store->chunk_size = 0; 1226 return 0; 1227 } 1228 1229 r = s->store->type->read_metadata(s->store, dm_add_exception, 1230 (void *)s); 1231 if (r < 0) { 1232 ti->error = "Failed to read snapshot metadata"; 1233 goto bad_read_metadata; 1234 } else if (r > 0) { 1235 s->valid = 0; 1236 DMWARN("Snapshot is marked invalid."); 1237 } 1238 1239 if (!s->store->chunk_size) { 1240 ti->error = "Chunk size not set"; 1241 goto bad_read_metadata; 1242 } 1243 1244 r = dm_set_target_max_io_len(ti, s->store->chunk_size); 1245 if (r) 1246 goto bad_read_metadata; 1247 1248 return 0; 1249 1250 bad_read_metadata: 1251 unregister_snapshot(s); 1252 1253 bad_load_and_register: 1254 mempool_destroy(s->pending_pool); 1255 1256 bad_pending_pool: 1257 dm_kcopyd_client_destroy(s->kcopyd_client); 1258 1259 bad_kcopyd: 1260 dm_exception_table_exit(&s->pending, pending_cache); 1261 dm_exception_table_exit(&s->complete, exception_cache); 1262 1263 bad_hash_tables: 1264 dm_exception_store_destroy(s->store); 1265 1266 bad_store: 1267 dm_put_device(ti, s->cow); 1268 1269 bad_cow: 1270 dm_put_device(ti, s->origin); 1271 1272 bad_origin: 1273 kfree(s); 1274 1275 bad: 1276 return r; 1277 } 1278 1279 static void __free_exceptions(struct dm_snapshot *s) 1280 { 1281 dm_kcopyd_client_destroy(s->kcopyd_client); 1282 s->kcopyd_client = NULL; 1283 1284 dm_exception_table_exit(&s->pending, pending_cache); 1285 dm_exception_table_exit(&s->complete, exception_cache); 1286 } 1287 1288 static void __handover_exceptions(struct dm_snapshot *snap_src, 1289 struct dm_snapshot *snap_dest) 1290 { 1291 union { 1292 struct dm_exception_table table_swap; 1293 struct dm_exception_store *store_swap; 1294 } u; 1295 1296 /* 1297 * Swap all snapshot context information between the two instances. 1298 */ 1299 u.table_swap = snap_dest->complete; 1300 snap_dest->complete = snap_src->complete; 1301 snap_src->complete = u.table_swap; 1302 1303 u.store_swap = snap_dest->store; 1304 snap_dest->store = snap_src->store; 1305 snap_src->store = u.store_swap; 1306 1307 snap_dest->store->snap = snap_dest; 1308 snap_src->store->snap = snap_src; 1309 1310 snap_dest->ti->max_io_len = snap_dest->store->chunk_size; 1311 snap_dest->valid = snap_src->valid; 1312 snap_dest->snapshot_overflowed = snap_src->snapshot_overflowed; 1313 1314 /* 1315 * Set source invalid to ensure it receives no further I/O. 1316 */ 1317 snap_src->valid = 0; 1318 } 1319 1320 static void snapshot_dtr(struct dm_target *ti) 1321 { 1322 #ifdef CONFIG_DM_DEBUG 1323 int i; 1324 #endif 1325 struct dm_snapshot *s = ti->private; 1326 struct dm_snapshot *snap_src = NULL, *snap_dest = NULL; 1327 1328 down_read(&_origins_lock); 1329 /* Check whether exception handover must be cancelled */ 1330 (void) __find_snapshots_sharing_cow(s, &snap_src, &snap_dest, NULL); 1331 if (snap_src && snap_dest && (s == snap_src)) { 1332 down_write(&snap_dest->lock); 1333 snap_dest->valid = 0; 1334 up_write(&snap_dest->lock); 1335 DMERR("Cancelling snapshot handover."); 1336 } 1337 up_read(&_origins_lock); 1338 1339 if (dm_target_is_snapshot_merge(ti)) 1340 stop_merge(s); 1341 1342 /* Prevent further origin writes from using this snapshot. */ 1343 /* After this returns there can be no new kcopyd jobs. */ 1344 unregister_snapshot(s); 1345 1346 while (atomic_read(&s->pending_exceptions_count)) 1347 msleep(1); 1348 /* 1349 * Ensure instructions in mempool_destroy aren't reordered 1350 * before atomic_read. 1351 */ 1352 smp_mb(); 1353 1354 #ifdef CONFIG_DM_DEBUG 1355 for (i = 0; i < DM_TRACKED_CHUNK_HASH_SIZE; i++) 1356 BUG_ON(!hlist_empty(&s->tracked_chunk_hash[i])); 1357 #endif 1358 1359 __free_exceptions(s); 1360 1361 mempool_destroy(s->pending_pool); 1362 1363 dm_exception_store_destroy(s->store); 1364 1365 dm_put_device(ti, s->cow); 1366 1367 dm_put_device(ti, s->origin); 1368 1369 kfree(s); 1370 } 1371 1372 /* 1373 * Flush a list of buffers. 1374 */ 1375 static void flush_bios(struct bio *bio) 1376 { 1377 struct bio *n; 1378 1379 while (bio) { 1380 n = bio->bi_next; 1381 bio->bi_next = NULL; 1382 generic_make_request(bio); 1383 bio = n; 1384 } 1385 } 1386 1387 static int do_origin(struct dm_dev *origin, struct bio *bio); 1388 1389 /* 1390 * Flush a list of buffers. 1391 */ 1392 static void retry_origin_bios(struct dm_snapshot *s, struct bio *bio) 1393 { 1394 struct bio *n; 1395 int r; 1396 1397 while (bio) { 1398 n = bio->bi_next; 1399 bio->bi_next = NULL; 1400 r = do_origin(s->origin, bio); 1401 if (r == DM_MAPIO_REMAPPED) 1402 generic_make_request(bio); 1403 bio = n; 1404 } 1405 } 1406 1407 /* 1408 * Error a list of buffers. 1409 */ 1410 static void error_bios(struct bio *bio) 1411 { 1412 struct bio *n; 1413 1414 while (bio) { 1415 n = bio->bi_next; 1416 bio->bi_next = NULL; 1417 bio_io_error(bio); 1418 bio = n; 1419 } 1420 } 1421 1422 static void __invalidate_snapshot(struct dm_snapshot *s, int err) 1423 { 1424 if (!s->valid) 1425 return; 1426 1427 if (err == -EIO) 1428 DMERR("Invalidating snapshot: Error reading/writing."); 1429 else if (err == -ENOMEM) 1430 DMERR("Invalidating snapshot: Unable to allocate exception."); 1431 1432 if (s->store->type->drop_snapshot) 1433 s->store->type->drop_snapshot(s->store); 1434 1435 s->valid = 0; 1436 1437 dm_table_event(s->ti->table); 1438 } 1439 1440 static void pending_complete(struct dm_snap_pending_exception *pe, int success) 1441 { 1442 struct dm_exception *e; 1443 struct dm_snapshot *s = pe->snap; 1444 struct bio *origin_bios = NULL; 1445 struct bio *snapshot_bios = NULL; 1446 struct bio *full_bio = NULL; 1447 int error = 0; 1448 1449 if (!success) { 1450 /* Read/write error - snapshot is unusable */ 1451 down_write(&s->lock); 1452 __invalidate_snapshot(s, -EIO); 1453 error = 1; 1454 goto out; 1455 } 1456 1457 e = alloc_completed_exception(GFP_NOIO); 1458 if (!e) { 1459 down_write(&s->lock); 1460 __invalidate_snapshot(s, -ENOMEM); 1461 error = 1; 1462 goto out; 1463 } 1464 *e = pe->e; 1465 1466 down_write(&s->lock); 1467 if (!s->valid) { 1468 free_completed_exception(e); 1469 error = 1; 1470 goto out; 1471 } 1472 1473 /* Check for conflicting reads */ 1474 __check_for_conflicting_io(s, pe->e.old_chunk); 1475 1476 /* 1477 * Add a proper exception, and remove the 1478 * in-flight exception from the list. 1479 */ 1480 dm_insert_exception(&s->complete, e); 1481 1482 out: 1483 dm_remove_exception(&pe->e); 1484 snapshot_bios = bio_list_get(&pe->snapshot_bios); 1485 origin_bios = bio_list_get(&pe->origin_bios); 1486 full_bio = pe->full_bio; 1487 if (full_bio) { 1488 full_bio->bi_end_io = pe->full_bio_end_io; 1489 full_bio->bi_private = pe->full_bio_private; 1490 } 1491 increment_pending_exceptions_done_count(); 1492 1493 up_write(&s->lock); 1494 1495 /* Submit any pending write bios */ 1496 if (error) { 1497 if (full_bio) 1498 bio_io_error(full_bio); 1499 error_bios(snapshot_bios); 1500 } else { 1501 if (full_bio) 1502 bio_endio(full_bio); 1503 flush_bios(snapshot_bios); 1504 } 1505 1506 retry_origin_bios(s, origin_bios); 1507 1508 free_pending_exception(pe); 1509 } 1510 1511 static void commit_callback(void *context, int success) 1512 { 1513 struct dm_snap_pending_exception *pe = context; 1514 1515 pending_complete(pe, success); 1516 } 1517 1518 static void complete_exception(struct dm_snap_pending_exception *pe) 1519 { 1520 struct dm_snapshot *s = pe->snap; 1521 1522 if (unlikely(pe->copy_error)) 1523 pending_complete(pe, 0); 1524 1525 else 1526 /* Update the metadata if we are persistent */ 1527 s->store->type->commit_exception(s->store, &pe->e, 1528 commit_callback, pe); 1529 } 1530 1531 /* 1532 * Called when the copy I/O has finished. kcopyd actually runs 1533 * this code so don't block. 1534 */ 1535 static void copy_callback(int read_err, unsigned long write_err, void *context) 1536 { 1537 struct dm_snap_pending_exception *pe = context; 1538 struct dm_snapshot *s = pe->snap; 1539 1540 pe->copy_error = read_err || write_err; 1541 1542 if (pe->exception_sequence == s->exception_complete_sequence) { 1543 s->exception_complete_sequence++; 1544 complete_exception(pe); 1545 1546 while (!list_empty(&s->out_of_order_list)) { 1547 pe = list_entry(s->out_of_order_list.next, 1548 struct dm_snap_pending_exception, out_of_order_entry); 1549 if (pe->exception_sequence != s->exception_complete_sequence) 1550 break; 1551 s->exception_complete_sequence++; 1552 list_del(&pe->out_of_order_entry); 1553 complete_exception(pe); 1554 } 1555 } else { 1556 struct list_head *lh; 1557 struct dm_snap_pending_exception *pe2; 1558 1559 list_for_each_prev(lh, &s->out_of_order_list) { 1560 pe2 = list_entry(lh, struct dm_snap_pending_exception, out_of_order_entry); 1561 if (pe2->exception_sequence < pe->exception_sequence) 1562 break; 1563 } 1564 list_add(&pe->out_of_order_entry, lh); 1565 } 1566 } 1567 1568 /* 1569 * Dispatches the copy operation to kcopyd. 1570 */ 1571 static void start_copy(struct dm_snap_pending_exception *pe) 1572 { 1573 struct dm_snapshot *s = pe->snap; 1574 struct dm_io_region src, dest; 1575 struct block_device *bdev = s->origin->bdev; 1576 sector_t dev_size; 1577 1578 dev_size = get_dev_size(bdev); 1579 1580 src.bdev = bdev; 1581 src.sector = chunk_to_sector(s->store, pe->e.old_chunk); 1582 src.count = min((sector_t)s->store->chunk_size, dev_size - src.sector); 1583 1584 dest.bdev = s->cow->bdev; 1585 dest.sector = chunk_to_sector(s->store, pe->e.new_chunk); 1586 dest.count = src.count; 1587 1588 /* Hand over to kcopyd */ 1589 dm_kcopyd_copy(s->kcopyd_client, &src, 1, &dest, 0, copy_callback, pe); 1590 } 1591 1592 static void full_bio_end_io(struct bio *bio) 1593 { 1594 void *callback_data = bio->bi_private; 1595 1596 dm_kcopyd_do_callback(callback_data, 0, bio->bi_error ? 1 : 0); 1597 } 1598 1599 static void start_full_bio(struct dm_snap_pending_exception *pe, 1600 struct bio *bio) 1601 { 1602 struct dm_snapshot *s = pe->snap; 1603 void *callback_data; 1604 1605 pe->full_bio = bio; 1606 pe->full_bio_end_io = bio->bi_end_io; 1607 pe->full_bio_private = bio->bi_private; 1608 1609 callback_data = dm_kcopyd_prepare_callback(s->kcopyd_client, 1610 copy_callback, pe); 1611 1612 bio->bi_end_io = full_bio_end_io; 1613 bio->bi_private = callback_data; 1614 1615 generic_make_request(bio); 1616 } 1617 1618 static struct dm_snap_pending_exception * 1619 __lookup_pending_exception(struct dm_snapshot *s, chunk_t chunk) 1620 { 1621 struct dm_exception *e = dm_lookup_exception(&s->pending, chunk); 1622 1623 if (!e) 1624 return NULL; 1625 1626 return container_of(e, struct dm_snap_pending_exception, e); 1627 } 1628 1629 /* 1630 * Looks to see if this snapshot already has a pending exception 1631 * for this chunk, otherwise it allocates a new one and inserts 1632 * it into the pending table. 1633 * 1634 * NOTE: a write lock must be held on snap->lock before calling 1635 * this. 1636 */ 1637 static struct dm_snap_pending_exception * 1638 __find_pending_exception(struct dm_snapshot *s, 1639 struct dm_snap_pending_exception *pe, chunk_t chunk) 1640 { 1641 struct dm_snap_pending_exception *pe2; 1642 1643 pe2 = __lookup_pending_exception(s, chunk); 1644 if (pe2) { 1645 free_pending_exception(pe); 1646 return pe2; 1647 } 1648 1649 pe->e.old_chunk = chunk; 1650 bio_list_init(&pe->origin_bios); 1651 bio_list_init(&pe->snapshot_bios); 1652 pe->started = 0; 1653 pe->full_bio = NULL; 1654 1655 if (s->store->type->prepare_exception(s->store, &pe->e)) { 1656 free_pending_exception(pe); 1657 return NULL; 1658 } 1659 1660 pe->exception_sequence = s->exception_start_sequence++; 1661 1662 dm_insert_exception(&s->pending, &pe->e); 1663 1664 return pe; 1665 } 1666 1667 static void remap_exception(struct dm_snapshot *s, struct dm_exception *e, 1668 struct bio *bio, chunk_t chunk) 1669 { 1670 bio->bi_bdev = s->cow->bdev; 1671 bio->bi_iter.bi_sector = 1672 chunk_to_sector(s->store, dm_chunk_number(e->new_chunk) + 1673 (chunk - e->old_chunk)) + 1674 (bio->bi_iter.bi_sector & s->store->chunk_mask); 1675 } 1676 1677 static int snapshot_map(struct dm_target *ti, struct bio *bio) 1678 { 1679 struct dm_exception *e; 1680 struct dm_snapshot *s = ti->private; 1681 int r = DM_MAPIO_REMAPPED; 1682 chunk_t chunk; 1683 struct dm_snap_pending_exception *pe = NULL; 1684 1685 init_tracked_chunk(bio); 1686 1687 if (bio->bi_rw & REQ_FLUSH) { 1688 bio->bi_bdev = s->cow->bdev; 1689 return DM_MAPIO_REMAPPED; 1690 } 1691 1692 chunk = sector_to_chunk(s->store, bio->bi_iter.bi_sector); 1693 1694 /* Full snapshots are not usable */ 1695 /* To get here the table must be live so s->active is always set. */ 1696 if (!s->valid) 1697 return -EIO; 1698 1699 /* FIXME: should only take write lock if we need 1700 * to copy an exception */ 1701 down_write(&s->lock); 1702 1703 if (!s->valid || (unlikely(s->snapshot_overflowed) && bio_rw(bio) == WRITE)) { 1704 r = -EIO; 1705 goto out_unlock; 1706 } 1707 1708 /* If the block is already remapped - use that, else remap it */ 1709 e = dm_lookup_exception(&s->complete, chunk); 1710 if (e) { 1711 remap_exception(s, e, bio, chunk); 1712 goto out_unlock; 1713 } 1714 1715 /* 1716 * Write to snapshot - higher level takes care of RW/RO 1717 * flags so we should only get this if we are 1718 * writeable. 1719 */ 1720 if (bio_rw(bio) == WRITE) { 1721 pe = __lookup_pending_exception(s, chunk); 1722 if (!pe) { 1723 up_write(&s->lock); 1724 pe = alloc_pending_exception(s); 1725 down_write(&s->lock); 1726 1727 if (!s->valid || s->snapshot_overflowed) { 1728 free_pending_exception(pe); 1729 r = -EIO; 1730 goto out_unlock; 1731 } 1732 1733 e = dm_lookup_exception(&s->complete, chunk); 1734 if (e) { 1735 free_pending_exception(pe); 1736 remap_exception(s, e, bio, chunk); 1737 goto out_unlock; 1738 } 1739 1740 pe = __find_pending_exception(s, pe, chunk); 1741 if (!pe) { 1742 s->snapshot_overflowed = 1; 1743 DMERR("Snapshot overflowed: Unable to allocate exception."); 1744 r = -EIO; 1745 goto out_unlock; 1746 } 1747 } 1748 1749 remap_exception(s, &pe->e, bio, chunk); 1750 1751 r = DM_MAPIO_SUBMITTED; 1752 1753 if (!pe->started && 1754 bio->bi_iter.bi_size == 1755 (s->store->chunk_size << SECTOR_SHIFT)) { 1756 pe->started = 1; 1757 up_write(&s->lock); 1758 start_full_bio(pe, bio); 1759 goto out; 1760 } 1761 1762 bio_list_add(&pe->snapshot_bios, bio); 1763 1764 if (!pe->started) { 1765 /* this is protected by snap->lock */ 1766 pe->started = 1; 1767 up_write(&s->lock); 1768 start_copy(pe); 1769 goto out; 1770 } 1771 } else { 1772 bio->bi_bdev = s->origin->bdev; 1773 track_chunk(s, bio, chunk); 1774 } 1775 1776 out_unlock: 1777 up_write(&s->lock); 1778 out: 1779 return r; 1780 } 1781 1782 /* 1783 * A snapshot-merge target behaves like a combination of a snapshot 1784 * target and a snapshot-origin target. It only generates new 1785 * exceptions in other snapshots and not in the one that is being 1786 * merged. 1787 * 1788 * For each chunk, if there is an existing exception, it is used to 1789 * redirect I/O to the cow device. Otherwise I/O is sent to the origin, 1790 * which in turn might generate exceptions in other snapshots. 1791 * If merging is currently taking place on the chunk in question, the 1792 * I/O is deferred by adding it to s->bios_queued_during_merge. 1793 */ 1794 static int snapshot_merge_map(struct dm_target *ti, struct bio *bio) 1795 { 1796 struct dm_exception *e; 1797 struct dm_snapshot *s = ti->private; 1798 int r = DM_MAPIO_REMAPPED; 1799 chunk_t chunk; 1800 1801 init_tracked_chunk(bio); 1802 1803 if (bio->bi_rw & REQ_FLUSH) { 1804 if (!dm_bio_get_target_bio_nr(bio)) 1805 bio->bi_bdev = s->origin->bdev; 1806 else 1807 bio->bi_bdev = s->cow->bdev; 1808 return DM_MAPIO_REMAPPED; 1809 } 1810 1811 chunk = sector_to_chunk(s->store, bio->bi_iter.bi_sector); 1812 1813 down_write(&s->lock); 1814 1815 /* Full merging snapshots are redirected to the origin */ 1816 if (!s->valid) 1817 goto redirect_to_origin; 1818 1819 /* If the block is already remapped - use that */ 1820 e = dm_lookup_exception(&s->complete, chunk); 1821 if (e) { 1822 /* Queue writes overlapping with chunks being merged */ 1823 if (bio_rw(bio) == WRITE && 1824 chunk >= s->first_merging_chunk && 1825 chunk < (s->first_merging_chunk + 1826 s->num_merging_chunks)) { 1827 bio->bi_bdev = s->origin->bdev; 1828 bio_list_add(&s->bios_queued_during_merge, bio); 1829 r = DM_MAPIO_SUBMITTED; 1830 goto out_unlock; 1831 } 1832 1833 remap_exception(s, e, bio, chunk); 1834 1835 if (bio_rw(bio) == WRITE) 1836 track_chunk(s, bio, chunk); 1837 goto out_unlock; 1838 } 1839 1840 redirect_to_origin: 1841 bio->bi_bdev = s->origin->bdev; 1842 1843 if (bio_rw(bio) == WRITE) { 1844 up_write(&s->lock); 1845 return do_origin(s->origin, bio); 1846 } 1847 1848 out_unlock: 1849 up_write(&s->lock); 1850 1851 return r; 1852 } 1853 1854 static int snapshot_end_io(struct dm_target *ti, struct bio *bio, int error) 1855 { 1856 struct dm_snapshot *s = ti->private; 1857 1858 if (is_bio_tracked(bio)) 1859 stop_tracking_chunk(s, bio); 1860 1861 return 0; 1862 } 1863 1864 static void snapshot_merge_presuspend(struct dm_target *ti) 1865 { 1866 struct dm_snapshot *s = ti->private; 1867 1868 stop_merge(s); 1869 } 1870 1871 static int snapshot_preresume(struct dm_target *ti) 1872 { 1873 int r = 0; 1874 struct dm_snapshot *s = ti->private; 1875 struct dm_snapshot *snap_src = NULL, *snap_dest = NULL; 1876 1877 down_read(&_origins_lock); 1878 (void) __find_snapshots_sharing_cow(s, &snap_src, &snap_dest, NULL); 1879 if (snap_src && snap_dest) { 1880 down_read(&snap_src->lock); 1881 if (s == snap_src) { 1882 DMERR("Unable to resume snapshot source until " 1883 "handover completes."); 1884 r = -EINVAL; 1885 } else if (!dm_suspended(snap_src->ti)) { 1886 DMERR("Unable to perform snapshot handover until " 1887 "source is suspended."); 1888 r = -EINVAL; 1889 } 1890 up_read(&snap_src->lock); 1891 } 1892 up_read(&_origins_lock); 1893 1894 return r; 1895 } 1896 1897 static void snapshot_resume(struct dm_target *ti) 1898 { 1899 struct dm_snapshot *s = ti->private; 1900 struct dm_snapshot *snap_src = NULL, *snap_dest = NULL, *snap_merging = NULL; 1901 struct dm_origin *o; 1902 struct mapped_device *origin_md = NULL; 1903 bool must_restart_merging = false; 1904 1905 down_read(&_origins_lock); 1906 1907 o = __lookup_dm_origin(s->origin->bdev); 1908 if (o) 1909 origin_md = dm_table_get_md(o->ti->table); 1910 if (!origin_md) { 1911 (void) __find_snapshots_sharing_cow(s, NULL, NULL, &snap_merging); 1912 if (snap_merging) 1913 origin_md = dm_table_get_md(snap_merging->ti->table); 1914 } 1915 if (origin_md == dm_table_get_md(ti->table)) 1916 origin_md = NULL; 1917 if (origin_md) { 1918 if (dm_hold(origin_md)) 1919 origin_md = NULL; 1920 } 1921 1922 up_read(&_origins_lock); 1923 1924 if (origin_md) { 1925 dm_internal_suspend_fast(origin_md); 1926 if (snap_merging && test_bit(RUNNING_MERGE, &snap_merging->state_bits)) { 1927 must_restart_merging = true; 1928 stop_merge(snap_merging); 1929 } 1930 } 1931 1932 down_read(&_origins_lock); 1933 1934 (void) __find_snapshots_sharing_cow(s, &snap_src, &snap_dest, NULL); 1935 if (snap_src && snap_dest) { 1936 down_write(&snap_src->lock); 1937 down_write_nested(&snap_dest->lock, SINGLE_DEPTH_NESTING); 1938 __handover_exceptions(snap_src, snap_dest); 1939 up_write(&snap_dest->lock); 1940 up_write(&snap_src->lock); 1941 } 1942 1943 up_read(&_origins_lock); 1944 1945 if (origin_md) { 1946 if (must_restart_merging) 1947 start_merge(snap_merging); 1948 dm_internal_resume_fast(origin_md); 1949 dm_put(origin_md); 1950 } 1951 1952 /* Now we have correct chunk size, reregister */ 1953 reregister_snapshot(s); 1954 1955 down_write(&s->lock); 1956 s->active = 1; 1957 up_write(&s->lock); 1958 } 1959 1960 static uint32_t get_origin_minimum_chunksize(struct block_device *bdev) 1961 { 1962 uint32_t min_chunksize; 1963 1964 down_read(&_origins_lock); 1965 min_chunksize = __minimum_chunk_size(__lookup_origin(bdev)); 1966 up_read(&_origins_lock); 1967 1968 return min_chunksize; 1969 } 1970 1971 static void snapshot_merge_resume(struct dm_target *ti) 1972 { 1973 struct dm_snapshot *s = ti->private; 1974 1975 /* 1976 * Handover exceptions from existing snapshot. 1977 */ 1978 snapshot_resume(ti); 1979 1980 /* 1981 * snapshot-merge acts as an origin, so set ti->max_io_len 1982 */ 1983 ti->max_io_len = get_origin_minimum_chunksize(s->origin->bdev); 1984 1985 start_merge(s); 1986 } 1987 1988 static void snapshot_status(struct dm_target *ti, status_type_t type, 1989 unsigned status_flags, char *result, unsigned maxlen) 1990 { 1991 unsigned sz = 0; 1992 struct dm_snapshot *snap = ti->private; 1993 1994 switch (type) { 1995 case STATUSTYPE_INFO: 1996 1997 down_write(&snap->lock); 1998 1999 if (!snap->valid) 2000 DMEMIT("Invalid"); 2001 else if (snap->merge_failed) 2002 DMEMIT("Merge failed"); 2003 else if (snap->snapshot_overflowed) 2004 DMEMIT("Overflow"); 2005 else { 2006 if (snap->store->type->usage) { 2007 sector_t total_sectors, sectors_allocated, 2008 metadata_sectors; 2009 snap->store->type->usage(snap->store, 2010 &total_sectors, 2011 §ors_allocated, 2012 &metadata_sectors); 2013 DMEMIT("%llu/%llu %llu", 2014 (unsigned long long)sectors_allocated, 2015 (unsigned long long)total_sectors, 2016 (unsigned long long)metadata_sectors); 2017 } 2018 else 2019 DMEMIT("Unknown"); 2020 } 2021 2022 up_write(&snap->lock); 2023 2024 break; 2025 2026 case STATUSTYPE_TABLE: 2027 /* 2028 * kdevname returns a static pointer so we need 2029 * to make private copies if the output is to 2030 * make sense. 2031 */ 2032 DMEMIT("%s %s", snap->origin->name, snap->cow->name); 2033 snap->store->type->status(snap->store, type, result + sz, 2034 maxlen - sz); 2035 break; 2036 } 2037 } 2038 2039 static int snapshot_iterate_devices(struct dm_target *ti, 2040 iterate_devices_callout_fn fn, void *data) 2041 { 2042 struct dm_snapshot *snap = ti->private; 2043 int r; 2044 2045 r = fn(ti, snap->origin, 0, ti->len, data); 2046 2047 if (!r) 2048 r = fn(ti, snap->cow, 0, get_dev_size(snap->cow->bdev), data); 2049 2050 return r; 2051 } 2052 2053 2054 /*----------------------------------------------------------------- 2055 * Origin methods 2056 *---------------------------------------------------------------*/ 2057 2058 /* 2059 * If no exceptions need creating, DM_MAPIO_REMAPPED is returned and any 2060 * supplied bio was ignored. The caller may submit it immediately. 2061 * (No remapping actually occurs as the origin is always a direct linear 2062 * map.) 2063 * 2064 * If further exceptions are required, DM_MAPIO_SUBMITTED is returned 2065 * and any supplied bio is added to a list to be submitted once all 2066 * the necessary exceptions exist. 2067 */ 2068 static int __origin_write(struct list_head *snapshots, sector_t sector, 2069 struct bio *bio) 2070 { 2071 int r = DM_MAPIO_REMAPPED; 2072 struct dm_snapshot *snap; 2073 struct dm_exception *e; 2074 struct dm_snap_pending_exception *pe; 2075 struct dm_snap_pending_exception *pe_to_start_now = NULL; 2076 struct dm_snap_pending_exception *pe_to_start_last = NULL; 2077 chunk_t chunk; 2078 2079 /* Do all the snapshots on this origin */ 2080 list_for_each_entry (snap, snapshots, list) { 2081 /* 2082 * Don't make new exceptions in a merging snapshot 2083 * because it has effectively been deleted 2084 */ 2085 if (dm_target_is_snapshot_merge(snap->ti)) 2086 continue; 2087 2088 down_write(&snap->lock); 2089 2090 /* Only deal with valid and active snapshots */ 2091 if (!snap->valid || !snap->active) 2092 goto next_snapshot; 2093 2094 /* Nothing to do if writing beyond end of snapshot */ 2095 if (sector >= dm_table_get_size(snap->ti->table)) 2096 goto next_snapshot; 2097 2098 /* 2099 * Remember, different snapshots can have 2100 * different chunk sizes. 2101 */ 2102 chunk = sector_to_chunk(snap->store, sector); 2103 2104 /* 2105 * Check exception table to see if block 2106 * is already remapped in this snapshot 2107 * and trigger an exception if not. 2108 */ 2109 e = dm_lookup_exception(&snap->complete, chunk); 2110 if (e) 2111 goto next_snapshot; 2112 2113 pe = __lookup_pending_exception(snap, chunk); 2114 if (!pe) { 2115 up_write(&snap->lock); 2116 pe = alloc_pending_exception(snap); 2117 down_write(&snap->lock); 2118 2119 if (!snap->valid) { 2120 free_pending_exception(pe); 2121 goto next_snapshot; 2122 } 2123 2124 e = dm_lookup_exception(&snap->complete, chunk); 2125 if (e) { 2126 free_pending_exception(pe); 2127 goto next_snapshot; 2128 } 2129 2130 pe = __find_pending_exception(snap, pe, chunk); 2131 if (!pe) { 2132 __invalidate_snapshot(snap, -ENOMEM); 2133 goto next_snapshot; 2134 } 2135 } 2136 2137 r = DM_MAPIO_SUBMITTED; 2138 2139 /* 2140 * If an origin bio was supplied, queue it to wait for the 2141 * completion of this exception, and start this one last, 2142 * at the end of the function. 2143 */ 2144 if (bio) { 2145 bio_list_add(&pe->origin_bios, bio); 2146 bio = NULL; 2147 2148 if (!pe->started) { 2149 pe->started = 1; 2150 pe_to_start_last = pe; 2151 } 2152 } 2153 2154 if (!pe->started) { 2155 pe->started = 1; 2156 pe_to_start_now = pe; 2157 } 2158 2159 next_snapshot: 2160 up_write(&snap->lock); 2161 2162 if (pe_to_start_now) { 2163 start_copy(pe_to_start_now); 2164 pe_to_start_now = NULL; 2165 } 2166 } 2167 2168 /* 2169 * Submit the exception against which the bio is queued last, 2170 * to give the other exceptions a head start. 2171 */ 2172 if (pe_to_start_last) 2173 start_copy(pe_to_start_last); 2174 2175 return r; 2176 } 2177 2178 /* 2179 * Called on a write from the origin driver. 2180 */ 2181 static int do_origin(struct dm_dev *origin, struct bio *bio) 2182 { 2183 struct origin *o; 2184 int r = DM_MAPIO_REMAPPED; 2185 2186 down_read(&_origins_lock); 2187 o = __lookup_origin(origin->bdev); 2188 if (o) 2189 r = __origin_write(&o->snapshots, bio->bi_iter.bi_sector, bio); 2190 up_read(&_origins_lock); 2191 2192 return r; 2193 } 2194 2195 /* 2196 * Trigger exceptions in all non-merging snapshots. 2197 * 2198 * The chunk size of the merging snapshot may be larger than the chunk 2199 * size of some other snapshot so we may need to reallocate multiple 2200 * chunks in other snapshots. 2201 * 2202 * We scan all the overlapping exceptions in the other snapshots. 2203 * Returns 1 if anything was reallocated and must be waited for, 2204 * otherwise returns 0. 2205 * 2206 * size must be a multiple of merging_snap's chunk_size. 2207 */ 2208 static int origin_write_extent(struct dm_snapshot *merging_snap, 2209 sector_t sector, unsigned size) 2210 { 2211 int must_wait = 0; 2212 sector_t n; 2213 struct origin *o; 2214 2215 /* 2216 * The origin's __minimum_chunk_size() got stored in max_io_len 2217 * by snapshot_merge_resume(). 2218 */ 2219 down_read(&_origins_lock); 2220 o = __lookup_origin(merging_snap->origin->bdev); 2221 for (n = 0; n < size; n += merging_snap->ti->max_io_len) 2222 if (__origin_write(&o->snapshots, sector + n, NULL) == 2223 DM_MAPIO_SUBMITTED) 2224 must_wait = 1; 2225 up_read(&_origins_lock); 2226 2227 return must_wait; 2228 } 2229 2230 /* 2231 * Origin: maps a linear range of a device, with hooks for snapshotting. 2232 */ 2233 2234 /* 2235 * Construct an origin mapping: <dev_path> 2236 * The context for an origin is merely a 'struct dm_dev *' 2237 * pointing to the real device. 2238 */ 2239 static int origin_ctr(struct dm_target *ti, unsigned int argc, char **argv) 2240 { 2241 int r; 2242 struct dm_origin *o; 2243 2244 if (argc != 1) { 2245 ti->error = "origin: incorrect number of arguments"; 2246 return -EINVAL; 2247 } 2248 2249 o = kmalloc(sizeof(struct dm_origin), GFP_KERNEL); 2250 if (!o) { 2251 ti->error = "Cannot allocate private origin structure"; 2252 r = -ENOMEM; 2253 goto bad_alloc; 2254 } 2255 2256 r = dm_get_device(ti, argv[0], dm_table_get_mode(ti->table), &o->dev); 2257 if (r) { 2258 ti->error = "Cannot get target device"; 2259 goto bad_open; 2260 } 2261 2262 o->ti = ti; 2263 ti->private = o; 2264 ti->num_flush_bios = 1; 2265 2266 return 0; 2267 2268 bad_open: 2269 kfree(o); 2270 bad_alloc: 2271 return r; 2272 } 2273 2274 static void origin_dtr(struct dm_target *ti) 2275 { 2276 struct dm_origin *o = ti->private; 2277 2278 dm_put_device(ti, o->dev); 2279 kfree(o); 2280 } 2281 2282 static int origin_map(struct dm_target *ti, struct bio *bio) 2283 { 2284 struct dm_origin *o = ti->private; 2285 unsigned available_sectors; 2286 2287 bio->bi_bdev = o->dev->bdev; 2288 2289 if (unlikely(bio->bi_rw & REQ_FLUSH)) 2290 return DM_MAPIO_REMAPPED; 2291 2292 if (bio_rw(bio) != WRITE) 2293 return DM_MAPIO_REMAPPED; 2294 2295 available_sectors = o->split_boundary - 2296 ((unsigned)bio->bi_iter.bi_sector & (o->split_boundary - 1)); 2297 2298 if (bio_sectors(bio) > available_sectors) 2299 dm_accept_partial_bio(bio, available_sectors); 2300 2301 /* Only tell snapshots if this is a write */ 2302 return do_origin(o->dev, bio); 2303 } 2304 2305 /* 2306 * Set the target "max_io_len" field to the minimum of all the snapshots' 2307 * chunk sizes. 2308 */ 2309 static void origin_resume(struct dm_target *ti) 2310 { 2311 struct dm_origin *o = ti->private; 2312 2313 o->split_boundary = get_origin_minimum_chunksize(o->dev->bdev); 2314 2315 down_write(&_origins_lock); 2316 __insert_dm_origin(o); 2317 up_write(&_origins_lock); 2318 } 2319 2320 static void origin_postsuspend(struct dm_target *ti) 2321 { 2322 struct dm_origin *o = ti->private; 2323 2324 down_write(&_origins_lock); 2325 __remove_dm_origin(o); 2326 up_write(&_origins_lock); 2327 } 2328 2329 static void origin_status(struct dm_target *ti, status_type_t type, 2330 unsigned status_flags, char *result, unsigned maxlen) 2331 { 2332 struct dm_origin *o = ti->private; 2333 2334 switch (type) { 2335 case STATUSTYPE_INFO: 2336 result[0] = '\0'; 2337 break; 2338 2339 case STATUSTYPE_TABLE: 2340 snprintf(result, maxlen, "%s", o->dev->name); 2341 break; 2342 } 2343 } 2344 2345 static int origin_iterate_devices(struct dm_target *ti, 2346 iterate_devices_callout_fn fn, void *data) 2347 { 2348 struct dm_origin *o = ti->private; 2349 2350 return fn(ti, o->dev, 0, ti->len, data); 2351 } 2352 2353 static struct target_type origin_target = { 2354 .name = "snapshot-origin", 2355 .version = {1, 9, 0}, 2356 .module = THIS_MODULE, 2357 .ctr = origin_ctr, 2358 .dtr = origin_dtr, 2359 .map = origin_map, 2360 .resume = origin_resume, 2361 .postsuspend = origin_postsuspend, 2362 .status = origin_status, 2363 .iterate_devices = origin_iterate_devices, 2364 }; 2365 2366 static struct target_type snapshot_target = { 2367 .name = "snapshot", 2368 .version = {1, 14, 0}, 2369 .module = THIS_MODULE, 2370 .ctr = snapshot_ctr, 2371 .dtr = snapshot_dtr, 2372 .map = snapshot_map, 2373 .end_io = snapshot_end_io, 2374 .preresume = snapshot_preresume, 2375 .resume = snapshot_resume, 2376 .status = snapshot_status, 2377 .iterate_devices = snapshot_iterate_devices, 2378 }; 2379 2380 static struct target_type merge_target = { 2381 .name = dm_snapshot_merge_target_name, 2382 .version = {1, 3, 0}, 2383 .module = THIS_MODULE, 2384 .ctr = snapshot_ctr, 2385 .dtr = snapshot_dtr, 2386 .map = snapshot_merge_map, 2387 .end_io = snapshot_end_io, 2388 .presuspend = snapshot_merge_presuspend, 2389 .preresume = snapshot_preresume, 2390 .resume = snapshot_merge_resume, 2391 .status = snapshot_status, 2392 .iterate_devices = snapshot_iterate_devices, 2393 }; 2394 2395 static int __init dm_snapshot_init(void) 2396 { 2397 int r; 2398 2399 r = dm_exception_store_init(); 2400 if (r) { 2401 DMERR("Failed to initialize exception stores"); 2402 return r; 2403 } 2404 2405 r = dm_register_target(&snapshot_target); 2406 if (r < 0) { 2407 DMERR("snapshot target register failed %d", r); 2408 goto bad_register_snapshot_target; 2409 } 2410 2411 r = dm_register_target(&origin_target); 2412 if (r < 0) { 2413 DMERR("Origin target register failed %d", r); 2414 goto bad_register_origin_target; 2415 } 2416 2417 r = dm_register_target(&merge_target); 2418 if (r < 0) { 2419 DMERR("Merge target register failed %d", r); 2420 goto bad_register_merge_target; 2421 } 2422 2423 r = init_origin_hash(); 2424 if (r) { 2425 DMERR("init_origin_hash failed."); 2426 goto bad_origin_hash; 2427 } 2428 2429 exception_cache = KMEM_CACHE(dm_exception, 0); 2430 if (!exception_cache) { 2431 DMERR("Couldn't create exception cache."); 2432 r = -ENOMEM; 2433 goto bad_exception_cache; 2434 } 2435 2436 pending_cache = KMEM_CACHE(dm_snap_pending_exception, 0); 2437 if (!pending_cache) { 2438 DMERR("Couldn't create pending cache."); 2439 r = -ENOMEM; 2440 goto bad_pending_cache; 2441 } 2442 2443 return 0; 2444 2445 bad_pending_cache: 2446 kmem_cache_destroy(exception_cache); 2447 bad_exception_cache: 2448 exit_origin_hash(); 2449 bad_origin_hash: 2450 dm_unregister_target(&merge_target); 2451 bad_register_merge_target: 2452 dm_unregister_target(&origin_target); 2453 bad_register_origin_target: 2454 dm_unregister_target(&snapshot_target); 2455 bad_register_snapshot_target: 2456 dm_exception_store_exit(); 2457 2458 return r; 2459 } 2460 2461 static void __exit dm_snapshot_exit(void) 2462 { 2463 dm_unregister_target(&snapshot_target); 2464 dm_unregister_target(&origin_target); 2465 dm_unregister_target(&merge_target); 2466 2467 exit_origin_hash(); 2468 kmem_cache_destroy(pending_cache); 2469 kmem_cache_destroy(exception_cache); 2470 2471 dm_exception_store_exit(); 2472 } 2473 2474 /* Module hooks */ 2475 module_init(dm_snapshot_init); 2476 module_exit(dm_snapshot_exit); 2477 2478 MODULE_DESCRIPTION(DM_NAME " snapshot target"); 2479 MODULE_AUTHOR("Joe Thornber"); 2480 MODULE_LICENSE("GPL"); 2481 MODULE_ALIAS("dm-snapshot-origin"); 2482 MODULE_ALIAS("dm-snapshot-merge"); 2483