diff options
author | Greg Rose <gregory.v.rose@intel.com> | 2011-06-09 21:27:09 -0400 |
---|---|---|
committer | Jeff Kirsher <jeffrey.t.kirsher@intel.com> | 2011-06-09 23:38:07 -0400 |
commit | c7ac8679bec9397afe8918f788cbcef88c38da54 (patch) | |
tree | c152712de4c997ea79252ef9ac72aaedb8f88c18 /net/bridge/br_netlink.c | |
parent | 929dd047720785f099e12113780b3d7914ce6d9f (diff) |
rtnetlink: Compute and store minimum ifinfo dump size
The message size allocated for rtnl ifinfo dumps was limited to
a single page. This is not enough for additional interface info
available with devices that support SR-IOV and caused a bug in
which VF info would not be displayed if more than approximately
40 VFs were created per interface.
Implement a new function pointer for the rtnl_register service that will
calculate the amount of data required for the ifinfo dump and allocate
enough data to satisfy the request.
Signed-off-by: Greg Rose <gregory.v.rose@intel.com>
Signed-off-by: Jeff Kirsher <jeffrey.t.kirsher@intel.com>
Diffstat (limited to 'net/bridge/br_netlink.c')
-rw-r--r-- | net/bridge/br_netlink.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/net/bridge/br_netlink.c b/net/bridge/br_netlink.c index ffb0dc4cc0e8..6814083a92f4 100644 --- a/net/bridge/br_netlink.c +++ b/net/bridge/br_netlink.c | |||
@@ -218,19 +218,24 @@ int __init br_netlink_init(void) | |||
218 | if (err < 0) | 218 | if (err < 0) |
219 | goto err1; | 219 | goto err1; |
220 | 220 | ||
221 | err = __rtnl_register(PF_BRIDGE, RTM_GETLINK, NULL, br_dump_ifinfo); | 221 | err = __rtnl_register(PF_BRIDGE, RTM_GETLINK, NULL, |
222 | br_dump_ifinfo, NULL); | ||
222 | if (err) | 223 | if (err) |
223 | goto err2; | 224 | goto err2; |
224 | err = __rtnl_register(PF_BRIDGE, RTM_SETLINK, br_rtm_setlink, NULL); | 225 | err = __rtnl_register(PF_BRIDGE, RTM_SETLINK, |
226 | br_rtm_setlink, NULL, NULL); | ||
225 | if (err) | 227 | if (err) |
226 | goto err3; | 228 | goto err3; |
227 | err = __rtnl_register(PF_BRIDGE, RTM_NEWNEIGH, br_fdb_add, NULL); | 229 | err = __rtnl_register(PF_BRIDGE, RTM_NEWNEIGH, |
230 | br_fdb_add, NULL, NULL); | ||
228 | if (err) | 231 | if (err) |
229 | goto err3; | 232 | goto err3; |
230 | err = __rtnl_register(PF_BRIDGE, RTM_DELNEIGH, br_fdb_delete, NULL); | 233 | err = __rtnl_register(PF_BRIDGE, RTM_DELNEIGH, |
234 | br_fdb_delete, NULL, NULL); | ||
231 | if (err) | 235 | if (err) |
232 | goto err3; | 236 | goto err3; |
233 | err = __rtnl_register(PF_BRIDGE, RTM_GETNEIGH, NULL, br_fdb_dump); | 237 | err = __rtnl_register(PF_BRIDGE, RTM_GETNEIGH, |
238 | NULL, br_fdb_dump, NULL); | ||
234 | if (err) | 239 | if (err) |
235 | goto err3; | 240 | goto err3; |
236 | 241 | ||