[PATCH 5.6 020/118] neigh: send protocol value in neighbor create notification

From: Greg Kroah-Hartman
Date: Wed May 13 2020 - 06:00:27 EST


From: Roman Mashak <mrv@xxxxxxxxxxxx>

[ Upstream commit 38212bb31fe923d0a2c6299bd2adfbb84cddef2a ]

When a new neighbor entry has been added, event is generated but it does not
include protocol, because its value is assigned after the event notification
routine has run, so move protocol assignment code earlier.

Fixes: df9b0e30d44c ("neighbor: Add protocol attribute")
Cc: David Ahern <dsahern@xxxxxxxxx>
Signed-off-by: Roman Mashak <mrv@xxxxxxxxxxxx>
Reviewed-by: David Ahern <dsahern@xxxxxxxxx>
Signed-off-by: David S. Miller <davem@xxxxxxxxxxxxx>
Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
---
net/core/neighbour.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)

--- a/net/core/neighbour.c
+++ b/net/core/neighbour.c
@@ -1954,6 +1954,9 @@ static int neigh_add(struct sk_buff *skb
NEIGH_UPDATE_F_OVERRIDE_ISROUTER);
}

+ if (protocol)
+ neigh->protocol = protocol;
+
if (ndm->ndm_flags & NTF_EXT_LEARNED)
flags |= NEIGH_UPDATE_F_EXT_LEARNED;

@@ -1967,9 +1970,6 @@ static int neigh_add(struct sk_buff *skb
err = __neigh_update(neigh, lladdr, ndm->ndm_state, flags,
NETLINK_CB(skb).portid, extack);

- if (protocol)
- neigh->protocol = protocol;
-
neigh_release(neigh);

out: