All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCHv2] Fix range checks in kernfs_get_target_path
@ 2018-07-07  9:41 Bernd Edlinger
  2018-07-07 14:01 ` Greg Kroah-Hartman
  0 siblings, 1 reply; 4+ messages in thread
From: Bernd Edlinger @ 2018-07-07  9:41 UTC (permalink / raw)
  To: Greg Kroah-Hartman, Tejun Heo, linux-kernel@vger.kernel.org

The strncpy causes a warning [-Wstringop-truncation] here,
which indicates that it never appends a NUL byte to the path.
The NUL byte is only there because the buffer is allocated
with kzalloc(PAGE_SIZE, GFP_KERNEL), but since the range-check
is also off-by-one, and PAGE_SIZE==PATH_MAX the returned string
will not be zero-terminated if it is exactly PATH_MAX characters.
Furthermore also the initial loop may theoretically exceed PATH_MAX
and cause a fault.

Signed-off-by: Bernd Edlinger <bernd.edlinger@hotmail.de>
---
  fs/kernfs/symlink.c | 10 +++++++---
  1 file changed, 7 insertions(+), 3 deletions(-)

diff --git a/fs/kernfs/symlink.c b/fs/kernfs/symlink.c
index 08ccabd..c8b7d44a 100644
--- a/fs/kernfs/symlink.c
+++ b/fs/kernfs/symlink.c
@@ -63,7 +63,10 @@ static int kernfs_get_target_path(struct kernfs_node
  		if (base == kn)
  			break;

-		strcpy(s, "../");
+		if ((s - path) + 3 >= PATH_MAX)
+			return -ENAMETOOLONG;
+
+		memcpy(s, "../", 3);
  		s += 3;
  		base = base->parent;
  	}
@@ -79,16 +82,17 @@ static int kernfs_get_target_path(struct kernfs_node
  	if (len < 2)
  		return -EINVAL;
  	len--;
-	if ((s - path) + len > PATH_MAX)
+	if ((s - path) + len >= PATH_MAX)
  		return -ENAMETOOLONG;

  	/* reverse fillup of target string from target to base */
  	kn = target;
+	s[len] = '\0';
  	while (kn->parent && kn != base) {
  		int slen = strlen(kn->name);

  		len -= slen;
-		strncpy(s + len, kn->name, slen);
+		memcpy(s + len, kn->name, slen);
  		if (len)
  			s[--len] = '/';

-- 
1.9.1

^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2018-07-07 14:52 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-07-07  9:41 [PATCHv2] Fix range checks in kernfs_get_target_path Bernd Edlinger
2018-07-07 14:01 ` Greg Kroah-Hartman
2018-07-07 14:34   ` Bernd Edlinger
2018-07-07 14:52     ` Greg Kroah-Hartman

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.