]> git.openfabrics.org - ~emulex/infiniband.git/commit
netlink: advertise incomplete dumps
authorJohannes Berg <johannes.berg@intel.com>
Mon, 20 Jun 2011 11:40:46 +0000 (13:40 +0200)
committerJohn W. Linville <linville@tuxdriver.com>
Wed, 22 Jun 2011 20:09:45 +0000 (16:09 -0400)
commit670dc2833d144375eac36ad74111495a825a9288
tree12d5d3a925da562a6ba0497c47f4b55c71ff545b
parentc1c3daee97498f5d74bfd23531cfe23c8e14a619
netlink: advertise incomplete dumps

Consider the following situation:
 * a dump that would show 8 entries, four in the first
   round, and four in the second
 * between the first and second rounds, 6 entries are
   removed
 * now the second round will not show any entry, and
   even if there is a sequence/generation counter the
   application will not know

To solve this problem, add a new flag NLM_F_DUMP_INTR
to the netlink header that indicates the dump wasn't
consistent, this flag can also be set on the MSG_DONE
message that terminates the dump, and as such above
situation can be detected.

To achieve this, add a sequence counter to the netlink
callback struct. Of course, netlink code still needs
to use this new functionality. The correct way to do
that is to always set cb->seq when a dumpit callback
is invoked and call nl_dump_check_consistent() for
each new message. The core code will also call this
function for the final MSG_DONE message.

To make it usable with generic netlink, a new function
genlmsg_nlhdr() is needed to obtain the netlink header
from the genetlink user header.

Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Acked-by: David S. Miller <davem@davemloft.net>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
include/linux/netlink.h
include/net/genetlink.h
include/net/netlink.h
net/netlink/af_netlink.c