diff mbox series

net: fix nla_strcmp to handle more then one trailing null character

Message ID 20210505165831.875497-1-zenczykowski@gmail.com (mailing list archive)
State Accepted
Commit 2c16db6c92b0ee4aa61e88366df82169e83c3f7e
Delegated to: Netdev Maintainers
Headers show
Series net: fix nla_strcmp to handle more then one trailing null character | expand

Checks

Context Check Description
netdev/tree_selection success Not a local patch

Commit Message

Maciej Żenczykowski May 5, 2021, 4:58 p.m. UTC
From: Maciej Żenczykowski <maze@google.com>

Android userspace has been using TCA_KIND with a char[IFNAMESIZ]
many-null-terminated buffer containing the string 'bpf'.

This works on 4.19 and ceases to work on 5.10.

I'm not entirely sure what fixes tag to use, but I think the issue
was likely introduced in the below mentioned 5.4 commit.

Reported-by: Nucca Chen <nuccachen@google.com>
Cc: Cong Wang <xiyou.wangcong@gmail.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: David S. Miller <davem@davemloft.net>
Cc: Jakub Kicinski <jakub.kicinski@netronome.com>
Cc: Jamal Hadi Salim <jhs@mojatatu.com>
Cc: Jiri Pirko <jiri@mellanox.com>
Cc: Jiri Pirko <jiri@resnulli.us>
Fixes: 62794fc4fbf5 ("net_sched: add max len check for TCA_KIND")
Change-Id: I66dc281f165a2858fc29a44869a270a2d698a82b
---
 lib/nlattr.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

patchwork-bot+netdevbpf@kernel.org May 5, 2021, 7:50 p.m. UTC | #1
Hello:

This patch was applied to netdev/net.git (refs/heads/master):

On Wed,  5 May 2021 09:58:31 -0700 you wrote:
> From: Maciej Żenczykowski <maze@google.com>
> 
> Android userspace has been using TCA_KIND with a char[IFNAMESIZ]
> many-null-terminated buffer containing the string 'bpf'.
> 
> This works on 4.19 and ceases to work on 5.10.
> 
> [...]

Here is the summary with links:
  - net: fix nla_strcmp to handle more then one trailing null character
    https://git.kernel.org/netdev/net/c/2c16db6c92b0

You are awesome, thank you!
--
Deet-doot-dot, I am a bot.
https://korg.docs.kernel.org/patchwork/pwbot.html
diff mbox series

Patch

diff --git a/lib/nlattr.c b/lib/nlattr.c
index 5b6116e81f9f..1d051ef66afe 100644
--- a/lib/nlattr.c
+++ b/lib/nlattr.c
@@ -828,7 +828,7 @@  int nla_strcmp(const struct nlattr *nla, const char *str)
 	int attrlen = nla_len(nla);
 	int d;
 
-	if (attrlen > 0 && buf[attrlen - 1] == '\0')
+	while (attrlen > 0 && buf[attrlen - 1] == '\0')
 		attrlen--;
 
 	d = attrlen - len;