Commit e5086736 authored by Jakub Kicinski's avatar Jakub Kicinski Committed by David S. Miller

genetlink: reorg struct genl_family

There are holes and oversized members in struct genl_family.

Before: /* size: 104, cachelines: 2, members: 16 */
After:  /* size:  88, cachelines: 2, members: 16 */

The command field in struct genlmsghdr is a u8, so no point
in the operation count being 32 bit. Also operation 0 is
usually undefined, so we only need 255 entries.

netnsok and parallel_ops are only ever initialized to true.

We can grow the fields as needed, compiler should warn us
if someone tries to assign larger constants.
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
Reviewed-by: default avatarJohannes Berg <johannes@sipsolutions.net>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 5a38b4fc
...@@ -48,8 +48,11 @@ struct genl_family { ...@@ -48,8 +48,11 @@ struct genl_family {
char name[GENL_NAMSIZ]; char name[GENL_NAMSIZ];
unsigned int version; unsigned int version;
unsigned int maxattr; unsigned int maxattr;
bool netnsok; unsigned int mcgrp_offset; /* private */
bool parallel_ops; u8 netnsok:1;
u8 parallel_ops:1;
u8 n_ops;
u8 n_mcgrps;
const struct nla_policy *policy; const struct nla_policy *policy;
int (*pre_doit)(const struct genl_ops *ops, int (*pre_doit)(const struct genl_ops *ops,
struct sk_buff *skb, struct sk_buff *skb,
...@@ -59,9 +62,6 @@ struct genl_family { ...@@ -59,9 +62,6 @@ struct genl_family {
struct genl_info *info); struct genl_info *info);
const struct genl_ops * ops; const struct genl_ops * ops;
const struct genl_multicast_group *mcgrps; const struct genl_multicast_group *mcgrps;
unsigned int n_ops;
unsigned int n_mcgrps;
unsigned int mcgrp_offset; /* private */
struct module *module; struct module *module;
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment