summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichal Kubecek <mkubecek@suse.cz>2019-05-02 10:15:10 -0400
committerDavid S. Miller <davem@davemloft.net>2019-05-04 01:27:10 -0400
commit05d7f547bea1872e711ee97bd46aace6cf61c42b (patch)
tree83d6f89440d326c510ca3546a6468590389ae548
parent5eabc27dedd30a738e50a80cdb184b94d2a2ef05 (diff)
genetlink: do not validate dump requests if there is no policy
Unlike do requests, dump genetlink requests now perform strict validation by default even if the genetlink family does not set policy and maxtype because it does validation and parsing on its own (e.g. because it wants to allow different message format for different commands). While the null policy will be ignored, maxtype (which would be zero) is still checked so that any attribute will fail validation. The solution is to only call __nla_validate() from genl_family_rcv_msg() if family->maxtype is set. Fixes: ef6243acb478 ("genetlink: optionally validate strictly/dumps") Signed-off-by: Michal Kubecek <mkubecek@suse.cz> Reviewed-by: Johannes Berg <johannes@sipsolutions.net> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/netlink/genetlink.c24
1 files changed, 14 insertions, 10 deletions
diff --git a/net/netlink/genetlink.c b/net/netlink/genetlink.c
index 79cfa031dc7d..efccd1ac9a66 100644
--- a/net/netlink/genetlink.c
+++ b/net/netlink/genetlink.c
@@ -537,21 +537,25 @@ static int genl_family_rcv_msg(const struct genl_family *family,
537 return -EOPNOTSUPP; 537 return -EOPNOTSUPP;
538 538
539 if (!(ops->validate & GENL_DONT_VALIDATE_DUMP)) { 539 if (!(ops->validate & GENL_DONT_VALIDATE_DUMP)) {
540 unsigned int validate = NL_VALIDATE_STRICT;
541 int hdrlen = GENL_HDRLEN + family->hdrsize; 540 int hdrlen = GENL_HDRLEN + family->hdrsize;
542 541
543 if (ops->validate & GENL_DONT_VALIDATE_DUMP_STRICT)
544 validate = NL_VALIDATE_LIBERAL;
545
546 if (nlh->nlmsg_len < nlmsg_msg_size(hdrlen)) 542 if (nlh->nlmsg_len < nlmsg_msg_size(hdrlen))
547 return -EINVAL; 543 return -EINVAL;
548 544
549 rc = __nla_validate(nlmsg_attrdata(nlh, hdrlen), 545 if (family->maxattr) {
550 nlmsg_attrlen(nlh, hdrlen), 546 unsigned int validate = NL_VALIDATE_STRICT;
551 family->maxattr, family->policy, 547
552 validate, extack); 548 if (ops->validate &
553 if (rc) 549 GENL_DONT_VALIDATE_DUMP_STRICT)
554 return rc; 550 validate = NL_VALIDATE_LIBERAL;
551 rc = __nla_validate(nlmsg_attrdata(nlh, hdrlen),
552 nlmsg_attrlen(nlh, hdrlen),
553 family->maxattr,
554 family->policy,
555 validate, extack);
556 if (rc)
557 return rc;
558 }
555 } 559 }
556 560
557 if (!family->parallel_ops) { 561 if (!family->parallel_ops) {