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 }, 36*5a7e09d5SGuvenc Gulce { 37*5a7e09d5SGuvenc Gulce .cmd = SMC_NETLINK_GET_LINK_SMCR, 38*5a7e09d5SGuvenc Gulce /* can be retrieved by unprivileged users */ 39*5a7e09d5SGuvenc Gulce .dumpit = smcr_nl_get_link, 40*5a7e09d5SGuvenc Gulce }, 41e8372d9dSGuvenc Gulce }; 42e8372d9dSGuvenc Gulce 43e8372d9dSGuvenc Gulce static const struct nla_policy smc_gen_nl_policy[2] = { 44e8372d9dSGuvenc Gulce [SMC_CMD_MAX_ATTR] = { .type = NLA_REJECT, }, 45e8372d9dSGuvenc Gulce }; 46e8372d9dSGuvenc Gulce 47e8372d9dSGuvenc Gulce /* SMC_GENL family definition */ 48e8372d9dSGuvenc Gulce struct genl_family smc_gen_nl_family __ro_after_init = { 49e8372d9dSGuvenc Gulce .hdrsize = 0, 50e8372d9dSGuvenc Gulce .name = SMC_GENL_FAMILY_NAME, 51e8372d9dSGuvenc Gulce .version = SMC_GENL_FAMILY_VERSION, 52e8372d9dSGuvenc Gulce .maxattr = SMC_CMD_MAX_ATTR, 53e8372d9dSGuvenc Gulce .policy = smc_gen_nl_policy, 54e8372d9dSGuvenc Gulce .netnsok = true, 55e8372d9dSGuvenc Gulce .module = THIS_MODULE, 56e8372d9dSGuvenc Gulce .ops = smc_gen_nl_ops, 57e8372d9dSGuvenc Gulce .n_ops = ARRAY_SIZE(smc_gen_nl_ops) 58e8372d9dSGuvenc Gulce }; 59e8372d9dSGuvenc Gulce 60e8372d9dSGuvenc Gulce int __init smc_nl_init(void) 61e8372d9dSGuvenc Gulce { 62e8372d9dSGuvenc Gulce return genl_register_family(&smc_gen_nl_family); 63e8372d9dSGuvenc Gulce } 64e8372d9dSGuvenc Gulce 65e8372d9dSGuvenc Gulce void smc_nl_exit(void) 66e8372d9dSGuvenc Gulce { 67e8372d9dSGuvenc Gulce genl_unregister_family(&smc_gen_nl_family); 68e8372d9dSGuvenc Gulce } 69