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
1870cfb64cSWen Gu #define SMC_VIRTUAL_ISM_CHID_MASK 0xFF00
1970cfb64cSWen Gu
20c6ba7c9bSHans Wippel struct smcd_dev_list { /* List of SMCD devices */
21c6ba7c9bSHans Wippel struct list_head list;
2282087c03SUrsula Braun struct mutex mutex; /* Protects list of devices */
23c6ba7c9bSHans Wippel };
24c6ba7c9bSHans Wippel
25c6ba7c9bSHans Wippel extern struct smcd_dev_list smcd_dev_list; /* list of smcd devices */
26c6ba7c9bSHans Wippel
27c6ba7c9bSHans Wippel struct smc_ism_vlanid { /* VLAN id set on ISM device */
28c6ba7c9bSHans Wippel struct list_head list;
29c6ba7c9bSHans Wippel unsigned short vlanid; /* Vlan id */
30c6ba7c9bSHans Wippel refcount_t refcnt; /* Reference count */
31c6ba7c9bSHans Wippel };
32c6ba7c9bSHans Wippel
33c6ba7c9bSHans Wippel struct smcd_dev;
34c6ba7c9bSHans Wippel
357e5ef8ebSWen Gu int smc_ism_cantalk(struct smcd_gid *peer_gid, unsigned short vlan_id,
367e5ef8ebSWen Gu struct smcd_dev *dev);
37c6ba7c9bSHans Wippel void smc_ism_set_conn(struct smc_connection *conn);
38c6ba7c9bSHans Wippel void smc_ism_unset_conn(struct smc_connection *conn);
39c6ba7c9bSHans Wippel int smc_ism_get_vlan(struct smcd_dev *dev, unsigned short vlan_id);
40c6ba7c9bSHans Wippel int smc_ism_put_vlan(struct smcd_dev *dev, unsigned short vlan_id);
41c6ba7c9bSHans Wippel int smc_ism_register_dmb(struct smc_link_group *lgr, int buf_size,
42c6ba7c9bSHans Wippel struct smc_buf_desc *dmb_desc);
43c6ba7c9bSHans Wippel int smc_ism_unregister_dmb(struct smcd_dev *dev, struct smc_buf_desc *dmb_desc);
44*fe7ef3a1SWen Gu bool smc_ism_support_dmb_nocopy(struct smcd_dev *smcd);
45*fe7ef3a1SWen Gu int smc_ism_attach_dmb(struct smcd_dev *dev, u64 token,
46*fe7ef3a1SWen Gu struct smc_buf_desc *dmb_desc);
47*fe7ef3a1SWen Gu int smc_ism_detach_dmb(struct smcd_dev *dev, u64 token);
480512f69eSHans Wippel int smc_ism_signal_shutdown(struct smc_link_group *lgr);
4911a26c59SKarsten Graul void smc_ism_get_system_eid(u8 **eid);
508caaccf5SUrsula Braun u16 smc_ism_get_chid(struct smcd_dev *dev);
5149407ae2SGuvenc Gulce bool smc_ism_is_v2_capable(void);
528747716fSStefan Raspl int smc_ism_init(void);
538747716fSStefan Raspl void smc_ism_exit(void);
54aaf95523SGuvenc Gulce int smcd_nl_get_device(struct sk_buff *skb, struct netlink_callback *cb);
55eb481b02SHeiko Carstens
smc_ism_write(struct smcd_dev * smcd,u64 dmb_tok,unsigned int idx,bool sf,unsigned int offset,void * data,size_t len)56eb481b02SHeiko Carstens static inline int smc_ism_write(struct smcd_dev *smcd, u64 dmb_tok,
57eb481b02SHeiko Carstens unsigned int idx, bool sf, unsigned int offset,
58eb481b02SHeiko Carstens void *data, size_t len)
59eb481b02SHeiko Carstens {
60eb481b02SHeiko Carstens int rc;
61eb481b02SHeiko Carstens
62eb481b02SHeiko Carstens rc = smcd->ops->move_data(smcd, dmb_tok, idx, sf, offset, data, len);
63eb481b02SHeiko Carstens return rc < 0 ? rc : 0;
64eb481b02SHeiko Carstens }
65eb481b02SHeiko Carstens
__smc_ism_is_virtual(u16 chid)6670cfb64cSWen Gu static inline bool __smc_ism_is_virtual(u16 chid)
6770cfb64cSWen Gu {
6870cfb64cSWen Gu /* CHIDs in range of 0xFF00 to 0xFFFF are reserved
6970cfb64cSWen Gu * for virtual ISM device.
7070cfb64cSWen Gu *
7170cfb64cSWen Gu * loopback-ism: 0xFFFF
7270cfb64cSWen Gu * virtio-ism: 0xFF00 ~ 0xFFFE
7370cfb64cSWen Gu */
7470cfb64cSWen Gu return ((chid & 0xFF00) == 0xFF00);
7570cfb64cSWen Gu }
7670cfb64cSWen Gu
smc_ism_is_virtual(struct smcd_dev * smcd)7770cfb64cSWen Gu static inline bool smc_ism_is_virtual(struct smcd_dev *smcd)
7870cfb64cSWen Gu {
7970cfb64cSWen Gu u16 chid = smcd->ops->get_chid(smcd);
8070cfb64cSWen Gu
8170cfb64cSWen Gu return __smc_ism_is_virtual(chid);
8270cfb64cSWen Gu }
8370cfb64cSWen Gu
84c6ba7c9bSHans Wippel #endif
85