diff options
author | Alex Elder <elder@inktank.com> | 2012-08-31 18:29:52 -0400 |
---|---|---|
committer | Alex Elder <elder@inktank.com> | 2012-10-01 15:30:51 -0400 |
commit | 4e1105a299adf7ac421d42a8be05205f51610f3c (patch) | |
tree | 74c0b0ba2390018d1aa66fdda2e9bc0b095bdb72 /drivers/block/rbd.c | |
parent | 3feeb8946739d980fb0922bf68363552a493a49c (diff) |
rbd: set mapping name with the rest
With the exception of the snapshot name, all of the mapping-specific
fields in an rbd device structure are set in rbd_header_set_snap().
Pass the snapshot name to be assigned into rbd_header_set_snap()
to keep all of the mapping assignments together.
Signed-off-by: Alex Elder <elder@inktank.com>
Reviewed-by: Josh Durgin <josh.durgin@inktank.com>
Diffstat (limited to 'drivers/block/rbd.c')
-rw-r--r-- | drivers/block/rbd.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c index 1a64ba294a76..23fa962fea36 100644 --- a/drivers/block/rbd.c +++ b/drivers/block/rbd.c | |||
@@ -644,21 +644,20 @@ static int snap_by_name(struct rbd_image_header *header, const char *snap_name, | |||
644 | return -ENOENT; | 644 | return -ENOENT; |
645 | } | 645 | } |
646 | 646 | ||
647 | static int rbd_header_set_snap(struct rbd_device *rbd_dev) | 647 | static int rbd_header_set_snap(struct rbd_device *rbd_dev, char *snap_name) |
648 | { | 648 | { |
649 | int ret; | 649 | int ret; |
650 | 650 | ||
651 | down_write(&rbd_dev->header_rwsem); | 651 | down_write(&rbd_dev->header_rwsem); |
652 | 652 | ||
653 | if (!memcmp(rbd_dev->mapping.snap_name, RBD_SNAP_HEAD_NAME, | 653 | if (!memcmp(snap_name, RBD_SNAP_HEAD_NAME, |
654 | sizeof (RBD_SNAP_HEAD_NAME))) { | 654 | sizeof (RBD_SNAP_HEAD_NAME))) { |
655 | rbd_dev->mapping.snap_id = CEPH_NOSNAP; | 655 | rbd_dev->mapping.snap_id = CEPH_NOSNAP; |
656 | rbd_dev->mapping.size = rbd_dev->header.image_size; | 656 | rbd_dev->mapping.size = rbd_dev->header.image_size; |
657 | rbd_dev->mapping.snap_exists = false; | 657 | rbd_dev->mapping.snap_exists = false; |
658 | rbd_dev->mapping.read_only = rbd_dev->rbd_opts.read_only; | 658 | rbd_dev->mapping.read_only = rbd_dev->rbd_opts.read_only; |
659 | } else { | 659 | } else { |
660 | ret = snap_by_name(&rbd_dev->header, | 660 | ret = snap_by_name(&rbd_dev->header, snap_name, |
661 | rbd_dev->mapping.snap_name, | ||
662 | &rbd_dev->mapping.snap_id, | 661 | &rbd_dev->mapping.snap_id, |
663 | &rbd_dev->mapping.size); | 662 | &rbd_dev->mapping.size); |
664 | if (ret < 0) | 663 | if (ret < 0) |
@@ -666,6 +665,7 @@ static int rbd_header_set_snap(struct rbd_device *rbd_dev) | |||
666 | rbd_dev->mapping.snap_exists = true; | 665 | rbd_dev->mapping.snap_exists = true; |
667 | rbd_dev->mapping.read_only = true; | 666 | rbd_dev->mapping.read_only = true; |
668 | } | 667 | } |
668 | rbd_dev->mapping.snap_name = snap_name; | ||
669 | 669 | ||
670 | ret = 0; | 670 | ret = 0; |
671 | done: | 671 | done: |
@@ -1888,7 +1888,7 @@ static int rbd_init_disk(struct rbd_device *rbd_dev) | |||
1888 | if (rc) | 1888 | if (rc) |
1889 | return rc; | 1889 | return rc; |
1890 | 1890 | ||
1891 | rc = rbd_header_set_snap(rbd_dev); | 1891 | rc = rbd_header_set_snap(rbd_dev, snap_name); |
1892 | if (rc) | 1892 | if (rc) |
1893 | return rc; | 1893 | return rc; |
1894 | 1894 | ||
@@ -2600,7 +2600,6 @@ static ssize_t rbd_add(struct bus_type *bus, | |||
2600 | rc = PTR_ERR(snap_name); | 2600 | rc = PTR_ERR(snap_name); |
2601 | goto err_put_id; | 2601 | goto err_put_id; |
2602 | } | 2602 | } |
2603 | rbd_dev->mapping.snap_name = snap_name; | ||
2604 | 2603 | ||
2605 | rc = rbd_get_client(rbd_dev, mon_addrs, mon_addrs_size - 1, options); | 2604 | rc = rbd_get_client(rbd_dev, mon_addrs, mon_addrs_size - 1, options); |
2606 | if (rc < 0) | 2605 | if (rc < 0) |