Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Ursula Braun | f16a7dd | 2017-01-09 16:55:26 +0100 | [diff] [blame] | 2 | /* |
| 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 Kicinski | 949d6b4 | 2022-07-20 16:57:58 -0700 | [diff] [blame] | 14 | #include <linux/device.h> |
| 15 | #include <linux/spinlock.h> |
| 16 | #include <linux/types.h> |
| 17 | #include <linux/wait.h> |
Stefan Raspl | 89e7d2b | 2023-01-23 19:17:48 +0100 | [diff] [blame] | 18 | #include "linux/ism.h" |
Jakub Kicinski | 949d6b4 | 2022-07-20 16:57:58 -0700 | [diff] [blame] | 19 | |
| 20 | struct sock; |
| 21 | |
Ursula Braun | 0afff91 | 2018-06-28 19:05:05 +0200 | [diff] [blame] | 22 | #define SMC_MAX_PNETID_LEN 16 /* Max. length of PNET id */ |
| 23 | |
Ursula Braun | f16a7dd | 2017-01-09 16:55:26 +0100 | [diff] [blame] | 24 | struct smc_hashinfo { |
| 25 | rwlock_t lock; |
| 26 | struct hlist_head ht; |
| 27 | }; |
| 28 | |
Hans Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 29 | /* SMCD/ISM device driver interface */ |
| 30 | struct 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 Braun | 201091e | 2020-09-26 12:44:24 +0200 | [diff] [blame] | 45 | #define ISM_RESERVED_VLANID 0x1FFF |
| 46 | |
Ursula Braun | 42bfba9 | 2019-11-14 13:02:41 +0100 | [diff] [blame] | 47 | #define ISM_ERROR 0xFFFF |
| 48 | |
Hans Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 49 | struct smcd_dev; |
| 50 | |
Wen Gu | b40584d | 2023-12-19 22:26:13 +0800 | [diff] [blame] | 51 | struct smcd_gid { |
| 52 | u64 gid; |
| 53 | u64 gid_ext; |
| 54 | }; |
| 55 | |
Hans Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 56 | struct smcd_ops { |
Wen Gu | b40584d | 2023-12-19 22:26:13 +0800 | [diff] [blame] | 57 | int (*query_remote_gid)(struct smcd_dev *dev, struct smcd_gid *rgid, |
| 58 | u32 vid_valid, u32 vid); |
Stefan Raspl | 820f210 | 2023-01-23 19:17:51 +0100 | [diff] [blame] | 59 | int (*register_dmb)(struct smcd_dev *dev, struct smcd_dmb *dmb, |
Wen Gu | 784c46f | 2024-04-28 14:07:28 +0800 | [diff] [blame] | 60 | void *client); |
Hans Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 61 | int (*unregister_dmb)(struct smcd_dev *dev, struct smcd_dmb *dmb); |
Hans Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 62 | 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 Raspl | f947568 | 2023-03-13 11:10:31 +0100 | [diff] [blame] | 65 | int (*supports_v2)(void); |
Wen Gu | b40584d | 2023-12-19 22:26:13 +0800 | [diff] [blame] | 66 | void (*get_local_gid)(struct smcd_dev *dev, struct smcd_gid *gid); |
Ursula Braun | 8caaccf | 2020-09-26 12:44:25 +0200 | [diff] [blame] | 67 | u16 (*get_chid)(struct smcd_dev *dev); |
Stefan Raspl | 8c81ba2 | 2023-01-23 19:17:52 +0100 | [diff] [blame] | 68 | struct device* (*get_dev)(struct smcd_dev *dev); |
Wen Gu | d1d8d0b | 2024-04-28 14:07:32 +0800 | [diff] [blame] | 69 | |
| 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 Gu | 4398888 | 2024-04-28 14:07:35 +0800 | [diff] [blame] | 77 | 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 Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 80 | }; |
| 81 | |
| 82 | struct smcd_dev { |
| 83 | const struct smcd_ops *ops; |
Hans Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 84 | void *priv; |
Wen Gu | 784c46f | 2024-04-28 14:07:28 +0800 | [diff] [blame] | 85 | void *client; |
Hans Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 86 | 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 Wippel | 1619f77 | 2018-06-28 19:05:08 +0200 | [diff] [blame] | 91 | u8 pnetid[SMC_MAX_PNETID_LEN]; |
Hans Wippel | f3d74b2 | 2019-02-21 13:01:01 +0100 | [diff] [blame] | 92 | bool pnetid_by_user; |
Ursula Braun | a2351c5 | 2019-10-09 10:07:43 +0200 | [diff] [blame] | 93 | struct list_head lgr_list; |
Ursula Braun | a0a62ee | 2019-10-09 10:07:44 +0200 | [diff] [blame] | 94 | spinlock_t lgr_lock; |
Ursula Braun | 5edd6b9 | 2019-11-14 13:02:43 +0100 | [diff] [blame] | 95 | atomic_t lgr_cnt; |
| 96 | wait_queue_head_t lgrs_deleted; |
Ursula Braun | c3d9494 | 2019-10-09 10:07:46 +0200 | [diff] [blame] | 97 | u8 going_away : 1; |
Hans Wippel | c6ba7c9 | 2018-06-28 19:05:07 +0200 | [diff] [blame] | 98 | }; |
| 99 | |
Ursula Braun | f16a7dd | 2017-01-09 16:55:26 +0100 | [diff] [blame] | 100 | #endif /* _SMC_H */ |