xref: /openbmc/linux/net/smc/smc_netlink.c (revision 8f9dde4b)
1e8372d9dSGuvenc Gulce // SPDX-License-Identifier: GPL-2.0
2e8372d9dSGuvenc Gulce /*
3e8372d9dSGuvenc Gulce  *  Shared Memory Communications over RDMA (SMC-R) and RoCE
4e8372d9dSGuvenc Gulce  *
5e8372d9dSGuvenc Gulce  *  Generic netlink support functions to interact with SMC module
6e8372d9dSGuvenc Gulce  *
7e8372d9dSGuvenc Gulce  *  Copyright IBM Corp. 2020
8e8372d9dSGuvenc Gulce  *
9e8372d9dSGuvenc Gulce  *  Author(s):	Guvenc Gulce <guvenc@linux.ibm.com>
10e8372d9dSGuvenc Gulce  */
11e8372d9dSGuvenc Gulce 
12e8372d9dSGuvenc Gulce #include <linux/module.h>
13e8372d9dSGuvenc Gulce #include <linux/list.h>
14e8372d9dSGuvenc Gulce #include <linux/ctype.h>
15e8372d9dSGuvenc Gulce #include <linux/mutex.h>
16e8372d9dSGuvenc Gulce #include <linux/if.h>
17e8372d9dSGuvenc Gulce #include <linux/smc.h>
18e8372d9dSGuvenc Gulce 
19e8372d9dSGuvenc Gulce #include "smc_core.h"
20e8372d9dSGuvenc Gulce #include "smc_netlink.h"
21e8372d9dSGuvenc Gulce 
22e8372d9dSGuvenc Gulce #define SMC_CMD_MAX_ATTR 1
23e8372d9dSGuvenc Gulce 
24e8372d9dSGuvenc Gulce /* SMC_GENL generic netlink operation definition */
25e8372d9dSGuvenc Gulce static const struct genl_ops smc_gen_nl_ops[] = {
26099b990bSGuvenc Gulce 	{
27099b990bSGuvenc Gulce 		.cmd = SMC_NETLINK_GET_SYS_INFO,
28099b990bSGuvenc Gulce 		/* can be retrieved by unprivileged users */
29099b990bSGuvenc Gulce 		.dumpit = smc_nl_get_sys_info,
30099b990bSGuvenc Gulce 	},
31e9b8c845SGuvenc Gulce 	{
32e9b8c845SGuvenc Gulce 		.cmd = SMC_NETLINK_GET_LGR_SMCR,
33e9b8c845SGuvenc Gulce 		/* can be retrieved by unprivileged users */
34e9b8c845SGuvenc Gulce 		.dumpit = smcr_nl_get_lgr,
35e9b8c845SGuvenc Gulce 	},
365a7e09d5SGuvenc Gulce 	{
375a7e09d5SGuvenc Gulce 		.cmd = SMC_NETLINK_GET_LINK_SMCR,
385a7e09d5SGuvenc Gulce 		/* can be retrieved by unprivileged users */
395a7e09d5SGuvenc Gulce 		.dumpit = smcr_nl_get_link,
405a7e09d5SGuvenc Gulce 	},
41*8f9dde4bSGuvenc Gulce 	{
42*8f9dde4bSGuvenc Gulce 		.cmd = SMC_NETLINK_GET_LGR_SMCD,
43*8f9dde4bSGuvenc Gulce 		/* can be retrieved by unprivileged users */
44*8f9dde4bSGuvenc Gulce 		.dumpit = smcd_nl_get_lgr,
45*8f9dde4bSGuvenc Gulce 	},
46e8372d9dSGuvenc Gulce };
47e8372d9dSGuvenc Gulce 
48e8372d9dSGuvenc Gulce static const struct nla_policy smc_gen_nl_policy[2] = {
49e8372d9dSGuvenc Gulce 	[SMC_CMD_MAX_ATTR]	= { .type = NLA_REJECT, },
50e8372d9dSGuvenc Gulce };
51e8372d9dSGuvenc Gulce 
52e8372d9dSGuvenc Gulce /* SMC_GENL family definition */
53e8372d9dSGuvenc Gulce struct genl_family smc_gen_nl_family __ro_after_init = {
54e8372d9dSGuvenc Gulce 	.hdrsize =	0,
55e8372d9dSGuvenc Gulce 	.name =		SMC_GENL_FAMILY_NAME,
56e8372d9dSGuvenc Gulce 	.version =	SMC_GENL_FAMILY_VERSION,
57e8372d9dSGuvenc Gulce 	.maxattr =	SMC_CMD_MAX_ATTR,
58e8372d9dSGuvenc Gulce 	.policy =	smc_gen_nl_policy,
59e8372d9dSGuvenc Gulce 	.netnsok =	true,
60e8372d9dSGuvenc Gulce 	.module =	THIS_MODULE,
61e8372d9dSGuvenc Gulce 	.ops =		smc_gen_nl_ops,
62e8372d9dSGuvenc Gulce 	.n_ops =	ARRAY_SIZE(smc_gen_nl_ops)
63e8372d9dSGuvenc Gulce };
64e8372d9dSGuvenc Gulce 
65e8372d9dSGuvenc Gulce int __init smc_nl_init(void)
66e8372d9dSGuvenc Gulce {
67e8372d9dSGuvenc Gulce 	return genl_register_family(&smc_gen_nl_family);
68e8372d9dSGuvenc Gulce }
69e8372d9dSGuvenc Gulce 
70e8372d9dSGuvenc Gulce void smc_nl_exit(void)
71e8372d9dSGuvenc Gulce {
72e8372d9dSGuvenc Gulce 	genl_unregister_family(&smc_gen_nl_family);
73e8372d9dSGuvenc Gulce }
74