|  | /* SPDX-License-Identifier: GPL-2.0 */ | 
|  | /* Shared Memory Communications Direct over ISM devices (SMC-D) | 
|  | * | 
|  | * SMC-D ISM device structure definitions. | 
|  | * | 
|  | * Copyright IBM Corp. 2018 | 
|  | */ | 
|  |  | 
|  | #ifndef SMCD_ISM_H | 
|  | #define SMCD_ISM_H | 
|  |  | 
|  | #include <linux/uio.h> | 
|  | #include <linux/types.h> | 
|  | #include <linux/mutex.h> | 
|  |  | 
|  | #include "smc.h" | 
|  |  | 
|  | #define SMC_EMULATED_ISM_CHID_MASK	0xFF00 | 
|  | #define SMC_ISM_IDENT_MASK		0x00FFFF | 
|  |  | 
|  | struct smcd_dev_list {	/* List of SMCD devices */ | 
|  | struct list_head list; | 
|  | struct mutex mutex;	/* Protects list of devices */ | 
|  | }; | 
|  |  | 
|  | extern struct smcd_dev_list	smcd_dev_list;	/* list of smcd devices */ | 
|  |  | 
|  | struct smc_ism_vlanid {			/* VLAN id set on ISM device */ | 
|  | struct list_head list; | 
|  | unsigned short vlanid;		/* Vlan id */ | 
|  | refcount_t refcnt;		/* Reference count */ | 
|  | }; | 
|  |  | 
|  | struct smc_ism_seid { | 
|  | u8 seid_string[24]; | 
|  | u8 serial_number[4]; | 
|  | u8 type[4]; | 
|  | }; | 
|  |  | 
|  | struct smcd_dev; | 
|  |  | 
|  | int smc_ism_cantalk(struct smcd_gid *peer_gid, unsigned short vlan_id, | 
|  | struct smcd_dev *dev); | 
|  | void smc_ism_set_conn(struct smc_connection *conn); | 
|  | void smc_ism_unset_conn(struct smc_connection *conn); | 
|  | int smc_ism_get_vlan(struct smcd_dev *dev, unsigned short vlan_id); | 
|  | int smc_ism_put_vlan(struct smcd_dev *dev, unsigned short vlan_id); | 
|  | int smc_ism_register_dmb(struct smc_link_group *lgr, int buf_size, | 
|  | struct smc_buf_desc *dmb_desc); | 
|  | int smc_ism_unregister_dmb(struct smcd_dev *dev, struct smc_buf_desc *dmb_desc); | 
|  | bool smc_ism_support_dmb_nocopy(struct smcd_dev *smcd); | 
|  | int smc_ism_attach_dmb(struct smcd_dev *dev, u64 token, | 
|  | struct smc_buf_desc *dmb_desc); | 
|  | int smc_ism_detach_dmb(struct smcd_dev *dev, u64 token); | 
|  | int smc_ism_signal_shutdown(struct smc_link_group *lgr); | 
|  | void smc_ism_get_system_eid(u8 **eid); | 
|  | u16 smc_ism_get_chid(struct smcd_dev *dev); | 
|  | bool smc_ism_is_v2_capable(void); | 
|  | void smc_ism_set_v2_capable(void); | 
|  | int smc_ism_init(void); | 
|  | void smc_ism_exit(void); | 
|  | int smcd_nl_get_device(struct sk_buff *skb, struct netlink_callback *cb); | 
|  |  | 
|  | static inline int smc_ism_write(struct smcd_dev *smcd, u64 dmb_tok, | 
|  | unsigned int idx, bool sf, unsigned int offset, | 
|  | void *data, size_t len) | 
|  | { | 
|  | int rc; | 
|  |  | 
|  | rc = smcd->ops->move_data(smcd, dmb_tok, idx, sf, offset, data, len); | 
|  | return rc < 0 ? rc : 0; | 
|  | } | 
|  |  | 
|  | static inline bool __smc_ism_is_emulated(u16 chid) | 
|  | { | 
|  | /* CHIDs in range of 0xFF00 to 0xFFFF are reserved | 
|  | * for Emulated-ISM device. | 
|  | * | 
|  | * loopback-ism:	0xFFFF | 
|  | * virtio-ism:		0xFF00 ~ 0xFFFE | 
|  | */ | 
|  | return ((chid & 0xFF00) == 0xFF00); | 
|  | } | 
|  |  | 
|  | static inline bool smc_ism_is_emulated(struct smcd_dev *smcd) | 
|  | { | 
|  | u16 chid = smcd->ops->get_chid(smcd); | 
|  |  | 
|  | return __smc_ism_is_emulated(chid); | 
|  | } | 
|  |  | 
|  | static inline bool smc_ism_is_loopback(struct smcd_dev *smcd) | 
|  | { | 
|  | return (smcd->ops->get_chid(smcd) == 0xFFFF); | 
|  | } | 
|  |  | 
|  | #endif |