Commit bc3ed28c authored by Thomas Graf's avatar Thomas Graf Committed by David S. Miller

netlink: Improve returned error codes

Make nlmsg_trim(), nlmsg_cancel(), genlmsg_cancel(), and
nla_nest_cancel() void functions.

Return -EMSGSIZE instead of -1 if the provided message buffer is not
big enough.
Signed-off-by: default avatarThomas Graf <tgraf@suug.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 1f9d11c7
...@@ -162,9 +162,9 @@ static inline int genlmsg_end(struct sk_buff *skb, void *hdr) ...@@ -162,9 +162,9 @@ static inline int genlmsg_end(struct sk_buff *skb, void *hdr)
* @skb: socket buffer the message is stored in * @skb: socket buffer the message is stored in
* @hdr: generic netlink message header * @hdr: generic netlink message header
*/ */
static inline int genlmsg_cancel(struct sk_buff *skb, void *hdr) static inline void genlmsg_cancel(struct sk_buff *skb, void *hdr)
{ {
return nlmsg_cancel(skb, hdr - GENL_HDRLEN - NLMSG_HDRLEN); nlmsg_cancel(skb, hdr - GENL_HDRLEN - NLMSG_HDRLEN);
} }
/** /**
......
...@@ -556,14 +556,12 @@ static inline void *nlmsg_get_pos(struct sk_buff *skb) ...@@ -556,14 +556,12 @@ static inline void *nlmsg_get_pos(struct sk_buff *skb)
* @skb: socket buffer the message is stored in * @skb: socket buffer the message is stored in
* @mark: mark to trim to * @mark: mark to trim to
* *
* Trims the message to the provided mark. Returns -1. * Trims the message to the provided mark.
*/ */
static inline int nlmsg_trim(struct sk_buff *skb, const void *mark) static inline void nlmsg_trim(struct sk_buff *skb, const void *mark)
{ {
if (mark) if (mark)
skb_trim(skb, (unsigned char *) mark - skb->data); skb_trim(skb, (unsigned char *) mark - skb->data);
return -1;
} }
/** /**
...@@ -572,11 +570,11 @@ static inline int nlmsg_trim(struct sk_buff *skb, const void *mark) ...@@ -572,11 +570,11 @@ static inline int nlmsg_trim(struct sk_buff *skb, const void *mark)
* @nlh: netlink message header * @nlh: netlink message header
* *
* Removes the complete netlink message including all * Removes the complete netlink message including all
* attributes from the socket buffer again. Returns -1. * attributes from the socket buffer again.
*/ */
static inline int nlmsg_cancel(struct sk_buff *skb, struct nlmsghdr *nlh) static inline void nlmsg_cancel(struct sk_buff *skb, struct nlmsghdr *nlh)
{ {
return nlmsg_trim(skb, nlh); nlmsg_trim(skb, nlh);
} }
/** /**
...@@ -775,7 +773,7 @@ static inline int __nla_parse_nested_compat(struct nlattr *tb[], int maxtype, ...@@ -775,7 +773,7 @@ static inline int __nla_parse_nested_compat(struct nlattr *tb[], int maxtype,
int nested_len = nla_len(nla) - NLA_ALIGN(len); int nested_len = nla_len(nla) - NLA_ALIGN(len);
if (nested_len < 0) if (nested_len < 0)
return -1; return -EINVAL;
if (nested_len >= nla_attr_size(0)) if (nested_len >= nla_attr_size(0))
return nla_parse(tb, maxtype, nla_data(nla) + NLA_ALIGN(len), return nla_parse(tb, maxtype, nla_data(nla) + NLA_ALIGN(len),
nested_len, policy); nested_len, policy);
...@@ -1080,11 +1078,11 @@ static inline int nla_nest_compat_end(struct sk_buff *skb, struct nlattr *start) ...@@ -1080,11 +1078,11 @@ static inline int nla_nest_compat_end(struct sk_buff *skb, struct nlattr *start)
* @start: container attribute * @start: container attribute
* *
* Removes the container attribute and including all nested * Removes the container attribute and including all nested
* attributes. Returns -1. * attributes. Returns -EMSGSIZE
*/ */
static inline int nla_nest_cancel(struct sk_buff *skb, struct nlattr *start) static inline void nla_nest_cancel(struct sk_buff *skb, struct nlattr *start)
{ {
return nlmsg_trim(skb, start); nlmsg_trim(skb, start);
} }
/** /**
......
...@@ -1714,7 +1714,8 @@ static int neightbl_fill_parms(struct sk_buff *skb, struct neigh_parms *parms) ...@@ -1714,7 +1714,8 @@ static int neightbl_fill_parms(struct sk_buff *skb, struct neigh_parms *parms)
return nla_nest_end(skb, nest); return nla_nest_end(skb, nest);
nla_put_failure: nla_put_failure:
return nla_nest_cancel(skb, nest); nla_nest_cancel(skb, nest);
return -EMSGSIZE;
} }
static int neightbl_fill_info(struct sk_buff *skb, struct neigh_table *tbl, static int neightbl_fill_info(struct sk_buff *skb, struct neigh_table *tbl,
......
...@@ -498,7 +498,8 @@ int rtnetlink_put_metrics(struct sk_buff *skb, u32 *metrics) ...@@ -498,7 +498,8 @@ int rtnetlink_put_metrics(struct sk_buff *skb, u32 *metrics)
return nla_nest_end(skb, mx); return nla_nest_end(skb, mx);
nla_put_failure: nla_put_failure:
return nla_nest_cancel(skb, mx); nla_nest_cancel(skb, mx);
return -EMSGSIZE;
} }
int rtnl_put_cacheinfo(struct sk_buff *skb, struct dst_entry *dst, u32 id, int rtnl_put_cacheinfo(struct sk_buff *skb, struct dst_entry *dst, u32 id,
......
...@@ -400,13 +400,13 @@ void __nla_put_nohdr(struct sk_buff *skb, int attrlen, const void *data) ...@@ -400,13 +400,13 @@ void __nla_put_nohdr(struct sk_buff *skb, int attrlen, const void *data)
* @attrlen: length of attribute payload * @attrlen: length of attribute payload
* @data: head of attribute payload * @data: head of attribute payload
* *
* Returns -1 if the tailroom of the skb is insufficient to store * Returns -EMSGSIZE if the tailroom of the skb is insufficient to store
* the attribute header and payload. * the attribute header and payload.
*/ */
int nla_put(struct sk_buff *skb, int attrtype, int attrlen, const void *data) int nla_put(struct sk_buff *skb, int attrtype, int attrlen, const void *data)
{ {
if (unlikely(skb_tailroom(skb) < nla_total_size(attrlen))) if (unlikely(skb_tailroom(skb) < nla_total_size(attrlen)))
return -1; return -EMSGSIZE;
__nla_put(skb, attrtype, attrlen, data); __nla_put(skb, attrtype, attrlen, data);
return 0; return 0;
...@@ -418,13 +418,13 @@ int nla_put(struct sk_buff *skb, int attrtype, int attrlen, const void *data) ...@@ -418,13 +418,13 @@ int nla_put(struct sk_buff *skb, int attrtype, int attrlen, const void *data)
* @attrlen: length of attribute payload * @attrlen: length of attribute payload
* @data: head of attribute payload * @data: head of attribute payload
* *
* Returns -1 if the tailroom of the skb is insufficient to store * Returns -EMSGSIZE if the tailroom of the skb is insufficient to store
* the attribute payload. * the attribute payload.
*/ */
int nla_put_nohdr(struct sk_buff *skb, int attrlen, const void *data) int nla_put_nohdr(struct sk_buff *skb, int attrlen, const void *data)
{ {
if (unlikely(skb_tailroom(skb) < NLA_ALIGN(attrlen))) if (unlikely(skb_tailroom(skb) < NLA_ALIGN(attrlen)))
return -1; return -EMSGSIZE;
__nla_put_nohdr(skb, attrlen, data); __nla_put_nohdr(skb, attrlen, data);
return 0; return 0;
...@@ -436,13 +436,13 @@ int nla_put_nohdr(struct sk_buff *skb, int attrlen, const void *data) ...@@ -436,13 +436,13 @@ int nla_put_nohdr(struct sk_buff *skb, int attrlen, const void *data)
* @attrlen: length of attribute payload * @attrlen: length of attribute payload
* @data: head of attribute payload * @data: head of attribute payload
* *
* Returns -1 if the tailroom of the skb is insufficient to store * Returns -EMSGSIZE if the tailroom of the skb is insufficient to store
* the attribute payload. * the attribute payload.
*/ */
int nla_append(struct sk_buff *skb, int attrlen, const void *data) int nla_append(struct sk_buff *skb, int attrlen, const void *data)
{ {
if (unlikely(skb_tailroom(skb) < NLA_ALIGN(attrlen))) if (unlikely(skb_tailroom(skb) < NLA_ALIGN(attrlen)))
return -1; return -EMSGSIZE;
memcpy(skb_put(skb, attrlen), data, attrlen); memcpy(skb_put(skb, attrlen), data, attrlen);
return 0; return 0;
......
...@@ -554,7 +554,8 @@ static int ctrl_fill_info(struct genl_family *family, u32 pid, u32 seq, ...@@ -554,7 +554,8 @@ static int ctrl_fill_info(struct genl_family *family, u32 pid, u32 seq,
return genlmsg_end(skb, hdr); return genlmsg_end(skb, hdr);
nla_put_failure: nla_put_failure:
return genlmsg_cancel(skb, hdr); genlmsg_cancel(skb, hdr);
return -EMSGSIZE;
} }
static int ctrl_fill_mcgrp_info(struct genl_multicast_group *grp, u32 pid, static int ctrl_fill_mcgrp_info(struct genl_multicast_group *grp, u32 pid,
...@@ -590,7 +591,8 @@ static int ctrl_fill_mcgrp_info(struct genl_multicast_group *grp, u32 pid, ...@@ -590,7 +591,8 @@ static int ctrl_fill_mcgrp_info(struct genl_multicast_group *grp, u32 pid,
return genlmsg_end(skb, hdr); return genlmsg_end(skb, hdr);
nla_put_failure: nla_put_failure:
return genlmsg_cancel(skb, hdr); genlmsg_cancel(skb, hdr);
return -EMSGSIZE;
} }
static int ctrl_dumpfamily(struct sk_buff *skb, struct netlink_callback *cb) static int ctrl_dumpfamily(struct sk_buff *skb, struct netlink_callback *cb)
......
...@@ -444,7 +444,8 @@ static int dsmark_dump_class(struct Qdisc *sch, unsigned long cl, ...@@ -444,7 +444,8 @@ static int dsmark_dump_class(struct Qdisc *sch, unsigned long cl,
return nla_nest_end(skb, opts); return nla_nest_end(skb, opts);
nla_put_failure: nla_put_failure:
return nla_nest_cancel(skb, opts); nla_nest_cancel(skb, opts);
return -EMSGSIZE;
} }
static int dsmark_dump(struct Qdisc *sch, struct sk_buff *skb) static int dsmark_dump(struct Qdisc *sch, struct sk_buff *skb)
...@@ -466,7 +467,8 @@ static int dsmark_dump(struct Qdisc *sch, struct sk_buff *skb) ...@@ -466,7 +467,8 @@ static int dsmark_dump(struct Qdisc *sch, struct sk_buff *skb)
return nla_nest_end(skb, opts); return nla_nest_end(skb, opts);
nla_put_failure: nla_put_failure:
return nla_nest_cancel(skb, opts); nla_nest_cancel(skb, opts);
return -EMSGSIZE;
} }
static const struct Qdisc_class_ops dsmark_class_ops = { static const struct Qdisc_class_ops dsmark_class_ops = {
......
...@@ -582,7 +582,8 @@ append_opt: ...@@ -582,7 +582,8 @@ append_opt:
return nla_nest_end(skb, opts); return nla_nest_end(skb, opts);
nla_put_failure: nla_put_failure:
return nla_nest_cancel(skb, opts); nla_nest_cancel(skb, opts);
return -EMSGSIZE;
} }
static void gred_destroy(struct Qdisc *sch) static void gred_destroy(struct Qdisc *sch)
......
...@@ -1360,7 +1360,7 @@ hfsc_dump_class(struct Qdisc *sch, unsigned long arg, struct sk_buff *skb, ...@@ -1360,7 +1360,7 @@ hfsc_dump_class(struct Qdisc *sch, unsigned long arg, struct sk_buff *skb,
nla_put_failure: nla_put_failure:
nla_nest_cancel(skb, nest); nla_nest_cancel(skb, nest);
return -1; return -EMSGSIZE;
} }
static int static int
......
...@@ -281,7 +281,8 @@ static int red_dump(struct Qdisc *sch, struct sk_buff *skb) ...@@ -281,7 +281,8 @@ static int red_dump(struct Qdisc *sch, struct sk_buff *skb)
return nla_nest_end(skb, opts); return nla_nest_end(skb, opts);
nla_put_failure: nla_put_failure:
return nla_nest_cancel(skb, opts); nla_nest_cancel(skb, opts);
return -EMSGSIZE;
} }
static int red_dump_stats(struct Qdisc *sch, struct gnet_dump *d) static int red_dump_stats(struct Qdisc *sch, struct gnet_dump *d)
......
...@@ -187,7 +187,8 @@ static int nl80211_send_wiphy(struct sk_buff *msg, u32 pid, u32 seq, int flags, ...@@ -187,7 +187,8 @@ static int nl80211_send_wiphy(struct sk_buff *msg, u32 pid, u32 seq, int flags,
return genlmsg_end(msg, hdr); return genlmsg_end(msg, hdr);
nla_put_failure: nla_put_failure:
return genlmsg_cancel(msg, hdr); genlmsg_cancel(msg, hdr);
return -EMSGSIZE;
} }
static int nl80211_dump_wiphy(struct sk_buff *skb, struct netlink_callback *cb) static int nl80211_dump_wiphy(struct sk_buff *skb, struct netlink_callback *cb)
...@@ -273,7 +274,8 @@ static int nl80211_send_iface(struct sk_buff *msg, u32 pid, u32 seq, int flags, ...@@ -273,7 +274,8 @@ static int nl80211_send_iface(struct sk_buff *msg, u32 pid, u32 seq, int flags,
return genlmsg_end(msg, hdr); return genlmsg_end(msg, hdr);
nla_put_failure: nla_put_failure:
return genlmsg_cancel(msg, hdr); genlmsg_cancel(msg, hdr);
return -EMSGSIZE;
} }
static int nl80211_dump_interface(struct sk_buff *skb, struct netlink_callback *cb) static int nl80211_dump_interface(struct sk_buff *skb, struct netlink_callback *cb)
...@@ -928,7 +930,8 @@ static int nl80211_send_station(struct sk_buff *msg, u32 pid, u32 seq, ...@@ -928,7 +930,8 @@ static int nl80211_send_station(struct sk_buff *msg, u32 pid, u32 seq,
return genlmsg_end(msg, hdr); return genlmsg_end(msg, hdr);
nla_put_failure: nla_put_failure:
return genlmsg_cancel(msg, hdr); genlmsg_cancel(msg, hdr);
return -EMSGSIZE;
} }
static int nl80211_dump_station(struct sk_buff *skb, static int nl80211_dump_station(struct sk_buff *skb,
...@@ -1267,7 +1270,8 @@ static int nl80211_send_mpath(struct sk_buff *msg, u32 pid, u32 seq, ...@@ -1267,7 +1270,8 @@ static int nl80211_send_mpath(struct sk_buff *msg, u32 pid, u32 seq,
return genlmsg_end(msg, hdr); return genlmsg_end(msg, hdr);
nla_put_failure: nla_put_failure:
return genlmsg_cancel(msg, hdr); genlmsg_cancel(msg, hdr);
return -EMSGSIZE;
} }
static int nl80211_dump_mpath(struct sk_buff *skb, static int nl80211_dump_mpath(struct sk_buff *skb,
......
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