diff options
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/block/rbd.c | 35 |
1 files changed, 15 insertions, 20 deletions
diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c index 815c174661a8..6b1e9a9f2f72 100644 --- a/drivers/block/rbd.c +++ b/drivers/block/rbd.c | |||
@@ -830,44 +830,39 @@ static const char *rbd_snap_name(struct rbd_device *rbd_dev, u64 snap_id) | |||
830 | return NULL; | 830 | return NULL; |
831 | } | 831 | } |
832 | 832 | ||
833 | static int snap_by_name(struct rbd_device *rbd_dev, const char *snap_name) | 833 | static struct rbd_snap *snap_by_name(struct rbd_device *rbd_dev, |
834 | const char *snap_name) | ||
834 | { | 835 | { |
835 | |||
836 | struct rbd_snap *snap; | 836 | struct rbd_snap *snap; |
837 | 837 | ||
838 | list_for_each_entry(snap, &rbd_dev->snaps, node) { | 838 | list_for_each_entry(snap, &rbd_dev->snaps, node) |
839 | if (!strcmp(snap_name, snap->name)) { | 839 | if (!strcmp(snap_name, snap->name)) |
840 | rbd_dev->spec->snap_id = snap->id; | 840 | return snap; |
841 | rbd_dev->mapping.size = snap->size; | ||
842 | rbd_dev->mapping.features = snap->features; | ||
843 | |||
844 | return 0; | ||
845 | } | ||
846 | } | ||
847 | 841 | ||
848 | return -ENOENT; | 842 | return NULL; |
849 | } | 843 | } |
850 | 844 | ||
851 | static int rbd_dev_set_mapping(struct rbd_device *rbd_dev) | 845 | static int rbd_dev_set_mapping(struct rbd_device *rbd_dev) |
852 | { | 846 | { |
853 | int ret; | ||
854 | |||
855 | if (!memcmp(rbd_dev->spec->snap_name, RBD_SNAP_HEAD_NAME, | 847 | if (!memcmp(rbd_dev->spec->snap_name, RBD_SNAP_HEAD_NAME, |
856 | sizeof (RBD_SNAP_HEAD_NAME))) { | 848 | sizeof (RBD_SNAP_HEAD_NAME))) { |
857 | rbd_dev->spec->snap_id = CEPH_NOSNAP; | 849 | rbd_dev->spec->snap_id = CEPH_NOSNAP; |
858 | rbd_dev->mapping.size = rbd_dev->header.image_size; | 850 | rbd_dev->mapping.size = rbd_dev->header.image_size; |
859 | rbd_dev->mapping.features = rbd_dev->header.features; | 851 | rbd_dev->mapping.features = rbd_dev->header.features; |
860 | ret = 0; | ||
861 | } else { | 852 | } else { |
862 | ret = snap_by_name(rbd_dev, rbd_dev->spec->snap_name); | 853 | struct rbd_snap *snap; |
863 | if (ret < 0) | 854 | |
864 | goto done; | 855 | snap = snap_by_name(rbd_dev, rbd_dev->spec->snap_name); |
856 | if (!snap) | ||
857 | return -ENOENT; | ||
858 | rbd_dev->spec->snap_id = snap->id; | ||
859 | rbd_dev->mapping.size = snap->size; | ||
860 | rbd_dev->mapping.features = snap->features; | ||
865 | rbd_dev->mapping.read_only = true; | 861 | rbd_dev->mapping.read_only = true; |
866 | } | 862 | } |
867 | set_bit(RBD_DEV_FLAG_EXISTS, &rbd_dev->flags); | 863 | set_bit(RBD_DEV_FLAG_EXISTS, &rbd_dev->flags); |
868 | 864 | ||
869 | done: | 865 | return 0; |
870 | return ret; | ||
871 | } | 866 | } |
872 | 867 | ||
873 | static void rbd_header_free(struct rbd_image_header *header) | 868 | static void rbd_header_free(struct rbd_image_header *header) |