From: Al Viro Date: Thu, 24 Sep 2020 23:41:58 +0000 (-0400) Subject: ep_create_wakeup_source(): dentry name can change under you... X-Git-Tag: v4.9.239~34 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f2b4a58ad279a232a2f4530dd150d4442ad9475d;p=platform%2Fkernel%2Flinux-amlogic.git ep_create_wakeup_source(): dentry name can change under you... commit 3701cb59d892b88d569427586f01491552f377b1 upstream. or get freed, for that matter, if it's a long (separately stored) name. Signed-off-by: Al Viro Signed-off-by: Greg Kroah-Hartman --- diff --git a/fs/eventpoll.c b/fs/eventpoll.c index 35dafa8..865afb5 100644 --- a/fs/eventpoll.c +++ b/fs/eventpoll.c @@ -1260,7 +1260,7 @@ static int reverse_path_check(void) static int ep_create_wakeup_source(struct epitem *epi) { - const char *name; + struct name_snapshot n; struct wakeup_source *ws; if (!epi->ep->ws) { @@ -1269,8 +1269,9 @@ static int ep_create_wakeup_source(struct epitem *epi) return -ENOMEM; } - name = epi->ffd.file->f_path.dentry->d_name.name; - ws = wakeup_source_register(name); + take_dentry_name_snapshot(&n, epi->ffd.file->f_path.dentry); + ws = wakeup_source_register(n.name); + release_dentry_name_snapshot(&n); if (!ws) return -ENOMEM;