gfs2: Free rd_bits later in gfs2_clear_rgrpd to fix use-after-free
Function gfs2_clear_rgrpd calls kfree(rgd->rd_bits) before calling return_all_reservations, but return_all_reservations still dereferences rgd->rd_bits in __rs_deltree. Fix that by moving the call to kfree below the call to return_all_reservations. Signed-off-by: Bob Peterson <rpeterso@redhat.com> Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
This commit is contained in:
parent
4525c8781e
commit
d0f17d3883
|
@ -719,9 +719,9 @@ void gfs2_clear_rgrpd(struct gfs2_sbd *sdp)
|
||||||
}
|
}
|
||||||
|
|
||||||
gfs2_free_clones(rgd);
|
gfs2_free_clones(rgd);
|
||||||
|
return_all_reservations(rgd);
|
||||||
kfree(rgd->rd_bits);
|
kfree(rgd->rd_bits);
|
||||||
rgd->rd_bits = NULL;
|
rgd->rd_bits = NULL;
|
||||||
return_all_reservations(rgd);
|
|
||||||
kmem_cache_free(gfs2_rgrpd_cachep, rgd);
|
kmem_cache_free(gfs2_rgrpd_cachep, rgd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue