Commit 40008e92 authored by Florian Westphal's avatar Florian Westphal Committed by David S. Miller

net: ipv4: remove erroneous advancement of list pointer

Causes crash when lifetime expires on an adress as garbage is
dereferenced soon after.

This used to look like this:

 for (ifap = &ifa->ifa_dev->ifa_list;
      *ifap != NULL; ifap = &(*ifap)->ifa_next) {
          if (*ifap == ifa) ...

but this was changed to:

struct in_ifaddr *tmp;

ifap = &ifa->ifa_dev->ifa_list;
tmp = rtnl_dereference(*ifap);
while (tmp) {
   tmp = rtnl_dereference(tmp->ifa_next); // Bogus
   if (rtnl_dereference(*ifap) == ifa) {
     ...
   ifap = &tmp->ifa_next;		// Can be NULL
   tmp = rtnl_dereference(*ifap);	// Dereference
   }
}

Remove the bogus assigment/list entry skip.

Fixes: 2638eb8b ("net: ipv4: provide __rcu annotation for ifa_list")
Signed-off-by: default avatarFlorian Westphal <fw@strlen.de>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 78fe8a28
...@@ -745,8 +745,7 @@ static void check_lifetime(struct work_struct *work) ...@@ -745,8 +745,7 @@ static void check_lifetime(struct work_struct *work)
ifap = &ifa->ifa_dev->ifa_list; ifap = &ifa->ifa_dev->ifa_list;
tmp = rtnl_dereference(*ifap); tmp = rtnl_dereference(*ifap);
while (tmp) { while (tmp) {
tmp = rtnl_dereference(tmp->ifa_next); if (tmp == ifa) {
if (rtnl_dereference(*ifap) == ifa) {
inet_del_ifa(ifa->ifa_dev, inet_del_ifa(ifa->ifa_dev,
ifap, 1); ifap, 1);
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment