[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20201201175730.0aa647a6@kicinski-fedora-pc1c0hjn.DHCP.thefacebook.com>
Date: Tue, 1 Dec 2020 17:57:30 -0800
From: Jakub Kicinski <kuba@...nel.org>
To: Karsten Graul <kgraul@...ux.ibm.com>
Cc: David Miller <davem@...emloft.net>,
Heiko Carstens <hca@...ux.ibm.com>,
Stefan Raspl <raspl@...ux.ibm.com>, netdev@...r.kernel.org,
linux-s390@...r.kernel.org
Subject: Re: [PATCH net-next v7 00/14] net/smc: Add support for generic
netlink API
On Tue, 1 Dec 2020 20:20:35 +0100 Karsten Graul wrote:
> Please apply the following patch series for smc to netdev's net-next tree.
>
> Up to version 4 this patch series was using the sock_diag netlink
> infrastructure. This version is using the generic netlink API. Generic
> netlink API offers a better type safety between kernel and userspace
> communication.
> Using the generic netlink API the smc module can now provide information
> about SMC linkgroups, links and devices (both for SMC-R and SMC-D).
>
> v2: Add missing include to uapi header smc_diag.h.
>
> v3: Apply code style recommendations from review comments.
> Instead of using EXPORTs to allow the smc_diag module to access
> data of the smc module, introduce struct smc_diag_ops and let
> smc_diag access the required data using function pointers.
>
> v4: Address checkpatch.pl warnings. Do not use static inline for
> functions.
>
> v5: Use generic netlink API instead of the sock_diag netlink
> infrastructure.
>
> v6: Integrate more review comments from Jakub.
>
> v7: Use nla_nest_start() with the new family. Use .maxattr=1 in the
> genl family and define one entry for attribute 1 in the policy to
> reject this attritbute for all commands. All other possible attributes
> are rejected because NL_VALIDATE_STRICT is set for the policy
> implicitely, which includes NL_VALIDATE_MAXTYPE.
> Setting policy[0].strict_start_type=1 does not work here because there
> is no valid attribute defined for this family, only plain commands. For
> any type > maxtype (which is .maxattr) validate_nla() would return 0 to
> userspace instead of -EINVAL. What helps here is __nla_validate_parse()
> which checks for type > maxtype and returns -EINVAL when NL_VALIDATE_MAXTYPE
> is set. This requires the one entry for type == .maxattr with
> .type = NLA_REJECT in the nla_policy.
> When a future command wants to allow attributes then it can easily specify a
> dedicated .policy for this new command in the genl_ops array. This dedicated
> policy overlays the global policy specified in the genl_family structure.
Applied, thank you!
Powered by blists - more mailing lists