]> git.ipfire.org Git - thirdparty/iproute2.git/commitdiff
dcb: Do not leave ACKs in socket receive buffer
authorIdo Schimmel <idosch@nvidia.com>
Tue, 27 Dec 2022 11:03:18 +0000 (13:03 +0200)
committerStephen Hemminger <stephen@networkplumber.org>
Thu, 29 Dec 2022 16:44:23 +0000 (08:44 -0800)
Originally, the dcb utility only stopped receiving messages from a
socket when it found the attribute it was looking for. Cited commit
changed that, so that the utility will also stop when seeing an ACK
(NLMSG_ERROR message), by setting the NLM_F_ACK flag on requests.

This is problematic because it means a successful request will leave an
ACK in the socket receive buffer, causing the next request to bail
before reading its response.

Fix that by not stopping when finding the required attribute in a
response. Instead, stop on the subsequent ACK.

Fixes: 84c036972659 ("dcb: unblock mnl_socket_recvfrom if not message received")
Signed-off-by: Ido Schimmel <idosch@nvidia.com>
Signed-off-by: Stephen Hemminger <stephen@networkplumber.org>
dcb/dcb.c

index 3ffa91d64d0dfa21fc0d586bd3b96c5554fe9925..9b996abac5298b6c7ec0e532960a6d6409ab82e0 100644 (file)
--- a/dcb/dcb.c
+++ b/dcb/dcb.c
@@ -72,7 +72,7 @@ static int dcb_get_attribute_attr_ieee_cb(const struct nlattr *attr, void *data)
 
        ga->payload = mnl_attr_get_payload(attr);
        ga->payload_len = mnl_attr_get_payload_len(attr);
-       return MNL_CB_STOP;
+       return MNL_CB_OK;
 }
 
 static int dcb_get_attribute_attr_cb(const struct nlattr *attr, void *data)
@@ -126,7 +126,7 @@ static int dcb_set_attribute_attr_cb(const struct nlattr *attr, void *data)
                return MNL_CB_ERROR;
        }
 
-       return MNL_CB_STOP;
+       return MNL_CB_OK;
 }
 
 static int dcb_set_attribute_cb(const struct nlmsghdr *nlh, void *data)