aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPatrick McHardy <kaber@trash.net>2007-06-26 06:23:44 -0400
committerDavid S. Miller <davem@sunset.davemloft.net>2007-07-11 01:15:40 -0400
commit2371baa4bdab3268b32009926f75e7a5d3a41506 (patch)
tree1c9d118ee17261b92da75550ef2a7b453bbe5bc9
parentafdc3238ec948531205f5c5f77d2de7bae519c71 (diff)
[RTNETLINK]: Fix rtnetlink compat attribute patch
Sent the wrong patch previously. Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--include/linux/rtnetlink.h8
-rw-r--r--net/core/rtnetlink.c8
2 files changed, 9 insertions, 7 deletions
diff --git a/include/linux/rtnetlink.h b/include/linux/rtnetlink.h
index 6731e7f4cc0..c91476ce314 100644
--- a/include/linux/rtnetlink.h
+++ b/include/linux/rtnetlink.h
@@ -570,12 +570,16 @@ static __inline__ int rtattr_strcmp(const struct rtattr *rta, const char *str)
570} 570}
571 571
572extern int rtattr_parse(struct rtattr *tb[], int maxattr, struct rtattr *rta, int len); 572extern int rtattr_parse(struct rtattr *tb[], int maxattr, struct rtattr *rta, int len);
573extern int rtattr_parse_nested_compat(struct rtattr *tb[], int maxattr, 573extern int __rtattr_parse_nested_compat(struct rtattr *tb[], int maxattr,
574 struct rtattr *rta, void **data, int len); 574 struct rtattr *rta, int len);
575 575
576#define rtattr_parse_nested(tb, max, rta) \ 576#define rtattr_parse_nested(tb, max, rta) \
577 rtattr_parse((tb), (max), RTA_DATA((rta)), RTA_PAYLOAD((rta))) 577 rtattr_parse((tb), (max), RTA_DATA((rta)), RTA_PAYLOAD((rta)))
578 578
579#define rtattr_parse_nested_compat(tb, max, rta, data, len) \
580({ data = RTA_PAYLOAD(rta) >= len ? RTA_DATA(rta) : NULL; \
581 __rtattr_parse_nested_compat(tb, max, rta, len); })
582
579extern int rtnetlink_send(struct sk_buff *skb, u32 pid, u32 group, int echo); 583extern int rtnetlink_send(struct sk_buff *skb, u32 pid, u32 group, int echo);
580extern int rtnl_unicast(struct sk_buff *skb, u32 pid); 584extern int rtnl_unicast(struct sk_buff *skb, u32 pid);
581extern int rtnl_notify(struct sk_buff *skb, u32 pid, u32 group, 585extern int rtnl_notify(struct sk_buff *skb, u32 pid, u32 group,
diff --git a/net/core/rtnetlink.c b/net/core/rtnetlink.c
index c25d23ba6d5..54c17e4cd28 100644
--- a/net/core/rtnetlink.c
+++ b/net/core/rtnetlink.c
@@ -97,13 +97,11 @@ int rtattr_parse(struct rtattr *tb[], int maxattr, struct rtattr *rta, int len)
97 return 0; 97 return 0;
98} 98}
99 99
100int rtattr_parse_nested_compat(struct rtattr *tb[], int maxattr, 100int __rtattr_parse_nested_compat(struct rtattr *tb[], int maxattr,
101 struct rtattr *rta, void **data, int len) 101 struct rtattr *rta, int len)
102{ 102{
103 if (RTA_PAYLOAD(rta) < len) 103 if (RTA_PAYLOAD(rta) < len)
104 return -1; 104 return -1;
105 *data = RTA_DATA(rta);
106
107 if (RTA_PAYLOAD(rta) >= RTA_ALIGN(len) + sizeof(struct rtattr)) { 105 if (RTA_PAYLOAD(rta) >= RTA_ALIGN(len) + sizeof(struct rtattr)) {
108 rta = RTA_DATA(rta) + RTA_ALIGN(len); 106 rta = RTA_DATA(rta) + RTA_ALIGN(len);
109 return rtattr_parse_nested(tb, maxattr, rta); 107 return rtattr_parse_nested(tb, maxattr, rta);
@@ -1312,7 +1310,7 @@ void __init rtnetlink_init(void)
1312EXPORT_SYMBOL(__rta_fill); 1310EXPORT_SYMBOL(__rta_fill);
1313EXPORT_SYMBOL(rtattr_strlcpy); 1311EXPORT_SYMBOL(rtattr_strlcpy);
1314EXPORT_SYMBOL(rtattr_parse); 1312EXPORT_SYMBOL(rtattr_parse);
1315EXPORT_SYMBOL(rtattr_parse_nested_compat); 1313EXPORT_SYMBOL(__rtattr_parse_nested_compat);
1316EXPORT_SYMBOL(rtnetlink_put_metrics); 1314EXPORT_SYMBOL(rtnetlink_put_metrics);
1317EXPORT_SYMBOL(rtnl_lock); 1315EXPORT_SYMBOL(rtnl_lock);
1318EXPORT_SYMBOL(rtnl_trylock); 1316EXPORT_SYMBOL(rtnl_trylock);