]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
macsec: replace custom checks for IFLA_MACSEC_* flags with NLA_POLICY_MAX
authorSabrina Dubroca <sd@queasysnail.net>
Tue, 26 Aug 2025 13:16:30 +0000 (15:16 +0200)
committerJakub Kicinski <kuba@kernel.org>
Thu, 28 Aug 2025 01:34:53 +0000 (18:34 -0700)
Those are all off/on flags.

Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
Reviewed-by: Simon Horman <horms@kernel.org>
Link: https://patch.msgid.link/95707fb36adc1904fa327bc8f4eb055895aa6eff.1756202772.git.sd@queasysnail.net
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/macsec.c

index dc17b91dce2db23c66b7561dcede714034b46857..115cdf347643aed85ca9012d08d34d7714f8f47f 100644 (file)
@@ -3766,12 +3766,12 @@ static const struct nla_policy macsec_rtnl_policy[IFLA_MACSEC_MAX + 1] = {
        [IFLA_MACSEC_CIPHER_SUITE] = NLA_POLICY_VALIDATE_FN(NLA_U64, validate_cipher_suite),
        [IFLA_MACSEC_WINDOW] = { .type = NLA_U32 },
        [IFLA_MACSEC_ENCODING_SA] = { .type = NLA_U8 },
-       [IFLA_MACSEC_ENCRYPT] = { .type = NLA_U8 },
-       [IFLA_MACSEC_PROTECT] = { .type = NLA_U8 },
-       [IFLA_MACSEC_INC_SCI] = { .type = NLA_U8 },
-       [IFLA_MACSEC_ES] = { .type = NLA_U8 },
-       [IFLA_MACSEC_SCB] = { .type = NLA_U8 },
-       [IFLA_MACSEC_REPLAY_PROTECT] = { .type = NLA_U8 },
+       [IFLA_MACSEC_ENCRYPT] = NLA_POLICY_MAX(NLA_U8, 1),
+       [IFLA_MACSEC_PROTECT] = NLA_POLICY_MAX(NLA_U8, 1),
+       [IFLA_MACSEC_INC_SCI] = NLA_POLICY_MAX(NLA_U8, 1),
+       [IFLA_MACSEC_ES] = NLA_POLICY_MAX(NLA_U8, 1),
+       [IFLA_MACSEC_SCB] = NLA_POLICY_MAX(NLA_U8, 1),
+       [IFLA_MACSEC_REPLAY_PROTECT] = NLA_POLICY_MAX(NLA_U8, 1),
        [IFLA_MACSEC_VALIDATION] = NLA_POLICY_MAX(NLA_U8, MACSEC_VALIDATE_MAX),
        [IFLA_MACSEC_OFFLOAD] = NLA_POLICY_MAX(NLA_U8, MACSEC_OFFLOAD_MAX),
 };
@@ -4246,7 +4246,6 @@ static int macsec_validate_attr(struct nlattr *tb[], struct nlattr *data[],
                                struct netlink_ext_ack *extack)
 {
        u8 icv_len = MACSEC_DEFAULT_ICV_LEN;
-       int flag;
        bool es, scb, sci;
 
        if (!data)
@@ -4272,15 +4271,6 @@ static int macsec_validate_attr(struct nlattr *tb[], struct nlattr *data[],
                        return -EINVAL;
        }
 
-       for (flag = IFLA_MACSEC_ENCODING_SA + 1;
-            flag < IFLA_MACSEC_VALIDATION;
-            flag++) {
-               if (data[flag]) {
-                       if (nla_get_u8(data[flag]) > 1)
-                               return -EINVAL;
-               }
-       }
-
        es  = nla_get_u8_default(data[IFLA_MACSEC_ES], false);
        sci = nla_get_u8_default(data[IFLA_MACSEC_INC_SCI], false);
        scb = nla_get_u8_default(data[IFLA_MACSEC_SCB], false);