mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
crush: fix a bug in tree bucket decode
commit 82cd003a77173c91b9acad8033fb7931dac8d751 upstream. struct crush_bucket_tree::num_nodes is u8, so ceph_decode_8_safe() should be used. -Wconversion catches this, but I guess it went unnoticed in all the noise it spews. The actual problem (at least for common crushmaps) isn't the u32 -> u8 truncation though - it's the advancement by 4 bytes instead of 1 in the crushmap buffer. Fixes: http://tracker.ceph.com/issues/2759 Signed-off-by: Ilya Dryomov <idryomov@gmail.com> Reviewed-by: Josh Durgin <jdurgin@redhat.com> Signed-off-by: Zefan Li <lizefan@huawei.com>
This commit is contained in:
parent
d6a9245c60
commit
8458a84420
1 changed files with 1 additions and 1 deletions
|
@ -102,7 +102,7 @@ static int crush_decode_tree_bucket(void **p, void *end,
|
||||||
{
|
{
|
||||||
int j;
|
int j;
|
||||||
dout("crush_decode_tree_bucket %p to %p\n", *p, end);
|
dout("crush_decode_tree_bucket %p to %p\n", *p, end);
|
||||||
ceph_decode_32_safe(p, end, b->num_nodes, bad);
|
ceph_decode_8_safe(p, end, b->num_nodes, bad);
|
||||||
b->node_weights = kcalloc(b->num_nodes, sizeof(u32), GFP_NOFS);
|
b->node_weights = kcalloc(b->num_nodes, sizeof(u32), GFP_NOFS);
|
||||||
if (b->node_weights == NULL)
|
if (b->node_weights == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
Loading…
Reference in a new issue