summaryrefslogtreecommitdiff
path: root/drivers/s390/crypto/zcrypt_pcixcc.h
blob: a78ff307fd191d22a67ef9dc017f6b8af309d517 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
 *  linux/drivers/s390/crypto/zcrypt_pcixcc.h
 *
 *  zcrypt 2.1.0
 *
 *  Copyright (C)  2001, 2006 IBM Corporation
 *  Author(s): Robert Burroughs
 *	       Eric Rossman (edrossma@us.ibm.com)
 *
 *  Hotplug & misc device support: Jochen Roehrig (roehrig@de.ibm.com)
 *  Major cleanup & driver split: Martin Schwidefsky <schwidefsky@de.ibm.com>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2, or (at your option)
 * any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */

#ifndef _ZCRYPT_PCIXCC_H_
#define _ZCRYPT_PCIXCC_H_

/**
 * CPRBX
 *	  Note that all shorts and ints are big-endian.
 *	  All pointer fields are 16 bytes long, and mean nothing.
 *
 *	  A request CPRB is followed by a request_parameter_block.
 *
 *	  The request (or reply) parameter block is organized thus:
 *	    function code
 *	    VUD block
 *	    key block
 */
struct CPRBX {
	unsigned short cprb_len;	/* CPRB length	      220	 */
	unsigned char  cprb_ver_id;	/* CPRB version id.   0x02	 */
	unsigned char  pad_000[3];	/* Alignment pad bytes		 */
	unsigned char  func_id[2];	/* function id	      0x5432	 */
	unsigned char  cprb_flags[4];	/* Flags			 */
	unsigned int   req_parml;	/* request parameter buffer len	 */
	unsigned int   req_datal;	/* request data buffer		 */
	unsigned int   rpl_msgbl;	/* reply  message block length	 */
	unsigned int   rpld_parml;	/* replied parameter block len	 */
	unsigned int   rpl_datal;	/* reply data block len		 */
	unsigned int   rpld_datal;	/* replied data block len	 */
	unsigned int   req_extbl;	/* request extension block len	 */
	unsigned char  pad_001[4];	/* reserved			 */
	unsigned int   rpld_extbl;	/* replied extension block len	 */
	unsigned char  req_parmb[16];	/* request parm block 'address'	 */
	unsigned char  req_datab[16];	/* request data block 'address'	 */
	unsigned char  rpl_parmb[16];	/* reply parm block 'address'	 */
	unsigned char  rpl_datab[16];	/* reply data block 'address'	 */
	unsigned char  req_extb[16];	/* request extension block 'addr'*/
	unsigned char  rpl_extb[16];	/* reply extension block 'addres'*/
	unsigned short ccp_rtcode;	/* server return code		 */
	unsigned short ccp_rscode;	/* server reason code		 */
	unsigned int   mac_data_len;	/* Mac Data Length		 */
	unsigned char  logon_id[8];	/* Logon Identifier		 */
	unsigned char  mac_value[8];	/* Mac Value			 */
	unsigned char  mac_content_flgs;/* Mac content flag byte	 */
	unsigned char  pad_002;		/* Alignment			 */
	unsigned short domain;		/* Domain			 */
	unsigned char  pad_003[12];	/* Domain masks			 */
	unsigned char  pad_004[36];	/* reserved			 */
} __attribute__((packed));

int zcrypt_pcixcc_init(void);
void zcrypt_pcixcc_exit(void);

#endif /* _ZCRYPT_PCIXCC_H_ */