diff options
author | Tom Gundersen <teg@jklm.no> | 2014-03-16 13:02:16 +0100 |
---|---|---|
committer | Tom Gundersen <teg@jklm.no> | 2014-03-16 13:05:04 +0100 |
commit | 1f0db3ed88015a0510b8bf4723af2121ee55d9a8 (patch) | |
tree | aabad4190b147ce043793385e71468e61e8e7f6e | |
parent | e09826dcf13a17cd63d900502282c511a06ecbe8 (diff) |
sd-rtnl: never treat broadcasts as replies
Otherwise the sequence number of a broadcast may match the sequence number of a
pending unicast message and cause confusion.
-rw-r--r-- | src/libsystemd/sd-rtnl/rtnl-message.c | 6 | ||||
-rw-r--r-- | src/libsystemd/sd-rtnl/sd-rtnl.c | 3 | ||||
-rw-r--r-- | src/systemd/sd-rtnl.h | 1 |
3 files changed, 10 insertions, 0 deletions
diff --git a/src/libsystemd/sd-rtnl/rtnl-message.c b/src/libsystemd/sd-rtnl/rtnl-message.c index 7ea68f18ae..e243c7b075 100644 --- a/src/libsystemd/sd-rtnl/rtnl-message.c +++ b/src/libsystemd/sd-rtnl/rtnl-message.c @@ -295,6 +295,12 @@ int sd_rtnl_message_get_type(sd_rtnl_message *m, uint16_t *type) { return 0; } +int sd_rtnl_message_is_broadcast(sd_rtnl_message *m) { + assert_return(m, -EINVAL); + + return !m->hdr->nlmsg_pid; +} + int sd_rtnl_message_link_get_ifindex(sd_rtnl_message *m, int *ifindex) { struct ifinfomsg *ifi; diff --git a/src/libsystemd/sd-rtnl/sd-rtnl.c b/src/libsystemd/sd-rtnl/sd-rtnl.c index 1b9f583726..1c2c8902f9 100644 --- a/src/libsystemd/sd-rtnl/sd-rtnl.c +++ b/src/libsystemd/sd-rtnl/sd-rtnl.c @@ -277,6 +277,9 @@ static int process_reply(sd_rtnl *rtnl, sd_rtnl_message *m) { assert(rtnl); assert(m); + if (sd_rtnl_message_is_broadcast(m)) + return 0; + serial = rtnl_message_get_serial(m); c = hashmap_remove(rtnl->reply_callbacks, &serial); if (!c) diff --git a/src/systemd/sd-rtnl.h b/src/systemd/sd-rtnl.h index a171978bcf..0a24873519 100644 --- a/src/systemd/sd-rtnl.h +++ b/src/systemd/sd-rtnl.h @@ -78,6 +78,7 @@ sd_rtnl_message *sd_rtnl_message_unref(sd_rtnl_message *m); int sd_rtnl_message_get_errno(sd_rtnl_message *m); int sd_rtnl_message_get_type(sd_rtnl_message *m, uint16_t *type); +int sd_rtnl_message_is_broadcast(sd_rtnl_message *m); int sd_rtnl_message_addr_set_prefixlen(sd_rtnl_message *m, unsigned char prefixlen); int sd_rtnl_message_addr_set_scope(sd_rtnl_message *m, unsigned char scope); |