| /* SPDX-License-Identifier: (GPL-2.0 OR Linux-OpenIB) */ | 
 | /* | 
 |  * Copyright (c) 2017-2018 Mellanox Technologies. All rights reserved. | 
 |  */ | 
 |  | 
 | #ifndef _RDMA_SIGNATURE_H_ | 
 | #define _RDMA_SIGNATURE_H_ | 
 |  | 
 | #include <linux/types.h> | 
 |  | 
 | enum ib_signature_prot_cap { | 
 | 	IB_PROT_T10DIF_TYPE_1 = 1, | 
 | 	IB_PROT_T10DIF_TYPE_2 = 1 << 1, | 
 | 	IB_PROT_T10DIF_TYPE_3 = 1 << 2, | 
 | }; | 
 |  | 
 | enum ib_signature_guard_cap { | 
 | 	IB_GUARD_T10DIF_CRC	= 1, | 
 | 	IB_GUARD_T10DIF_CSUM	= 1 << 1, | 
 | }; | 
 |  | 
 | /** | 
 |  * enum ib_signature_type - Signature types | 
 |  * @IB_SIG_TYPE_NONE: Unprotected. | 
 |  * @IB_SIG_TYPE_T10_DIF: Type T10-DIF | 
 |  */ | 
 | enum ib_signature_type { | 
 | 	IB_SIG_TYPE_NONE, | 
 | 	IB_SIG_TYPE_T10_DIF, | 
 | }; | 
 |  | 
 | /** | 
 |  * enum ib_t10_dif_bg_type - Signature T10-DIF block-guard types | 
 |  * @IB_T10DIF_CRC: Corresponds to T10-PI mandated CRC checksum rules. | 
 |  * @IB_T10DIF_CSUM: Corresponds to IP checksum rules. | 
 |  */ | 
 | enum ib_t10_dif_bg_type { | 
 | 	IB_T10DIF_CRC, | 
 | 	IB_T10DIF_CSUM, | 
 | }; | 
 |  | 
 | /** | 
 |  * struct ib_t10_dif_domain - Parameters specific for T10-DIF | 
 |  *     domain. | 
 |  * @bg_type: T10-DIF block guard type (CRC|CSUM) | 
 |  * @pi_interval: protection information interval. | 
 |  * @bg: seed of guard computation. | 
 |  * @app_tag: application tag of guard block | 
 |  * @ref_tag: initial guard block reference tag. | 
 |  * @ref_remap: Indicate wethear the reftag increments each block | 
 |  * @app_escape: Indicate to skip block check if apptag=0xffff | 
 |  * @ref_escape: Indicate to skip block check if reftag=0xffffffff | 
 |  * @apptag_check_mask: check bitmask of application tag. | 
 |  */ | 
 | struct ib_t10_dif_domain { | 
 | 	enum ib_t10_dif_bg_type bg_type; | 
 | 	u16			pi_interval; | 
 | 	u16			bg; | 
 | 	u16			app_tag; | 
 | 	u32			ref_tag; | 
 | 	bool			ref_remap; | 
 | 	bool			app_escape; | 
 | 	bool			ref_escape; | 
 | 	u16			apptag_check_mask; | 
 | }; | 
 |  | 
 | /** | 
 |  * struct ib_sig_domain - Parameters for signature domain | 
 |  * @sig_type: specific signauture type | 
 |  * @sig: union of all signature domain attributes that may | 
 |  *     be used to set domain layout. | 
 |  */ | 
 | struct ib_sig_domain { | 
 | 	enum ib_signature_type sig_type; | 
 | 	union { | 
 | 		struct ib_t10_dif_domain dif; | 
 | 	} sig; | 
 | }; | 
 |  | 
 | /** | 
 |  * struct ib_sig_attrs - Parameters for signature handover operation | 
 |  * @check_mask: bitmask for signature byte check (8 bytes) | 
 |  * @mem: memory domain layout descriptor. | 
 |  * @wire: wire domain layout descriptor. | 
 |  * @meta_length: metadata length | 
 |  */ | 
 | struct ib_sig_attrs { | 
 | 	u8			check_mask; | 
 | 	struct ib_sig_domain	mem; | 
 | 	struct ib_sig_domain	wire; | 
 | 	int			meta_length; | 
 | }; | 
 |  | 
 | enum ib_sig_err_type { | 
 | 	IB_SIG_BAD_GUARD, | 
 | 	IB_SIG_BAD_REFTAG, | 
 | 	IB_SIG_BAD_APPTAG, | 
 | }; | 
 |  | 
 | /* | 
 |  * Signature check masks (8 bytes in total) according to the T10-PI standard: | 
 |  *  -------- -------- ------------ | 
 |  * | GUARD  | APPTAG |   REFTAG   | | 
 |  * |  2B    |  2B    |    4B      | | 
 |  *  -------- -------- ------------ | 
 |  */ | 
 | enum { | 
 | 	IB_SIG_CHECK_GUARD = 0xc0, | 
 | 	IB_SIG_CHECK_APPTAG = 0x30, | 
 | 	IB_SIG_CHECK_REFTAG = 0x0f, | 
 | }; | 
 |  | 
 | /* | 
 |  * struct ib_sig_err - signature error descriptor | 
 |  */ | 
 | struct ib_sig_err { | 
 | 	enum ib_sig_err_type	err_type; | 
 | 	u32			expected; | 
 | 	u32			actual; | 
 | 	u64			sig_err_offset; | 
 | 	u32			key; | 
 | }; | 
 |  | 
 | #endif /* _RDMA_SIGNATURE_H_ */ |