blob: e441aa97ad61b1834f4983d10e15a34a7936f916 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Ursula Braunf16a7dd2017-01-09 16:55:26 +01002/*
3 * Shared Memory Communications over RDMA (SMC-R) and RoCE
4 *
5 * Definitions for the SMC module (socket related)
6 *
7 * Copyright IBM Corp. 2016
8 *
9 * Author(s): Ursula Braun <ubraun@linux.vnet.ibm.com>
10 */
11#ifndef _SMC_H
12#define _SMC_H
13
Ursula Braun0afff912018-06-28 19:05:05 +020014#define SMC_MAX_PNETID_LEN 16 /* Max. length of PNET id */
15
Ursula Braunf16a7dd2017-01-09 16:55:26 +010016struct smc_hashinfo {
17 rwlock_t lock;
18 struct hlist_head ht;
19};
20
21int smc_hash_sk(struct sock *sk);
22void smc_unhash_sk(struct sock *sk);
Hans Wippelc6ba7c92018-06-28 19:05:07 +020023
24/* SMCD/ISM device driver interface */
25struct smcd_dmb {
26 u64 dmb_tok;
27 u64 rgid;
28 u32 dmb_len;
29 u32 sba_idx;
30 u32 vlan_valid;
31 u32 vlan_id;
32 void *cpu_addr;
33 dma_addr_t dma_addr;
34};
35
36#define ISM_EVENT_DMB 0
37#define ISM_EVENT_GID 1
38#define ISM_EVENT_SWR 2
39
Ursula Braun201091e2020-09-26 12:44:24 +020040#define ISM_RESERVED_VLANID 0x1FFF
41
Ursula Braun42bfba92019-11-14 13:02:41 +010042#define ISM_ERROR 0xFFFF
43
Hans Wippelc6ba7c92018-06-28 19:05:07 +020044struct smcd_event {
45 u32 type;
46 u32 code;
47 u64 tok;
48 u64 time;
49 u64 info;
50};
51
52struct smcd_dev;
53
54struct smcd_ops {
55 int (*query_remote_gid)(struct smcd_dev *dev, u64 rgid, u32 vid_valid,
56 u32 vid);
57 int (*register_dmb)(struct smcd_dev *dev, struct smcd_dmb *dmb);
58 int (*unregister_dmb)(struct smcd_dev *dev, struct smcd_dmb *dmb);
59 int (*add_vlan_id)(struct smcd_dev *dev, u64 vlan_id);
60 int (*del_vlan_id)(struct smcd_dev *dev, u64 vlan_id);
61 int (*set_vlan_required)(struct smcd_dev *dev);
62 int (*reset_vlan_required)(struct smcd_dev *dev);
63 int (*signal_event)(struct smcd_dev *dev, u64 rgid, u32 trigger_irq,
64 u32 event_code, u64 info);
65 int (*move_data)(struct smcd_dev *dev, u64 dmb_tok, unsigned int idx,
66 bool sf, unsigned int offset, void *data,
67 unsigned int size);
Ursula Braun201091e2020-09-26 12:44:24 +020068 void (*get_system_eid)(struct smcd_dev *dev, u8 **eid);
Ursula Braun8caaccf2020-09-26 12:44:25 +020069 u16 (*get_chid)(struct smcd_dev *dev);
Hans Wippelc6ba7c92018-06-28 19:05:07 +020070};
71
72struct smcd_dev {
73 const struct smcd_ops *ops;
74 struct device dev;
75 void *priv;
76 u64 local_gid;
77 struct list_head list;
78 spinlock_t lock;
79 struct smc_connection **conn;
80 struct list_head vlan;
81 struct workqueue_struct *event_wq;
Hans Wippel1619f772018-06-28 19:05:08 +020082 u8 pnetid[SMC_MAX_PNETID_LEN];
Hans Wippelf3d74b22019-02-21 13:01:01 +010083 bool pnetid_by_user;
Ursula Brauna2351c52019-10-09 10:07:43 +020084 struct list_head lgr_list;
Ursula Brauna0a62ee2019-10-09 10:07:44 +020085 spinlock_t lgr_lock;
Ursula Braun5edd6b92019-11-14 13:02:43 +010086 atomic_t lgr_cnt;
87 wait_queue_head_t lgrs_deleted;
Ursula Braunc3d94942019-10-09 10:07:46 +020088 u8 going_away : 1;
Hans Wippelc6ba7c92018-06-28 19:05:07 +020089};
90
91struct smcd_dev *smcd_alloc_dev(struct device *parent, const char *name,
92 const struct smcd_ops *ops, int max_dmbs);
93int smcd_register_dev(struct smcd_dev *smcd);
94void smcd_unregister_dev(struct smcd_dev *smcd);
95void smcd_free_dev(struct smcd_dev *smcd);
96void smcd_handle_event(struct smcd_dev *dev, struct smcd_event *event);
97void smcd_handle_irq(struct smcd_dev *dev, unsigned int bit);
Ursula Braunf16a7dd2017-01-09 16:55:26 +010098#endif /* _SMC_H */