blob: 4564e4d69c2e563d3c519434f01c4fb203781242 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Thomas Richter6812baa2017-01-09 16:55:15 +01002/*
3 * Shared Memory Communications over RDMA (SMC-R) and RoCE
4 *
5 * PNET table queries
6 *
7 * Copyright IBM Corp. 2016
8 *
9 * Author(s): Thomas Richter <tmricht@linux.vnet.ibm.com>
10 */
11
12#ifndef _SMC_PNET_H
13#define _SMC_PNET_H
14
Ursula Braun0afff912018-06-28 19:05:05 +020015#if IS_ENABLED(CONFIG_HAVE_PNETID)
16#include <asm/pnet.h>
17#endif
18
Thomas Richter6812baa2017-01-09 16:55:15 +010019struct smc_ib_device;
Hans Wippel1619f772018-06-28 19:05:08 +020020struct smcd_dev;
Karsten Graulbc36d2f2019-04-12 12:57:26 +020021struct smc_init_info;
Thomas Richter6812baa2017-01-09 16:55:15 +010022
Hans Wippel64e28b52019-02-21 13:01:02 +010023/**
24 * struct smc_pnettable - SMC PNET table anchor
25 * @lock: Lock for list action
26 * @pnetlist: List of PNETIDs
27 */
28struct smc_pnettable {
29 rwlock_t lock;
30 struct list_head pnetlist;
31};
32
Ursula Braun0afff912018-06-28 19:05:05 +020033static inline int smc_pnetid_by_dev_port(struct device *dev,
34 unsigned short port, u8 *pnetid)
35{
36#if IS_ENABLED(CONFIG_HAVE_PNETID)
37 return pnet_id_by_dev_port(dev, port, pnetid);
38#else
39 return -ENOENT;
40#endif
41}
42
Thomas Richter6812baa2017-01-09 16:55:15 +010043int smc_pnet_init(void) __init;
Hans Wippel64e28b52019-02-21 13:01:02 +010044int smc_pnet_net_init(struct net *net);
Thomas Richter6812baa2017-01-09 16:55:15 +010045void smc_pnet_exit(void);
Hans Wippel64e28b52019-02-21 13:01:02 +010046void smc_pnet_net_exit(struct net *net);
Karsten Graulbc36d2f2019-04-12 12:57:26 +020047void smc_pnet_find_roce_resource(struct sock *sk, struct smc_init_info *ini);
48void smc_pnet_find_ism_resource(struct sock *sk, struct smc_init_info *ini);
Thomas Richter6812baa2017-01-09 16:55:15 +010049
50#endif