ipsec: add support of limited SA dump
authorNicolas Dichtel <nicolas.dichtel@6wind.com>
Fri, 14 Feb 2014 14:30:36 +0000 (15:30 +0100)
committerSteffen Klassert <steffen.klassert@secunet.com>
Mon, 17 Feb 2014 06:18:19 +0000 (07:18 +0100)
commitd3623099d3509fa68fa28235366049dd3156c63a
treeff5daaf9b564f3a073a50ed461c7b823b899af7b
parent0f24558e91563888d51e9be5b70981da920c37ac
ipsec: add support of limited SA dump

The goal of this patch is to allow userland to dump only a part of SA by
specifying a filter during the dump.
The kernel is in charge to filter SA, this avoids to generate useless netlink
traffic (it save also some cpu cycles). This is particularly useful when there
is a big number of SA set on the system.

Note that I removed the union in struct xfrm_state_walk to fix a problem on arm.
struct netlink_callback->args is defined as a array of 6 long and the first long
is used in xfrm code to flag the cb as initialized. Hence, we must have:
sizeof(struct xfrm_state_walk) <= sizeof(long) * 5.
With the union, it was false on arm (sizeof(struct xfrm_state_walk) was
sizeof(long) * 7), due to the padding.
In fact, whatever the arch is, this union seems useless, there will be always
padding after it. Removing it will not increase the size of this struct (and
reduce it on arm).

Signed-off-by: Nicolas Dichtel <nicolas.dichtel@6wind.com>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
include/net/xfrm.h
include/uapi/linux/pfkeyv2.h
include/uapi/linux/xfrm.h
net/key/af_key.c
net/xfrm/xfrm_state.c
net/xfrm/xfrm_user.c