blob: db84e4e35080f4792409993d0dfa62de8621e8a3 [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
Jakub Kicinski949d6b42022-07-20 16:57:58 -070014#include <linux/device.h>
15#include <linux/spinlock.h>
16#include <linux/types.h>
17#include <linux/wait.h>
Stefan Raspl89e7d2b2023-01-23 19:17:48 +010018#include "linux/ism.h"
Jakub Kicinski949d6b42022-07-20 16:57:58 -070019
20struct sock;
21
Ursula Braun0afff912018-06-28 19:05:05 +020022#define SMC_MAX_PNETID_LEN 16 /* Max. length of PNET id */
23
Ursula Braunf16a7dd2017-01-09 16:55:26 +010024struct smc_hashinfo {
25 rwlock_t lock;
26 struct hlist_head ht;
27};
28
Hans Wippelc6ba7c92018-06-28 19:05:07 +020029/* SMCD/ISM device driver interface */
30struct smcd_dmb {
31 u64 dmb_tok;
32 u64 rgid;
33 u32 dmb_len;
34 u32 sba_idx;
35 u32 vlan_valid;
36 u32 vlan_id;
37 void *cpu_addr;
38 dma_addr_t dma_addr;
39};
40
41#define ISM_EVENT_DMB 0
42#define ISM_EVENT_GID 1
43#define ISM_EVENT_SWR 2
44
Ursula Braun201091e2020-09-26 12:44:24 +020045#define ISM_RESERVED_VLANID 0x1FFF
46
Ursula Braun42bfba92019-11-14 13:02:41 +010047#define ISM_ERROR 0xFFFF
48
Hans Wippelc6ba7c92018-06-28 19:05:07 +020049struct smcd_dev;
50
Wen Gub40584d2023-12-19 22:26:13 +080051struct smcd_gid {
52 u64 gid;
53 u64 gid_ext;
54};
55
Hans Wippelc6ba7c92018-06-28 19:05:07 +020056struct smcd_ops {
Wen Gub40584d2023-12-19 22:26:13 +080057 int (*query_remote_gid)(struct smcd_dev *dev, struct smcd_gid *rgid,
58 u32 vid_valid, u32 vid);
Stefan Raspl820f2102023-01-23 19:17:51 +010059 int (*register_dmb)(struct smcd_dev *dev, struct smcd_dmb *dmb,
Wen Gu784c46f2024-04-28 14:07:28 +080060 void *client);
Hans Wippelc6ba7c92018-06-28 19:05:07 +020061 int (*unregister_dmb)(struct smcd_dev *dev, struct smcd_dmb *dmb);
Hans Wippelc6ba7c92018-06-28 19:05:07 +020062 int (*move_data)(struct smcd_dev *dev, u64 dmb_tok, unsigned int idx,
63 bool sf, unsigned int offset, void *data,
64 unsigned int size);
Stefan Rasplf9475682023-03-13 11:10:31 +010065 int (*supports_v2)(void);
Wen Gub40584d2023-12-19 22:26:13 +080066 void (*get_local_gid)(struct smcd_dev *dev, struct smcd_gid *gid);
Ursula Braun8caaccf2020-09-26 12:44:25 +020067 u16 (*get_chid)(struct smcd_dev *dev);
Stefan Raspl8c81ba22023-01-23 19:17:52 +010068 struct device* (*get_dev)(struct smcd_dev *dev);
Wen Gud1d8d0b2024-04-28 14:07:32 +080069
70 /* optional operations */
71 int (*add_vlan_id)(struct smcd_dev *dev, u64 vlan_id);
72 int (*del_vlan_id)(struct smcd_dev *dev, u64 vlan_id);
73 int (*set_vlan_required)(struct smcd_dev *dev);
74 int (*reset_vlan_required)(struct smcd_dev *dev);
75 int (*signal_event)(struct smcd_dev *dev, struct smcd_gid *rgid,
76 u32 trigger_irq, u32 event_code, u64 info);
Wen Gu43988882024-04-28 14:07:35 +080077 int (*support_dmb_nocopy)(struct smcd_dev *dev);
78 int (*attach_dmb)(struct smcd_dev *dev, struct smcd_dmb *dmb);
79 int (*detach_dmb)(struct smcd_dev *dev, u64 token);
Hans Wippelc6ba7c92018-06-28 19:05:07 +020080};
81
82struct smcd_dev {
83 const struct smcd_ops *ops;
Hans Wippelc6ba7c92018-06-28 19:05:07 +020084 void *priv;
Wen Gu784c46f2024-04-28 14:07:28 +080085 void *client;
Hans Wippelc6ba7c92018-06-28 19:05:07 +020086 struct list_head list;
87 spinlock_t lock;
88 struct smc_connection **conn;
89 struct list_head vlan;
90 struct workqueue_struct *event_wq;
Hans Wippel1619f772018-06-28 19:05:08 +020091 u8 pnetid[SMC_MAX_PNETID_LEN];
Hans Wippelf3d74b22019-02-21 13:01:01 +010092 bool pnetid_by_user;
Ursula Brauna2351c52019-10-09 10:07:43 +020093 struct list_head lgr_list;
Ursula Brauna0a62ee2019-10-09 10:07:44 +020094 spinlock_t lgr_lock;
Ursula Braun5edd6b92019-11-14 13:02:43 +010095 atomic_t lgr_cnt;
96 wait_queue_head_t lgrs_deleted;
Ursula Braunc3d94942019-10-09 10:07:46 +020097 u8 going_away : 1;
Hans Wippelc6ba7c92018-06-28 19:05:07 +020098};
99
Ursula Braunf16a7dd2017-01-09 16:55:26 +0100100#endif /* _SMC_H */