aboutsummaryrefslogtreecommitdiffstats
path: root/net/ceph/osdmap.c
diff options
context:
space:
mode:
authorIlya Dryomov <ilya.dryomov@inktank.com>2014-03-13 10:36:15 -0400
committerSage Weil <sage@inktank.com>2014-04-05 00:07:43 -0400
commit9902e682c7f3df9ed5f60bc6f9c7efa6fd6b2d1d (patch)
tree2f8d6bbb7bd710aca4689662a8877666e1ac5eae /net/ceph/osdmap.c
parent2d88b2e0819e0401ebb195e9fa20fab4be1965c8 (diff)
libceph: fix crush_decode() call site in osdmap_decode()
The size of the memory area feeded to crush_decode() should be limited not only by osdmap end, but also by the crush map length. Also, drop unnecessary dout() (dout() in crush_decode() conveys the same info) and step past crush map only if it is decoded successfully. Signed-off-by: Ilya Dryomov <ilya.dryomov@inktank.com> Reviewed-by: Alex Elder <elder@linaro.org>
Diffstat (limited to 'net/ceph/osdmap.c')
-rw-r--r--net/ceph/osdmap.c7
1 files changed, 2 insertions, 5 deletions
diff --git a/net/ceph/osdmap.c b/net/ceph/osdmap.c
index c39ac624ccc3..d4a6b0df3627 100644
--- a/net/ceph/osdmap.c
+++ b/net/ceph/osdmap.c
@@ -802,16 +802,13 @@ static int osdmap_decode(void **p, void *end, struct ceph_osdmap *map)
802 802
803 /* crush */ 803 /* crush */
804 ceph_decode_32_safe(p, end, len, e_inval); 804 ceph_decode_32_safe(p, end, len, e_inval);
805 dout("osdmap_decode crush len %d from off 0x%x\n", len, 805 map->crush = crush_decode(*p, min(*p + len, end));
806 (int)(*p - start));
807 ceph_decode_need(p, end, len, e_inval);
808 map->crush = crush_decode(*p, end);
809 *p += len;
810 if (IS_ERR(map->crush)) { 806 if (IS_ERR(map->crush)) {
811 err = PTR_ERR(map->crush); 807 err = PTR_ERR(map->crush);
812 map->crush = NULL; 808 map->crush = NULL;
813 goto bad; 809 goto bad;
814 } 810 }
811 *p += len;
815 812
816 /* ignore the rest */ 813 /* ignore the rest */
817 *p = end; 814 *p = end;