| #ifndef _N2_CORE_H | 
 | #define _N2_CORE_H | 
 |  | 
 | #ifndef __ASSEMBLY__ | 
 |  | 
 | struct ino_blob { | 
 | 	u64			intr; | 
 | 	u64			ino; | 
 | }; | 
 |  | 
 | struct spu_mdesc_info { | 
 | 	u64			cfg_handle; | 
 | 	struct ino_blob		*ino_table; | 
 | 	int			num_intrs; | 
 | }; | 
 |  | 
 | struct n2_crypto { | 
 | 	struct spu_mdesc_info	cwq_info; | 
 | 	struct list_head	cwq_list; | 
 | }; | 
 |  | 
 | struct n2_mau { | 
 | 	struct spu_mdesc_info	mau_info; | 
 | 	struct list_head	mau_list; | 
 | }; | 
 |  | 
 | #define CWQ_ENTRY_SIZE		64 | 
 | #define CWQ_NUM_ENTRIES		64 | 
 |  | 
 | #define MAU_ENTRY_SIZE		64 | 
 | #define MAU_NUM_ENTRIES		64 | 
 |  | 
 | struct cwq_initial_entry { | 
 | 	u64			control; | 
 | 	u64			src_addr; | 
 | 	u64			auth_key_addr; | 
 | 	u64			auth_iv_addr; | 
 | 	u64			final_auth_state_addr; | 
 | 	u64			enc_key_addr; | 
 | 	u64			enc_iv_addr; | 
 | 	u64			dest_addr; | 
 | }; | 
 |  | 
 | struct cwq_ext_entry { | 
 | 	u64			len; | 
 | 	u64			src_addr; | 
 | 	u64			resv1; | 
 | 	u64			resv2; | 
 | 	u64			resv3; | 
 | 	u64			resv4; | 
 | 	u64			resv5; | 
 | 	u64			resv6; | 
 | }; | 
 |  | 
 | struct cwq_final_entry { | 
 | 	u64			control; | 
 | 	u64			src_addr; | 
 | 	u64			resv1; | 
 | 	u64			resv2; | 
 | 	u64			resv3; | 
 | 	u64			resv4; | 
 | 	u64			resv5; | 
 | 	u64			resv6; | 
 | }; | 
 |  | 
 | #define CONTROL_LEN			0x000000000000ffffULL | 
 | #define CONTROL_LEN_SHIFT		0 | 
 | #define CONTROL_HMAC_KEY_LEN		0x0000000000ff0000ULL | 
 | #define CONTROL_HMAC_KEY_LEN_SHIFT	16 | 
 | #define CONTROL_ENC_TYPE		0x00000000ff000000ULL | 
 | #define CONTROL_ENC_TYPE_SHIFT		24 | 
 | #define  ENC_TYPE_ALG_RC4_STREAM	0x00ULL | 
 | #define  ENC_TYPE_ALG_RC4_NOSTREAM	0x04ULL | 
 | #define  ENC_TYPE_ALG_DES		0x08ULL | 
 | #define  ENC_TYPE_ALG_3DES		0x0cULL | 
 | #define  ENC_TYPE_ALG_AES128		0x10ULL | 
 | #define  ENC_TYPE_ALG_AES192		0x14ULL | 
 | #define  ENC_TYPE_ALG_AES256		0x18ULL | 
 | #define  ENC_TYPE_ALG_RESERVED		0x1cULL | 
 | #define  ENC_TYPE_ALG_MASK		0x1cULL | 
 | #define  ENC_TYPE_CHAINING_ECB		0x00ULL | 
 | #define  ENC_TYPE_CHAINING_CBC		0x01ULL | 
 | #define  ENC_TYPE_CHAINING_CFB		0x02ULL | 
 | #define  ENC_TYPE_CHAINING_COUNTER	0x03ULL | 
 | #define  ENC_TYPE_CHAINING_MASK		0x03ULL | 
 | #define CONTROL_AUTH_TYPE		0x0000001f00000000ULL | 
 | #define CONTROL_AUTH_TYPE_SHIFT		32 | 
 | #define  AUTH_TYPE_RESERVED		0x00ULL | 
 | #define  AUTH_TYPE_MD5			0x01ULL | 
 | #define  AUTH_TYPE_SHA1			0x02ULL | 
 | #define  AUTH_TYPE_SHA256		0x03ULL | 
 | #define  AUTH_TYPE_CRC32		0x04ULL | 
 | #define  AUTH_TYPE_HMAC_MD5		0x05ULL | 
 | #define  AUTH_TYPE_HMAC_SHA1		0x06ULL | 
 | #define  AUTH_TYPE_HMAC_SHA256		0x07ULL | 
 | #define  AUTH_TYPE_TCP_CHECKSUM		0x08ULL | 
 | #define  AUTH_TYPE_SSL_HMAC_MD5		0x09ULL | 
 | #define  AUTH_TYPE_SSL_HMAC_SHA1	0x0aULL | 
 | #define  AUTH_TYPE_SSL_HMAC_SHA256	0x0bULL | 
 | #define CONTROL_STRAND			0x000000e000000000ULL | 
 | #define CONTROL_STRAND_SHIFT		37 | 
 | #define CONTROL_HASH_LEN		0x0000ff0000000000ULL | 
 | #define CONTROL_HASH_LEN_SHIFT		40 | 
 | #define CONTROL_INTERRUPT		0x0001000000000000ULL | 
 | #define CONTROL_STORE_FINAL_AUTH_STATE	0x0002000000000000ULL | 
 | #define CONTROL_RESERVED		0x001c000000000000ULL | 
 | #define CONTROL_HV_DONE			0x0004000000000000ULL | 
 | #define CONTROL_HV_PROTOCOL_ERROR	0x0008000000000000ULL | 
 | #define CONTROL_HV_HARDWARE_ERROR	0x0010000000000000ULL | 
 | #define CONTROL_END_OF_BLOCK		0x0020000000000000ULL | 
 | #define CONTROL_START_OF_BLOCK		0x0040000000000000ULL | 
 | #define CONTROL_ENCRYPT			0x0080000000000000ULL | 
 | #define CONTROL_OPCODE			0xff00000000000000ULL | 
 | #define CONTROL_OPCODE_SHIFT		56 | 
 | #define  OPCODE_INPLACE_BIT		0x80ULL | 
 | #define  OPCODE_SSL_KEYBLOCK		0x10ULL | 
 | #define  OPCODE_COPY			0x20ULL | 
 | #define  OPCODE_ENCRYPT			0x40ULL | 
 | #define  OPCODE_AUTH_MAC		0x41ULL | 
 |  | 
 | #endif /* !(__ASSEMBLY__) */ | 
 |  | 
 | /* NCS v2.0 hypervisor interfaces */ | 
 | #define HV_NCS_QTYPE_MAU		0x01 | 
 | #define HV_NCS_QTYPE_CWQ		0x02 | 
 |  | 
 | /* ncs_qconf() | 
 |  * TRAP:	HV_FAST_TRAP | 
 |  * FUNCTION:	HV_FAST_NCS_QCONF | 
 |  * ARG0:	Queue type (HV_NCS_QTYPE_{MAU,CWQ}) | 
 |  * ARG1:	Real address of queue, or handle for unconfigure | 
 |  * ARG2:	Number of entries in queue, zero for unconfigure | 
 |  * RET0:	status | 
 |  * RET1:	queue handle | 
 |  * | 
 |  * Configure a queue in the stream processing unit. | 
 |  * | 
 |  * The real address given as the base must be 64-byte | 
 |  * aligned. | 
 |  * | 
 |  * The queue size can range from a minimum of 2 to a maximum | 
 |  * of 64.  The queue size must be a power of two. | 
 |  * | 
 |  * To unconfigure a queue, specify a length of zero and place | 
 |  * the queue handle into ARG1. | 
 |  * | 
 |  * On configure success the hypervisor will set the FIRST, HEAD, | 
 |  * and TAIL registers to the address of the first entry in the | 
 |  * queue.  The LAST register will be set to point to the last | 
 |  * entry in the queue. | 
 |  */ | 
 | #define HV_FAST_NCS_QCONF		0x111 | 
 |  | 
 | /* ncs_qinfo() | 
 |  * TRAP:	HV_FAST_TRAP | 
 |  * FUNCTION:	HV_FAST_NCS_QINFO | 
 |  * ARG0:	Queue handle | 
 |  * RET0:	status | 
 |  * RET1:	Queue type (HV_NCS_QTYPE_{MAU,CWQ}) | 
 |  * RET2:	Queue base address | 
 |  * RET3:	Number of entries | 
 |  */ | 
 | #define HV_FAST_NCS_QINFO		0x112 | 
 |  | 
 | /* ncs_gethead() | 
 |  * TRAP:	HV_FAST_TRAP | 
 |  * FUNCTION:	HV_FAST_NCS_GETHEAD | 
 |  * ARG0:	Queue handle | 
 |  * RET0:	status | 
 |  * RET1:	queue head offset | 
 |  */ | 
 | #define HV_FAST_NCS_GETHEAD		0x113 | 
 |  | 
 | /* ncs_gettail() | 
 |  * TRAP:	HV_FAST_TRAP | 
 |  * FUNCTION:	HV_FAST_NCS_GETTAIL | 
 |  * ARG0:	Queue handle | 
 |  * RET0:	status | 
 |  * RET1:	queue tail offset | 
 |  */ | 
 | #define HV_FAST_NCS_GETTAIL		0x114 | 
 |  | 
 | /* ncs_settail() | 
 |  * TRAP:	HV_FAST_TRAP | 
 |  * FUNCTION:	HV_FAST_NCS_SETTAIL | 
 |  * ARG0:	Queue handle | 
 |  * ARG1:	New tail offset | 
 |  * RET0:	status | 
 |  */ | 
 | #define HV_FAST_NCS_SETTAIL		0x115 | 
 |  | 
 | /* ncs_qhandle_to_devino() | 
 |  * TRAP:	HV_FAST_TRAP | 
 |  * FUNCTION:	HV_FAST_NCS_QHANDLE_TO_DEVINO | 
 |  * ARG0:	Queue handle | 
 |  * RET0:	status | 
 |  * RET1:	devino | 
 |  */ | 
 | #define HV_FAST_NCS_QHANDLE_TO_DEVINO	0x116 | 
 |  | 
 | /* ncs_sethead_marker() | 
 |  * TRAP:	HV_FAST_TRAP | 
 |  * FUNCTION:	HV_FAST_NCS_SETHEAD_MARKER | 
 |  * ARG0:	Queue handle | 
 |  * ARG1:	New head offset | 
 |  * RET0:	status | 
 |  */ | 
 | #define HV_FAST_NCS_SETHEAD_MARKER	0x117 | 
 |  | 
 | #ifndef __ASSEMBLY__ | 
 | extern unsigned long sun4v_ncs_qconf(unsigned long queue_type, | 
 | 				     unsigned long queue_ra, | 
 | 				     unsigned long num_entries, | 
 | 				     unsigned long *qhandle); | 
 | extern unsigned long sun4v_ncs_qinfo(unsigned long qhandle, | 
 | 				     unsigned long *queue_type, | 
 | 				     unsigned long *queue_ra, | 
 | 				     unsigned long *num_entries); | 
 | extern unsigned long sun4v_ncs_gethead(unsigned long qhandle, | 
 | 				       unsigned long *head); | 
 | extern unsigned long sun4v_ncs_gettail(unsigned long qhandle, | 
 | 				       unsigned long *tail); | 
 | extern unsigned long sun4v_ncs_settail(unsigned long qhandle, | 
 | 				       unsigned long tail); | 
 | extern unsigned long sun4v_ncs_qhandle_to_devino(unsigned long qhandle, | 
 | 						 unsigned long *devino); | 
 | extern unsigned long sun4v_ncs_sethead_marker(unsigned long qhandle, | 
 | 					      unsigned long head); | 
 | #endif /* !(__ASSEMBLY__) */ | 
 |  | 
 | #endif /* _N2_CORE_H */ |