diff options
| -rw-r--r-- | drivers/block/rbd.c | 5 | ||||
| -rw-r--r-- | include/linux/ceph/libceph.h | 4 | ||||
| -rw-r--r-- | net/ceph/pagevec.c | 14 |
3 files changed, 10 insertions, 13 deletions
diff --git a/drivers/block/rbd.c b/drivers/block/rbd.c index c259b4089e95..b0eea3eaee93 100644 --- a/drivers/block/rbd.c +++ b/drivers/block/rbd.c | |||
| @@ -1890,8 +1890,7 @@ static int rbd_obj_method_sync(struct rbd_device *rbd_dev, | |||
| 1890 | if (ret < 0) | 1890 | if (ret < 0) |
| 1891 | goto out; | 1891 | goto out; |
| 1892 | ret = 0; | 1892 | ret = 0; |
| 1893 | (void) ceph_copy_from_page_vector(pages, inbound, 0, | 1893 | ceph_copy_from_page_vector(pages, inbound, 0, obj_request->xferred); |
| 1894 | obj_request->xferred); | ||
| 1895 | if (version) | 1894 | if (version) |
| 1896 | *version = obj_request->version; | 1895 | *version = obj_request->version; |
| 1897 | out: | 1896 | out: |
| @@ -2089,7 +2088,7 @@ static int rbd_obj_read_sync(struct rbd_device *rbd_dev, | |||
| 2089 | 2088 | ||
| 2090 | rbd_assert(obj_request->xferred <= (u64) SIZE_MAX); | 2089 | rbd_assert(obj_request->xferred <= (u64) SIZE_MAX); |
| 2091 | size = (size_t) obj_request->xferred; | 2090 | size = (size_t) obj_request->xferred; |
| 2092 | (void) ceph_copy_from_page_vector(pages, buf, 0, size); | 2091 | ceph_copy_from_page_vector(pages, buf, 0, size); |
| 2093 | rbd_assert(size <= (size_t) INT_MAX); | 2092 | rbd_assert(size <= (size_t) INT_MAX); |
| 2094 | ret = (int) size; | 2093 | ret = (int) size; |
| 2095 | if (version) | 2094 | if (version) |
diff --git a/include/linux/ceph/libceph.h b/include/linux/ceph/libceph.h index 2250f8bb2490..29818fc3fa49 100644 --- a/include/linux/ceph/libceph.h +++ b/include/linux/ceph/libceph.h | |||
| @@ -232,10 +232,10 @@ extern struct page **ceph_alloc_page_vector(int num_pages, gfp_t flags); | |||
| 232 | extern int ceph_copy_user_to_page_vector(struct page **pages, | 232 | extern int ceph_copy_user_to_page_vector(struct page **pages, |
| 233 | const void __user *data, | 233 | const void __user *data, |
| 234 | loff_t off, size_t len); | 234 | loff_t off, size_t len); |
| 235 | extern int ceph_copy_to_page_vector(struct page **pages, | 235 | extern void ceph_copy_to_page_vector(struct page **pages, |
| 236 | const void *data, | 236 | const void *data, |
| 237 | loff_t off, size_t len); | 237 | loff_t off, size_t len); |
| 238 | extern int ceph_copy_from_page_vector(struct page **pages, | 238 | extern void ceph_copy_from_page_vector(struct page **pages, |
| 239 | void *data, | 239 | void *data, |
| 240 | loff_t off, size_t len); | 240 | loff_t off, size_t len); |
| 241 | extern int ceph_copy_page_vector_to_user(struct page **pages, void __user *data, | 241 | extern int ceph_copy_page_vector_to_user(struct page **pages, void __user *data, |
diff --git a/net/ceph/pagevec.c b/net/ceph/pagevec.c index 5b20be979c19..815a2249cfa9 100644 --- a/net/ceph/pagevec.c +++ b/net/ceph/pagevec.c | |||
| @@ -118,17 +118,17 @@ int ceph_copy_user_to_page_vector(struct page **pages, | |||
| 118 | } | 118 | } |
| 119 | EXPORT_SYMBOL(ceph_copy_user_to_page_vector); | 119 | EXPORT_SYMBOL(ceph_copy_user_to_page_vector); |
| 120 | 120 | ||
| 121 | int ceph_copy_to_page_vector(struct page **pages, | 121 | void ceph_copy_to_page_vector(struct page **pages, |
| 122 | const void *data, | 122 | const void *data, |
| 123 | loff_t off, size_t len) | 123 | loff_t off, size_t len) |
| 124 | { | 124 | { |
| 125 | int i = 0; | 125 | int i = 0; |
| 126 | size_t po = off & ~PAGE_CACHE_MASK; | 126 | size_t po = off & ~PAGE_CACHE_MASK; |
| 127 | size_t left = len; | 127 | size_t left = len; |
| 128 | size_t l; | ||
| 129 | 128 | ||
| 130 | while (left > 0) { | 129 | while (left > 0) { |
| 131 | l = min_t(size_t, PAGE_CACHE_SIZE-po, left); | 130 | size_t l = min_t(size_t, PAGE_CACHE_SIZE-po, left); |
| 131 | |||
| 132 | memcpy(page_address(pages[i]) + po, data, l); | 132 | memcpy(page_address(pages[i]) + po, data, l); |
| 133 | data += l; | 133 | data += l; |
| 134 | left -= l; | 134 | left -= l; |
| @@ -138,21 +138,20 @@ int ceph_copy_to_page_vector(struct page **pages, | |||
| 138 | i++; | 138 | i++; |
| 139 | } | 139 | } |
| 140 | } | 140 | } |
| 141 | return len; | ||
| 142 | } | 141 | } |
| 143 | EXPORT_SYMBOL(ceph_copy_to_page_vector); | 142 | EXPORT_SYMBOL(ceph_copy_to_page_vector); |
| 144 | 143 | ||
| 145 | int ceph_copy_from_page_vector(struct page **pages, | 144 | void ceph_copy_from_page_vector(struct page **pages, |
| 146 | void *data, | 145 | void *data, |
| 147 | loff_t off, size_t len) | 146 | loff_t off, size_t len) |
| 148 | { | 147 | { |
| 149 | int i = 0; | 148 | int i = 0; |
| 150 | size_t po = off & ~PAGE_CACHE_MASK; | 149 | size_t po = off & ~PAGE_CACHE_MASK; |
| 151 | size_t left = len; | 150 | size_t left = len; |
| 152 | size_t l; | ||
| 153 | 151 | ||
| 154 | while (left > 0) { | 152 | while (left > 0) { |
| 155 | l = min_t(size_t, PAGE_CACHE_SIZE-po, left); | 153 | size_t l = min_t(size_t, PAGE_CACHE_SIZE-po, left); |
| 154 | |||
| 156 | memcpy(data, page_address(pages[i]) + po, l); | 155 | memcpy(data, page_address(pages[i]) + po, l); |
| 157 | data += l; | 156 | data += l; |
| 158 | left -= l; | 157 | left -= l; |
| @@ -162,7 +161,6 @@ int ceph_copy_from_page_vector(struct page **pages, | |||
| 162 | i++; | 161 | i++; |
| 163 | } | 162 | } |
| 164 | } | 163 | } |
| 165 | return len; | ||
| 166 | } | 164 | } |
| 167 | EXPORT_SYMBOL(ceph_copy_from_page_vector); | 165 | EXPORT_SYMBOL(ceph_copy_from_page_vector); |
| 168 | 166 | ||
