mirror of https://gitee.com/openkylin/linux.git
mnt: Fix a memory stomp in umount
While reviewing the code of umount_tree I realized that when we append to a preexisting unmounted list we do not change pprev of the former first item in the list. Which means later in namespace_unlock hlist_del_init(&mnt->mnt_hash) on the former first item of the list will stomp unmounted.first leaving it set to some random mount point which we are likely to free soon. This isn't likely to hit, but if it does I don't know how anyone could track it down. [ This happened because we don't have all the same operations for hlist's as we do for normal doubly-linked lists. In particular, list_splice() is easy on our standard doubly-linked lists, while hlist_splice() doesn't exist and needs both start/end entries of the hlist. And commit38129a13e6
incorrectly open-coded that missing hlist_splice(). We should think about making these kinds of "mindless" conversions easier to get right by adding the missing hlist helpers - Linus ] Fixes:38129a13e6
switch mnt_hash to hlist Cc: stable@vger.kernel.org Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
44e8967d59
commit
c297abfdf1
|
@ -1370,6 +1370,8 @@ void umount_tree(struct mount *mnt, int how)
|
|||
}
|
||||
if (last) {
|
||||
last->mnt_hash.next = unmounted.first;
|
||||
if (unmounted.first)
|
||||
unmounted.first->pprev = &last->mnt_hash.next;
|
||||
unmounted.first = tmp_list.first;
|
||||
unmounted.first->pprev = &unmounted.first;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue