Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp2231391ybz; Thu, 30 Apr 2020 13:16:34 -0700 (PDT) X-Google-Smtp-Source: APiQypJdWevR3S9+KoMIYFK8I06lo5VYf5HtxpuI3/teQSsolkEZ1Zn+ZLiwHT/t4e0psxumtEeX X-Received: by 2002:a50:9f23:: with SMTP id b32mr652372edf.183.1588277794726; Thu, 30 Apr 2020 13:16:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588277794; cv=none; d=google.com; s=arc-20160816; b=zjBmf5oCwFIsl2u1dXfKK1NqcwTQ9bDFKYjblsgMGSVPThBF1nYxfW9GGQ43JXaESm xHr3KEFQVFTy/kM6DbBRLmyIY0T/UGS6aVkYjLwPXfsco9Fm+NU+rUek3RncQbifbbTB fEGPdeYKmG0kHxFG1zm5Nlbz1VlY3WOmdUdSki5QUBZg+GEFKpmtLk+4zmmsjZw1tNpX Zq6cj5YemZF7TVzwR9/1rUe+EIW+fCv/tYOvb7eoa7n5wZD+5JlF5dhEze+OuWPs9JUz h4LR6epZKOmKax4/8QcFZSCGuBX0XXNtqSWjQxhlTAaBBUliVZXMoI0W+WToL4bZK3ht zdJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=JSX0p2Ow1OI/xIfoviUi2EDPoYbzznpN4vxAcNr+T50=; b=Ekd4fE2GEh7kGrRDlBz1fNzioNHjgAa311g9LC+jWZzkEIyKjcVIs9QET9uj+ZIGw3 XAYwQL/db/K/sYkIMOr+w8leQWbP/sEQ1uOwP8SowEbiHGU1+vnWbaTGypkaWdIkrhdP 2I01xbU8yNu+WM9VgKoHqflehH8PtHs633ELJu0q3Ty9VxBZ1S6L0uWKsL95PuZJVLtZ ErIrZb2ccdZp3TwI0IAudwLTtVwi4ReuG/DcHaTZ1eNM2T04x1etFVuBqcw942YERVu0 omadpin8uGh6OMDtIYZujRz8hvovpkwdIlY8x0fhd5NX7KTblVbil+aYc6gJcT3hBJOB b9vg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s15si376270edq.231.2020.04.30.13.16.10; Thu, 30 Apr 2020 13:16:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726927AbgD3UNo (ORCPT + 99 others); Thu, 30 Apr 2020 16:13:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58730 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727089AbgD3UNZ (ORCPT ); Thu, 30 Apr 2020 16:13:25 -0400 Received: from sipsolutions.net (s3.sipsolutions.net [IPv6:2a01:4f8:191:4433::2]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D3E9DC08ED7D; Thu, 30 Apr 2020 13:13:24 -0700 (PDT) Received: by sipsolutions.net with esmtpsa (TLS1.3:ECDHE_X25519__RSA_PSS_RSAE_SHA256__AES_256_GCM:256) (Exim 4.93) (envelope-from ) id 1jUFYh-002qzz-57; Thu, 30 Apr 2020 22:13:23 +0200 From: Johannes Berg To: netdev@vger.kernel.org Cc: Antonio Quartulli , linux-wireless@vger.kernel.org, Johannes Berg Subject: [PATCH v2 5/8] netlink: allow NLA_MSECS to have range validation Date: Thu, 30 Apr 2020 22:13:09 +0200 Message-Id: <20200430221106.3c17837abd4c.I46e9164d064042d49227b9af7a686b3a02080ff0@changeid> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200430201312.60143-1-johannes@sipsolutions.net> References: <20200430201312.60143-1-johannes@sipsolutions.net> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org From: Johannes Berg Since NLA_MSECS is really equivalent to NLA_U64, allow it to have range validation as well. Signed-off-by: Johannes Berg --- include/net/netlink.h | 6 ++++-- lib/nlattr.c | 2 ++ 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/include/net/netlink.h b/include/net/netlink.h index 94a7df4ab122..4acd7165e900 100644 --- a/include/net/netlink.h +++ b/include/net/netlink.h @@ -371,7 +371,8 @@ struct nla_policy { #define __NLA_ENSURE(condition) BUILD_BUG_ON_ZERO(!(condition)) #define NLA_ENSURE_UINT_TYPE(tp) \ (__NLA_ENSURE(tp == NLA_U8 || tp == NLA_U16 || \ - tp == NLA_U32 || tp == NLA_U64) + tp) + tp == NLA_U32 || tp == NLA_U64 || \ + tp == NLA_MSECS) + tp) #define NLA_ENSURE_SINT_TYPE(tp) \ (__NLA_ENSURE(tp == NLA_S8 || tp == NLA_S16 || \ tp == NLA_S32 || tp == NLA_S64) + tp) @@ -379,7 +380,8 @@ struct nla_policy { (__NLA_ENSURE(tp == NLA_S8 || tp == NLA_U8 || \ tp == NLA_S16 || tp == NLA_U16 || \ tp == NLA_S32 || tp == NLA_U32 || \ - tp == NLA_S64 || tp == NLA_U64) + tp) + tp == NLA_S64 || tp == NLA_U64 || \ + tp == NLA_MSECS) + tp) #define NLA_ENSURE_NO_VALIDATION_PTR(tp) \ (__NLA_ENSURE(tp != NLA_BITFIELD32 && \ tp != NLA_REJECT && \ diff --git a/lib/nlattr.c b/lib/nlattr.c index a8beb173f558..21ef3998b9d9 100644 --- a/lib/nlattr.c +++ b/lib/nlattr.c @@ -151,6 +151,7 @@ static int nla_validate_int_range_unsigned(const struct nla_policy *pt, value = nla_get_u32(nla); break; case NLA_U64: + case NLA_MSECS: value = nla_get_u64(nla); break; default: @@ -227,6 +228,7 @@ static int nla_validate_int_range(const struct nla_policy *pt, case NLA_U16: case NLA_U32: case NLA_U64: + case NLA_MSECS: return nla_validate_int_range_unsigned(pt, nla, extack); case NLA_S8: case NLA_S16: -- 2.25.1