diff options
author | Herbert Xu <herbert@gondor.apana.org.au> | 2015-03-21 14:14:03 +1100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-03-21 00:16:39 -0400 |
commit | 8f2ddaac302a8ca364cb04efb19cd3b5cd058910 (patch) | |
tree | 162dcee7acf5194f04e0cd3ce444f7520f87553a | |
parent | 69a3b16ff66201cb24a772a6e3009044ec582b12 (diff) | |
download | op-kernel-dev-8f2ddaac302a8ca364cb04efb19cd3b5cd058910.zip op-kernel-dev-8f2ddaac302a8ca364cb04efb19cd3b5cd058910.tar.gz |
netlink: Remove netlink_compare_arg.trailer
Instead of computing the offset from trailer, this patch computes
netlink_compare_arg_len from the offset of portid and then adds 4
to it. This allows trailer to be removed.
Reported-by: David Miller <davem@davemloft.net>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/netlink/af_netlink.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/net/netlink/af_netlink.c b/net/netlink/af_netlink.c index 72c6b55..6517921 100644 --- a/net/netlink/af_netlink.c +++ b/net/netlink/af_netlink.c @@ -974,10 +974,11 @@ struct netlink_compare_arg { possible_net_t pnet; u32 portid; - char trailer[]; }; -#define netlink_compare_arg_len offsetof(struct netlink_compare_arg, trailer) +/* Doing sizeof directly may yield 4 extra bytes on 64-bit. */ +#define netlink_compare_arg_len \ + (offsetof(struct netlink_compare_arg, portid) + sizeof(u32)) static inline int netlink_compare(struct rhashtable_compare_arg *arg, const void *ptr) |