diff options
Diffstat (limited to 'drivers/block')
-rw-r--r-- | drivers/block/rbd.c | 85 | ||||
-rw-r--r-- | drivers/block/rbd_types.h | 4 |
2 files changed, 52 insertions, 37 deletions
diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c index a42b28e7f3fa..568fa5b1206b 100644 --- a/drivers/block/rbd.c +++ b/drivers/block/rbd.c | |||
@@ -41,6 +41,15 @@ | |||
41 | 41 | ||
42 | #include "rbd_types.h" | 42 | #include "rbd_types.h" |
43 | 43 | ||
44 | /* | ||
45 | * The basic unit of block I/O is a sector. It is interpreted in a | ||
46 | * number of contexts in Linux (blk, bio, genhd), but the default is | ||
47 | * universally 512 bytes. These symbols are just slightly more | ||
48 | * meaningful than the bare numbers they represent. | ||
49 | */ | ||
50 | #define SECTOR_SHIFT 9 | ||
51 | #define SECTOR_SIZE (1ULL << SECTOR_SHIFT) | ||
52 | |||
44 | #define RBD_DRV_NAME "rbd" | 53 | #define RBD_DRV_NAME "rbd" |
45 | #define RBD_DRV_NAME_LONG "rbd (rados block device)" | 54 | #define RBD_DRV_NAME_LONG "rbd (rados block device)" |
46 | 55 | ||
@@ -221,11 +230,6 @@ static struct device rbd_root_dev = { | |||
221 | }; | 230 | }; |
222 | 231 | ||
223 | 232 | ||
224 | static struct rbd_device *dev_to_rbd(struct device *dev) | ||
225 | { | ||
226 | return container_of(dev, struct rbd_device, dev); | ||
227 | } | ||
228 | |||
229 | static struct device *rbd_get_dev(struct rbd_device *rbd_dev) | 233 | static struct device *rbd_get_dev(struct rbd_device *rbd_dev) |
230 | { | 234 | { |
231 | return get_device(&rbd_dev->dev); | 235 | return get_device(&rbd_dev->dev); |
@@ -743,7 +747,7 @@ static struct bio *bio_chain_clone(struct bio **old, struct bio **next, | |||
743 | 747 | ||
744 | /* split the bio. We'll release it either in the next | 748 | /* split the bio. We'll release it either in the next |
745 | call, or it will have to be released outside */ | 749 | call, or it will have to be released outside */ |
746 | bp = bio_split(old_chain, (len - total) / 512ULL); | 750 | bp = bio_split(old_chain, (len - total) / SECTOR_SIZE); |
747 | if (!bp) | 751 | if (!bp) |
748 | goto err_out; | 752 | goto err_out; |
749 | 753 | ||
@@ -1471,7 +1475,7 @@ static void rbd_rq_fn(struct request_queue *q) | |||
1471 | do_write = (rq_data_dir(rq) == WRITE); | 1475 | do_write = (rq_data_dir(rq) == WRITE); |
1472 | 1476 | ||
1473 | size = blk_rq_bytes(rq); | 1477 | size = blk_rq_bytes(rq); |
1474 | ofs = blk_rq_pos(rq) * 512ULL; | 1478 | ofs = blk_rq_pos(rq) * SECTOR_SIZE; |
1475 | rq_bio = rq->bio; | 1479 | rq_bio = rq->bio; |
1476 | if (do_write && rbd_dev->read_only) { | 1480 | if (do_write && rbd_dev->read_only) { |
1477 | __blk_end_request_all(rq, -EROFS); | 1481 | __blk_end_request_all(rq, -EROFS); |
@@ -1482,7 +1486,7 @@ static void rbd_rq_fn(struct request_queue *q) | |||
1482 | 1486 | ||
1483 | dout("%s 0x%x bytes at 0x%llx\n", | 1487 | dout("%s 0x%x bytes at 0x%llx\n", |
1484 | do_write ? "write" : "read", | 1488 | do_write ? "write" : "read", |
1485 | size, blk_rq_pos(rq) * 512ULL); | 1489 | size, blk_rq_pos(rq) * SECTOR_SIZE); |
1486 | 1490 | ||
1487 | num_segs = rbd_get_num_segments(&rbd_dev->header, ofs, size); | 1491 | num_segs = rbd_get_num_segments(&rbd_dev->header, ofs, size); |
1488 | coll = rbd_alloc_coll(num_segs); | 1492 | coll = rbd_alloc_coll(num_segs); |
@@ -1547,13 +1551,17 @@ static int rbd_merge_bvec(struct request_queue *q, struct bvec_merge_data *bmd, | |||
1547 | struct bio_vec *bvec) | 1551 | struct bio_vec *bvec) |
1548 | { | 1552 | { |
1549 | struct rbd_device *rbd_dev = q->queuedata; | 1553 | struct rbd_device *rbd_dev = q->queuedata; |
1550 | unsigned int chunk_sectors = 1 << (rbd_dev->header.obj_order - 9); | 1554 | unsigned int chunk_sectors; |
1551 | sector_t sector = bmd->bi_sector + get_start_sect(bmd->bi_bdev); | 1555 | sector_t sector; |
1552 | unsigned int bio_sectors = bmd->bi_size >> 9; | 1556 | unsigned int bio_sectors; |
1553 | int max; | 1557 | int max; |
1554 | 1558 | ||
1559 | chunk_sectors = 1 << (rbd_dev->header.obj_order - SECTOR_SHIFT); | ||
1560 | sector = bmd->bi_sector + get_start_sect(bmd->bi_bdev); | ||
1561 | bio_sectors = bmd->bi_size >> SECTOR_SHIFT; | ||
1562 | |||
1555 | max = (chunk_sectors - ((sector & (chunk_sectors - 1)) | 1563 | max = (chunk_sectors - ((sector & (chunk_sectors - 1)) |
1556 | + bio_sectors)) << 9; | 1564 | + bio_sectors)) << SECTOR_SHIFT; |
1557 | if (max < 0) | 1565 | if (max < 0) |
1558 | max = 0; /* bio_add cannot handle a negative return */ | 1566 | max = 0; /* bio_add cannot handle a negative return */ |
1559 | if (max <= bvec->bv_len && bio_sectors == 0) | 1567 | if (max <= bvec->bv_len && bio_sectors == 0) |
@@ -1708,7 +1716,7 @@ static int __rbd_update_snaps(struct rbd_device *rbd_dev) | |||
1708 | return ret; | 1716 | return ret; |
1709 | 1717 | ||
1710 | /* resized? */ | 1718 | /* resized? */ |
1711 | set_capacity(rbd_dev->disk, h.image_size / 512ULL); | 1719 | set_capacity(rbd_dev->disk, h.image_size / SECTOR_SIZE); |
1712 | 1720 | ||
1713 | down_write(&rbd_dev->header.snap_rwsem); | 1721 | down_write(&rbd_dev->header.snap_rwsem); |
1714 | 1722 | ||
@@ -1745,6 +1753,7 @@ static int rbd_init_disk(struct rbd_device *rbd_dev) | |||
1745 | struct gendisk *disk; | 1753 | struct gendisk *disk; |
1746 | struct request_queue *q; | 1754 | struct request_queue *q; |
1747 | int rc; | 1755 | int rc; |
1756 | u64 segment_size; | ||
1748 | u64 total_size = 0; | 1757 | u64 total_size = 0; |
1749 | 1758 | ||
1750 | /* contact OSD, request size info about the object being mapped */ | 1759 | /* contact OSD, request size info about the object being mapped */ |
@@ -1780,11 +1789,15 @@ static int rbd_init_disk(struct rbd_device *rbd_dev) | |||
1780 | if (!q) | 1789 | if (!q) |
1781 | goto out_disk; | 1790 | goto out_disk; |
1782 | 1791 | ||
1792 | /* We use the default size, but let's be explicit about it. */ | ||
1793 | blk_queue_physical_block_size(q, SECTOR_SIZE); | ||
1794 | |||
1783 | /* set io sizes to object size */ | 1795 | /* set io sizes to object size */ |
1784 | blk_queue_max_hw_sectors(q, rbd_obj_bytes(&rbd_dev->header) / 512ULL); | 1796 | segment_size = rbd_obj_bytes(&rbd_dev->header); |
1785 | blk_queue_max_segment_size(q, rbd_obj_bytes(&rbd_dev->header)); | 1797 | blk_queue_max_hw_sectors(q, segment_size / SECTOR_SIZE); |
1786 | blk_queue_io_min(q, rbd_obj_bytes(&rbd_dev->header)); | 1798 | blk_queue_max_segment_size(q, segment_size); |
1787 | blk_queue_io_opt(q, rbd_obj_bytes(&rbd_dev->header)); | 1799 | blk_queue_io_min(q, segment_size); |
1800 | blk_queue_io_opt(q, segment_size); | ||
1788 | 1801 | ||
1789 | blk_queue_merge_bvec(q, rbd_merge_bvec); | 1802 | blk_queue_merge_bvec(q, rbd_merge_bvec); |
1790 | disk->queue = q; | 1803 | disk->queue = q; |
@@ -1795,7 +1808,7 @@ static int rbd_init_disk(struct rbd_device *rbd_dev) | |||
1795 | rbd_dev->q = q; | 1808 | rbd_dev->q = q; |
1796 | 1809 | ||
1797 | /* finally, announce the disk to the world */ | 1810 | /* finally, announce the disk to the world */ |
1798 | set_capacity(disk, total_size / 512ULL); | 1811 | set_capacity(disk, total_size / SECTOR_SIZE); |
1799 | add_disk(disk); | 1812 | add_disk(disk); |
1800 | 1813 | ||
1801 | pr_info("%s: added with size 0x%llx\n", | 1814 | pr_info("%s: added with size 0x%llx\n", |
@@ -1812,10 +1825,15 @@ out: | |||
1812 | sysfs | 1825 | sysfs |
1813 | */ | 1826 | */ |
1814 | 1827 | ||
1828 | static struct rbd_device *dev_to_rbd_dev(struct device *dev) | ||
1829 | { | ||
1830 | return container_of(dev, struct rbd_device, dev); | ||
1831 | } | ||
1832 | |||
1815 | static ssize_t rbd_size_show(struct device *dev, | 1833 | static ssize_t rbd_size_show(struct device *dev, |
1816 | struct device_attribute *attr, char *buf) | 1834 | struct device_attribute *attr, char *buf) |
1817 | { | 1835 | { |
1818 | struct rbd_device *rbd_dev = dev_to_rbd(dev); | 1836 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
1819 | 1837 | ||
1820 | return sprintf(buf, "%llu\n", (unsigned long long)rbd_dev->header.image_size); | 1838 | return sprintf(buf, "%llu\n", (unsigned long long)rbd_dev->header.image_size); |
1821 | } | 1839 | } |
@@ -1823,7 +1841,7 @@ static ssize_t rbd_size_show(struct device *dev, | |||
1823 | static ssize_t rbd_major_show(struct device *dev, | 1841 | static ssize_t rbd_major_show(struct device *dev, |
1824 | struct device_attribute *attr, char *buf) | 1842 | struct device_attribute *attr, char *buf) |
1825 | { | 1843 | { |
1826 | struct rbd_device *rbd_dev = dev_to_rbd(dev); | 1844 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
1827 | 1845 | ||
1828 | return sprintf(buf, "%d\n", rbd_dev->major); | 1846 | return sprintf(buf, "%d\n", rbd_dev->major); |
1829 | } | 1847 | } |
@@ -1831,7 +1849,7 @@ static ssize_t rbd_major_show(struct device *dev, | |||
1831 | static ssize_t rbd_client_id_show(struct device *dev, | 1849 | static ssize_t rbd_client_id_show(struct device *dev, |
1832 | struct device_attribute *attr, char *buf) | 1850 | struct device_attribute *attr, char *buf) |
1833 | { | 1851 | { |
1834 | struct rbd_device *rbd_dev = dev_to_rbd(dev); | 1852 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
1835 | 1853 | ||
1836 | return sprintf(buf, "client%lld\n", | 1854 | return sprintf(buf, "client%lld\n", |
1837 | ceph_client_id(rbd_dev->rbd_client->client)); | 1855 | ceph_client_id(rbd_dev->rbd_client->client)); |
@@ -1840,7 +1858,7 @@ static ssize_t rbd_client_id_show(struct device *dev, | |||
1840 | static ssize_t rbd_pool_show(struct device *dev, | 1858 | static ssize_t rbd_pool_show(struct device *dev, |
1841 | struct device_attribute *attr, char *buf) | 1859 | struct device_attribute *attr, char *buf) |
1842 | { | 1860 | { |
1843 | struct rbd_device *rbd_dev = dev_to_rbd(dev); | 1861 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
1844 | 1862 | ||
1845 | return sprintf(buf, "%s\n", rbd_dev->pool_name); | 1863 | return sprintf(buf, "%s\n", rbd_dev->pool_name); |
1846 | } | 1864 | } |
@@ -1848,7 +1866,7 @@ static ssize_t rbd_pool_show(struct device *dev, | |||
1848 | static ssize_t rbd_name_show(struct device *dev, | 1866 | static ssize_t rbd_name_show(struct device *dev, |
1849 | struct device_attribute *attr, char *buf) | 1867 | struct device_attribute *attr, char *buf) |
1850 | { | 1868 | { |
1851 | struct rbd_device *rbd_dev = dev_to_rbd(dev); | 1869 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
1852 | 1870 | ||
1853 | return sprintf(buf, "%s\n", rbd_dev->obj); | 1871 | return sprintf(buf, "%s\n", rbd_dev->obj); |
1854 | } | 1872 | } |
@@ -1857,7 +1875,7 @@ static ssize_t rbd_snap_show(struct device *dev, | |||
1857 | struct device_attribute *attr, | 1875 | struct device_attribute *attr, |
1858 | char *buf) | 1876 | char *buf) |
1859 | { | 1877 | { |
1860 | struct rbd_device *rbd_dev = dev_to_rbd(dev); | 1878 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
1861 | 1879 | ||
1862 | return sprintf(buf, "%s\n", rbd_dev->snap_name); | 1880 | return sprintf(buf, "%s\n", rbd_dev->snap_name); |
1863 | } | 1881 | } |
@@ -1867,7 +1885,7 @@ static ssize_t rbd_image_refresh(struct device *dev, | |||
1867 | const char *buf, | 1885 | const char *buf, |
1868 | size_t size) | 1886 | size_t size) |
1869 | { | 1887 | { |
1870 | struct rbd_device *rbd_dev = dev_to_rbd(dev); | 1888 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
1871 | int rc; | 1889 | int rc; |
1872 | int ret = size; | 1890 | int ret = size; |
1873 | 1891 | ||
@@ -1932,7 +1950,7 @@ static ssize_t rbd_snap_size_show(struct device *dev, | |||
1932 | { | 1950 | { |
1933 | struct rbd_snap *snap = container_of(dev, struct rbd_snap, dev); | 1951 | struct rbd_snap *snap = container_of(dev, struct rbd_snap, dev); |
1934 | 1952 | ||
1935 | return sprintf(buf, "%lld\n", (long long)snap->size); | 1953 | return sprintf(buf, "%zd\n", snap->size); |
1936 | } | 1954 | } |
1937 | 1955 | ||
1938 | static ssize_t rbd_snap_id_show(struct device *dev, | 1956 | static ssize_t rbd_snap_id_show(struct device *dev, |
@@ -1941,7 +1959,7 @@ static ssize_t rbd_snap_id_show(struct device *dev, | |||
1941 | { | 1959 | { |
1942 | struct rbd_snap *snap = container_of(dev, struct rbd_snap, dev); | 1960 | struct rbd_snap *snap = container_of(dev, struct rbd_snap, dev); |
1943 | 1961 | ||
1944 | return sprintf(buf, "%lld\n", (long long)snap->id); | 1962 | return sprintf(buf, "%llu\n", (unsigned long long) snap->id); |
1945 | } | 1963 | } |
1946 | 1964 | ||
1947 | static DEVICE_ATTR(snap_size, S_IRUGO, rbd_snap_size_show, NULL); | 1965 | static DEVICE_ATTR(snap_size, S_IRUGO, rbd_snap_size_show, NULL); |
@@ -2232,7 +2250,8 @@ static void rbd_id_put(struct rbd_device *rbd_dev) | |||
2232 | /* | 2250 | /* |
2233 | * Skips over white space at *buf, and updates *buf to point to the | 2251 | * Skips over white space at *buf, and updates *buf to point to the |
2234 | * first found non-space character (if any). Returns the length of | 2252 | * first found non-space character (if any). Returns the length of |
2235 | * the token (string of non-white space characters) found. | 2253 | * the token (string of non-white space characters) found. Note |
2254 | * that *buf must be terminated with '\0'. | ||
2236 | */ | 2255 | */ |
2237 | static inline size_t next_token(const char **buf) | 2256 | static inline size_t next_token(const char **buf) |
2238 | { | 2257 | { |
@@ -2250,13 +2269,14 @@ static inline size_t next_token(const char **buf) | |||
2250 | /* | 2269 | /* |
2251 | * Finds the next token in *buf, and if the provided token buffer is | 2270 | * Finds the next token in *buf, and if the provided token buffer is |
2252 | * big enough, copies the found token into it. The result, if | 2271 | * big enough, copies the found token into it. The result, if |
2253 | * copied, is guaranteed to be terminated with '\0'. | 2272 | * copied, is guaranteed to be terminated with '\0'. Note that *buf |
2273 | * must be terminated with '\0' on entry. | ||
2254 | * | 2274 | * |
2255 | * Returns the length of the token found (not including the '\0'). | 2275 | * Returns the length of the token found (not including the '\0'). |
2256 | * Return value will be 0 if no token is found, and it will be >= | 2276 | * Return value will be 0 if no token is found, and it will be >= |
2257 | * token_size if the token would not fit. | 2277 | * token_size if the token would not fit. |
2258 | * | 2278 | * |
2259 | * The *buf pointer will be updated point beyond the end of the | 2279 | * The *buf pointer will be updated to point beyond the end of the |
2260 | * found token. Note that this occurs even if the token buffer is | 2280 | * found token. Note that this occurs even if the token buffer is |
2261 | * too small to hold it. | 2281 | * too small to hold it. |
2262 | */ | 2282 | */ |
@@ -2456,8 +2476,7 @@ static struct rbd_device *__rbd_get_dev(unsigned long id) | |||
2456 | 2476 | ||
2457 | static void rbd_dev_release(struct device *dev) | 2477 | static void rbd_dev_release(struct device *dev) |
2458 | { | 2478 | { |
2459 | struct rbd_device *rbd_dev = | 2479 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
2460 | container_of(dev, struct rbd_device, dev); | ||
2461 | 2480 | ||
2462 | if (rbd_dev->watch_request) { | 2481 | if (rbd_dev->watch_request) { |
2463 | struct ceph_client *client = rbd_dev->rbd_client->client; | 2482 | struct ceph_client *client = rbd_dev->rbd_client->client; |
@@ -2520,7 +2539,7 @@ static ssize_t rbd_snap_add(struct device *dev, | |||
2520 | const char *buf, | 2539 | const char *buf, |
2521 | size_t count) | 2540 | size_t count) |
2522 | { | 2541 | { |
2523 | struct rbd_device *rbd_dev = dev_to_rbd(dev); | 2542 | struct rbd_device *rbd_dev = dev_to_rbd_dev(dev); |
2524 | int ret; | 2543 | int ret; |
2525 | char *name = kmalloc(count + 1, GFP_KERNEL); | 2544 | char *name = kmalloc(count + 1, GFP_KERNEL); |
2526 | if (!name) | 2545 | if (!name) |
diff --git a/drivers/block/rbd_types.h b/drivers/block/rbd_types.h index fc6c678aa2cb..950708688f17 100644 --- a/drivers/block/rbd_types.h +++ b/drivers/block/rbd_types.h | |||
@@ -41,10 +41,6 @@ | |||
41 | #define RBD_HEADER_SIGNATURE "RBD" | 41 | #define RBD_HEADER_SIGNATURE "RBD" |
42 | #define RBD_HEADER_VERSION "001.005" | 42 | #define RBD_HEADER_VERSION "001.005" |
43 | 43 | ||
44 | struct rbd_info { | ||
45 | __le64 max_id; | ||
46 | } __attribute__ ((packed)); | ||
47 | |||
48 | struct rbd_image_snap_ondisk { | 44 | struct rbd_image_snap_ondisk { |
49 | __le64 id; | 45 | __le64 id; |
50 | __le64 image_size; | 46 | __le64 image_size; |