1c6ba7c9bSHans Wippel /* SPDX-License-Identifier: GPL-2.0 */
2c6ba7c9bSHans Wippel /* Shared Memory Communications Direct over ISM devices (SMC-D)
3c6ba7c9bSHans Wippel *
4c6ba7c9bSHans Wippel * SMC-D ISM device structure definitions.
5c6ba7c9bSHans Wippel *
6c6ba7c9bSHans Wippel * Copyright IBM Corp. 2018
7c6ba7c9bSHans Wippel */
8c6ba7c9bSHans Wippel
9c6ba7c9bSHans Wippel #ifndef SMCD_ISM_H
10c6ba7c9bSHans Wippel #define SMCD_ISM_H
11c6ba7c9bSHans Wippel
12c6ba7c9bSHans Wippel #include <linux/uio.h>
1349407ae2SGuvenc Gulce #include <linux/types.h>
1482087c03SUrsula Braun #include <linux/mutex.h>
15c6ba7c9bSHans Wippel
16c6ba7c9bSHans Wippel #include "smc.h"
17c6ba7c9bSHans Wippel
18b27696cdSWen Gu #define SMC_EMULATED_ISM_CHID_MASK 0xFF00
19b3bf7602SWen Gu #define SMC_ISM_IDENT_MASK 0x00FFFF
208dd512dfSWen Gu
21c6ba7c9bSHans Wippel struct smcd_dev_list { /* List of SMCD devices */
22c6ba7c9bSHans Wippel struct list_head list;
2382087c03SUrsula Braun struct mutex mutex; /* Protects list of devices */
24c6ba7c9bSHans Wippel };
25c6ba7c9bSHans Wippel
26c6ba7c9bSHans Wippel extern struct smcd_dev_list smcd_dev_list; /* list of smcd devices */
27c6ba7c9bSHans Wippel
28c6ba7c9bSHans Wippel struct smc_ism_vlanid { /* VLAN id set on ISM device */
29c6ba7c9bSHans Wippel struct list_head list;
30c6ba7c9bSHans Wippel unsigned short vlanid; /* Vlan id */
31c6ba7c9bSHans Wippel refcount_t refcnt; /* Reference count */
32c6ba7c9bSHans Wippel };
33c6ba7c9bSHans Wippel
34b3bf7602SWen Gu struct smc_ism_seid {
35b3bf7602SWen Gu u8 seid_string[24];
36b3bf7602SWen Gu u8 serial_number[4];
37b3bf7602SWen Gu u8 type[4];
38b3bf7602SWen Gu };
39b3bf7602SWen Gu
40c6ba7c9bSHans Wippel struct smcd_dev;
41c6ba7c9bSHans Wippel
42b40584d1SWen Gu int smc_ism_cantalk(struct smcd_gid *peer_gid, unsigned short vlan_id,
43b40584d1SWen Gu struct smcd_dev *dev);
44c6ba7c9bSHans Wippel void smc_ism_set_conn(struct smc_connection *conn);
45c6ba7c9bSHans Wippel void smc_ism_unset_conn(struct smc_connection *conn);
46c6ba7c9bSHans Wippel int smc_ism_get_vlan(struct smcd_dev *dev, unsigned short vlan_id);
47c6ba7c9bSHans Wippel int smc_ism_put_vlan(struct smcd_dev *dev, unsigned short vlan_id);
48c6ba7c9bSHans Wippel int smc_ism_register_dmb(struct smc_link_group *lgr, int buf_size,
49c6ba7c9bSHans Wippel struct smc_buf_desc *dmb_desc);
50c6ba7c9bSHans Wippel int smc_ism_unregister_dmb(struct smcd_dev *dev, struct smc_buf_desc *dmb_desc);
5143988882SWen Gu bool smc_ism_support_dmb_nocopy(struct smcd_dev *smcd);
5243988882SWen Gu int smc_ism_attach_dmb(struct smcd_dev *dev, u64 token,
5343988882SWen Gu struct smc_buf_desc *dmb_desc);
5443988882SWen Gu int smc_ism_detach_dmb(struct smcd_dev *dev, u64 token);
550512f69eSHans Wippel int smc_ism_signal_shutdown(struct smc_link_group *lgr);
5611a26c59SKarsten Graul void smc_ism_get_system_eid(u8 **eid);
578caaccf5SUrsula Braun u16 smc_ism_get_chid(struct smcd_dev *dev);
5849407ae2SGuvenc Gulce bool smc_ism_is_v2_capable(void);
5904791343SWen Gu void smc_ism_set_v2_capable(void);
608747716fSStefan Raspl int smc_ism_init(void);
618747716fSStefan Raspl void smc_ism_exit(void);
62aaf95523SGuvenc Gulce int smcd_nl_get_device(struct sk_buff *skb, struct netlink_callback *cb);
63eb481b02SHeiko Carstens
smc_ism_write(struct smcd_dev * smcd,u64 dmb_tok,unsigned int idx,bool sf,unsigned int offset,void * data,size_t len)64eb481b02SHeiko Carstens static inline int smc_ism_write(struct smcd_dev *smcd, u64 dmb_tok,
65eb481b02SHeiko Carstens unsigned int idx, bool sf, unsigned int offset,
66eb481b02SHeiko Carstens void *data, size_t len)
67eb481b02SHeiko Carstens {
68eb481b02SHeiko Carstens int rc;
69eb481b02SHeiko Carstens
70eb481b02SHeiko Carstens rc = smcd->ops->move_data(smcd, dmb_tok, idx, sf, offset, data, len);
71eb481b02SHeiko Carstens return rc < 0 ? rc : 0;
72eb481b02SHeiko Carstens }
73eb481b02SHeiko Carstens
__smc_ism_is_emulated(u16 chid)74b27696cdSWen Gu static inline bool __smc_ism_is_emulated(u16 chid)
758dd512dfSWen Gu {
768dd512dfSWen Gu /* CHIDs in range of 0xFF00 to 0xFFFF are reserved
77b27696cdSWen Gu * for Emulated-ISM device.
788dd512dfSWen Gu *
798dd512dfSWen Gu * loopback-ism: 0xFFFF
808dd512dfSWen Gu * virtio-ism: 0xFF00 ~ 0xFFFE
818dd512dfSWen Gu */
828dd512dfSWen Gu return ((chid & 0xFF00) == 0xFF00);
838dd512dfSWen Gu }
848dd512dfSWen Gu
smc_ism_is_emulated(struct smcd_dev * smcd)85b27696cdSWen Gu static inline bool smc_ism_is_emulated(struct smcd_dev *smcd)
868dd512dfSWen Gu {
878dd512dfSWen Gu u16 chid = smcd->ops->get_chid(smcd);
888dd512dfSWen Gu
89b27696cdSWen Gu return __smc_ism_is_emulated(chid);
908dd512dfSWen Gu }
918dd512dfSWen Gu
smc_ism_is_loopback(struct smcd_dev * smcd)92c8df2d44SWen Gu static inline bool smc_ism_is_loopback(struct smcd_dev *smcd)
93c8df2d44SWen Gu {
94c8df2d44SWen Gu return (smcd->ops->get_chid(smcd) == 0xFFFF);
95c8df2d44SWen Gu }
96c8df2d44SWen Gu
97c6ba7c9bSHans Wippel #endif
98