summaryrefslogtreecommitdiff
path: root/drivers/crypto/msm/qcryptohw_30.h
blob: 3c18ed2a097a9f08dad20005436cbe00ce9a4bcb (plain)
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
/* Copyright (c)2009- 2011, The Linux Foundation. All rights reserved.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 and
 * only version 2 as published by the Free Software Foundation.
 *
 * 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.
 */

#ifndef _DRIVERS_CRYPTO_MSM_QCRYPTOHW_30_H_
#define _DRIVERS_CRYPTO_MSM_QCRYPTOHW_30_H_

#define QCE_AUTH_REG_BYTE_COUNT 2
#define CRYPTO_DATA_IN_REG			0x0
#define CRYPTO_DATA_OUT_REG			0x10
#define CRYPTO_STATUS_REG			0x20
#define CRYPTO_CONFIG_REG			0x24
#define CRYPTO_DEBUG_REG			0x28
#define CRYPTO_REGISTER_LOCK_REG		0x2C
#define CRYPTO_SEG_CFG_REG			0x30
#define CRYPTO_ENCR_SEG_CFG_REG			0x34
#define CRYPTO_AUTH_SEG_CFG_REG			0x38
#define CRYPTO_SEG_SIZE_REG			0x3C
#define CRYPTO_GOPROC_REG			0x40
#define CRYPTO_ENGINES_AVAIL			0x44

#define CRYPTO_DES_KEY0_REG			0x50
#define CRYPTO_DES_KEY1_REG			0x54
#define CRYPTO_DES_KEY2_REG			0x58
#define CRYPTO_DES_KEY3_REG			0x5C
#define CRYPTO_DES_KEY4_REG			0x60
#define CRYPTO_DES_KEY5_REG			0x64

#define CRYPTO_CNTR0_IV0_REG			0x70
#define CRYPTO_CNTR1_IV1_REG			0x74
#define CRYPTO_CNTR2_IV2_REG			0x78
#define CRYPTO_CNTR3_IV3_REG			0x7C
#define CRYPTO_CNTR_MASK_REG			0x80

#define CRYPTO_AUTH_BYTECNT0_REG		0x90
#define CRYPTO_AUTH_BYTECNT1_REG		0x94
#define CRYPTO_AUTH_BYTECNT2_REG		0x98
#define CRYPTO_AUTH_BYTECNT3_REG		0x9C

#define CRYPTO_AUTH_IV0_REG			0x100
#define CRYPTO_AUTH_IV1_REG			0x104
#define CRYPTO_AUTH_IV2_REG			0x108
#define CRYPTO_AUTH_IV3_REG			0x10C
#define CRYPTO_AUTH_IV4_REG			0x110
#define CRYPTO_AUTH_IV5_REG			0x114
#define CRYPTO_AUTH_IV6_REG			0x118
#define CRYPTO_AUTH_IV7_REG			0x11C
#define CRYPTO_AUTH_IV8_REG			0x120
#define CRYPTO_AUTH_IV9_REG			0x124
#define CRYPTO_AUTH_IV10_REG			0x128
#define CRYPTO_AUTH_IV11_REG			0x12C
#define CRYPTO_AUTH_IV12_REG			0x130
#define CRYPTO_AUTH_IV13_REG			0x134
#define CRYPTO_AUTH_IV14_REG			0x138
#define CRYPTO_AUTH_IV15_REG			0x13C

#define CRYPTO_AES_RNDKEY0			0x200
#define CRYPTO_AES_RNDKEY1			0x204
#define CRYPTO_AES_RNDKEY2			0x208
#define CRYPTO_AES_RNDKEY3			0x20C
#define CRYPTO_AES_RNDKEY4			0x210
#define CRYPTO_AES_RNDKEY5			0x214
#define CRYPTO_AES_RNDKEY6			0x218
#define CRYPTO_AES_RNDKEY7			0x21C
#define CRYPTO_AES_RNDKEY8			0x220
#define CRYPTO_AES_RNDKEY9			0x224
#define CRYPTO_AES_RNDKEY10			0x228
#define CRYPTO_AES_RNDKEY11			0x22c
#define CRYPTO_AES_RNDKEY12			0x230
#define CRYPTO_AES_RNDKEY13			0x234
#define CRYPTO_AES_RNDKEY14			0x238
#define CRYPTO_AES_RNDKEY15			0x23C
#define CRYPTO_AES_RNDKEY16			0x240
#define CRYPTO_AES_RNDKEY17			0x244
#define CRYPTO_AES_RNDKEY18			0x248
#define CRYPTO_AES_RNDKEY19			0x24C
#define CRYPTO_AES_RNDKEY20			0x250
#define CRYPTO_AES_RNDKEY21			0x254
#define CRYPTO_AES_RNDKEY22			0x258
#define CRYPTO_AES_RNDKEY23			0x25C
#define CRYPTO_AES_RNDKEY24			0x260
#define CRYPTO_AES_RNDKEY25			0x264
#define CRYPTO_AES_RNDKEY26			0x268
#define CRYPTO_AES_RNDKEY27			0x26C
#define CRYPTO_AES_RNDKEY28			0x270
#define CRYPTO_AES_RNDKEY29			0x274
#define CRYPTO_AES_RNDKEY30			0x278
#define CRYPTO_AES_RNDKEY31			0x27C
#define CRYPTO_AES_RNDKEY32			0x280
#define CRYPTO_AES_RNDKEY33			0x284
#define CRYPTO_AES_RNDKEY34			0x288
#define CRYPTO_AES_RNDKEY35			0x28c
#define CRYPTO_AES_RNDKEY36			0x290
#define CRYPTO_AES_RNDKEY37			0x294
#define CRYPTO_AES_RNDKEY38			0x298
#define CRYPTO_AES_RNDKEY39			0x29C
#define CRYPTO_AES_RNDKEY40			0x2A0
#define CRYPTO_AES_RNDKEY41			0x2A4
#define CRYPTO_AES_RNDKEY42			0x2A8
#define CRYPTO_AES_RNDKEY43			0x2AC
#define CRYPTO_AES_RNDKEY44			0x2B0
#define CRYPTO_AES_RNDKEY45			0x2B4
#define CRYPTO_AES_RNDKEY46			0x2B8
#define CRYPTO_AES_RNDKEY47			0x2BC
#define CRYPTO_AES_RNDKEY48			0x2C0
#define CRYPTO_AES_RNDKEY49			0x2C4
#define CRYPTO_AES_RNDKEY50			0x2C8
#define CRYPTO_AES_RNDKEY51			0x2CC
#define CRYPTO_AES_RNDKEY52			0x2D0
#define CRYPTO_AES_RNDKEY53			0x2D4
#define CRYPTO_AES_RNDKEY54			0x2D8
#define CRYPTO_AES_RNDKEY55			0x2DC
#define CRYPTO_AES_RNDKEY56			0x2E0
#define CRYPTO_AES_RNDKEY57			0x2E4
#define CRYPTO_AES_RNDKEY58			0x2E8
#define CRYPTO_AES_RNDKEY59			0x2EC

#define CRYPTO_DATA_SHADOW0			0x8000
#define CRYPTO_DATA_SHADOW8191			0x8FFC

/* status reg  */
#define CRYPTO_CORE_REV				28	/* bit 31-28 */
#define CRYPTO_CORE_REV_MASK			(0xf << CRYPTO_CORE_REV)
#define CRYPTO_DOUT_SIZE_AVAIL			22	/* bit 24-22 */
#define CRYPTO_DOUT_SIZE_AVAIL_MASK		(0x7 << CRYPTO_DOUT_SIZE_AVAIL)
#define CRYPTO_DIN_SIZE_AVAIL			19	/* bit 21-19 */
#define CRYPTO_DIN_SIZE_AVAIL_MASK		(0x7 << CRYPTO_DIN_SIZE_AVAIL)
#define CRYPTO_ACCESS_VIOL			18
#define CRYPTO_SEG_CHNG_ERR			17
#define CRYPTO_CFH_CHNG_ERR			16
#define CRYPTO_DOUT_ERR				15
#define CRYPTO_DIN_ERR				14
#define CRYPTO_LOCKED				13
#define CRYPTO_CRYPTO_STATE			10	/* bit 12-10 */
#define CRYPTO_CRYPTO_STATE_MASK		(0x7 << CRYPTO_CRYPTO_STATE)
#define CRYPTO_ENCR_BUSY			9
#define CRYPTO_AUTH_BUSY			8
#define CRYPTO_DOUT_INTR			7
#define CRYPTO_DIN_INTR				6
#define CRYPTO_AUTH_DONE_INTR			5
#define CRYPTO_ERR_INTR				4
#define CRYPTO_DOUT_RDY				3
#define CRYPTO_DIN_RDY				2
#define CRYPTO_AUTH_DONE			1
#define CRYPTO_SW_ERR				0

#define CRYPTO_CRYPTO_STATE_IDLE		0
#define CRYPTO_CRYPTO_STATE_LOCKED		1
#define CRYPTO_CRYPTO_STATE_GO			3
#define CRYPTO_CRYPTO_STATE_PROCESSING		4
#define CRYPTO_CRYPTO_STATE_FINAL_READ		5
#define CRYPTO_CRYPTO_STATE_CTXT_CLEARING	6
#define CRYPTO_CRYPTO_STATE_UNLOCKING		7

/* config reg */
#define CRYPTO_HIGH_SPD_HASH_EN_N		15
#define CRYPTO_HIGH_SPD_OUT_EN_N		14
#define CRYPTO_HIGH_SPD_IN_EN_N			13
#define CRYPTO_DBG_EN				12
#define CRYPTO_DBG_SEL				7	/* bit 11:7 */
#define CRYPTO_DBG_SEL_MASK			(0x1F << CRYPTO_DBG_SEL)
#define CRYPTO_MASK_DOUT_INTR			6
#define CRYPTO_MASK_DIN_INTR			5
#define CRYPTO_MASK_AUTH_DONE_INTR		4
#define CRYPTO_MASK_ERR_INTR			3
#define CRYPTO_AUTO_SHUTDOWN_EN			2
#define CRYPTO_CLK_EN_N				1
#define CRYPTO_SW_RST				0

/* seg_cfg reg */
#define CRYPTO_F8_KEYSTREAM_ENABLE		25
#define CRYPTO_F9_DIRECTION			24
#define CRYPTO_F8_DIRECTION			23
#define CRYPTO_USE_HW_KEY			22

#define CRYPTO_CNTR_ALG				20	/* bit 21-20 */
#define CRYPTO_CNTR_ALG_MASK			(3 << efine CRYPTO_CNTR_ALG)

#define CRYPTO_CLR_CNTXT			19
#define CRYPTO_LAST				18
#define CRYPTO_FIRST				17
#define CRYPTO_ENCODE				16

#define CRYPTO_AUTH_POS				14	/* bit 15-14 */
#define CRYPTO_AUTH_POS_MASK			(3 << CRYPTO_AUTH_POS)

#define CRYPTO_AUTH_SIZE			11	/* bit 13-11 */
#define CRYPTO_AUTH_SIZE_MASK			(7 << CRYPTO_AUTH_SIZE)

#define CRYPTO_AUTH_ALG				9	/* bit 10-9 */
#define CRYPTO_AUTH_ALG_MASK			(3 << CRYPTO_AUTH_ALG)

#define CRYPTO_ENCR_MODE			6	/* bit 8-6 */
#define CRYPTO_ENCR_MODE_MASK			(7 << CRYPTO_ENCR_MODE)

#define CRYPTO_ENCR_KEY_SZ			3	/* bit 5-3 */
#define CRYPTO_ENCR_KEY_SZ_MASK			(7 << CRYPTO_ENCR_KEY_SZ)

#define CRYPTO_ENCR_ALG				0	/* bit 2-0 */
#define CRYPTO_ENCR_ALG_MASK			(7 << CRYPTO_ENCR_ALG)

#define CRYPTO_CNTR_ALG_NIST			0
#define CRYPTO_CNTR_ALG_UMB			1
#define CRYPTO_CNTR_ALG_VAR2			2

#define CRYPTO_AUTH_POS_BEFORE			0
#define CRYPTO_AUTH_POS_AFTER			1

#define CRYPTO_AUTH_SIZE_SHA1			0
#define CRYPTO_AUTH_SIZE_SHA256			1
#define CRYPTO_AUTH_SIZE_SHA384			2
#define CRYPTO_AUTH_SIZE_SHA512			3
#define CRYPTO_AUTH_SIZE_HMAC_SHA1		4

#define CRYPTO_AUTH_SIZE_UIA1			0
#define CRYPTO_AUTH_SIZE_UIA2			1

#define CRYPTO_AUTH_ALG_NONE			0
#define CRYPTO_AUTH_ALG_SHA			1
#define CRYPTO_AUTH_ALG_F9			2
#define CRYPTO_AUTH_ALG_RESERVED1		3

#define CRYPTO_ENCR_MODE_ECB			0
#define CRYPTO_ENCR_MODE_CBC			1
/* only valid when AES */
#define CRYPTO_ENCR_MODE_CTR			2


#define CRYPTO_ENCR_KEY_SZ_DES			0
#define CRYPTO_ENCR_KEY_SZ_3DES			1

#define CRYPTO_ENCR_KEY_SZ_AES128		0
#define CRYPTO_ENCR_KEY_SZ_AES192		1
#define CRYPTO_ENCR_KEY_SZ_AES256		2

#define CRYPTO_ENCR_KEY_SZ_UEA1			0
#define CRYPTO_ENCR_KEY_SZ_UEA2			1

#define CRYPTO_ENCR_ALG_NONE			0
#define CRYPTO_ENCR_ALG_DES			1
#define CRYPTO_ENCR_ALG_AES			2
#define CRYPTO_ENCR_ALG_C2			3
#define CRYPTO_ENCR_ALG_F8			4

/* encr_seg_cfg reg */
#define CRYPTO_ENCR_SEG_SIZE			16	/* bit 31-16  */
#define CRYPTO_ENCR_SEG_SIZE_MASK		(0xffff << CRYPTO_ENCR_SEG_SIZE)

#define CRYPTO_ENCR_START			0
#define CRYPTO_ENCR_START_MASK			(0xffff << CRYPTO_ENCR_START)

/* auth_seg_cfg reg */
#define CRYPTO_AUTH_SEG_SIZE			16	/* bit 31-16  */
#define CRYPTO_AUTH_SEG_SIZE_MASK		(0xffff << CRYPTO_AUTH_SEG_SIZE)

#define CRYPTO_AUTH_START			0
#define CRYPTO_AUTH_START_MASK			(0xffff << CRYPTO_AUTH_START)


/* seg_size reg */
#define CRYPTO_SEG_SIZE				0
#define CRYPTO_SEG_SIZE_MASK			(0xffff << CRYPTO_SEG_SIZE)

/* goproc reg */
#define CRYPTO_GO				0

/* engines_avail */
#define CRYPTO_F9_SEL				8
#define CRYPTO_F8_SEL				7
#define CRYPTO_HMAC_SEL				6
#define CRYPTO_SHA512_SEL			5
#define CRYPTO_SHA_SEL				4
#define CRYPTO_DES_SEL				3
#define CRYPTO_C2_SEL				2

#define CRYPTO_AES_SEL				0	/* bit 1-0 */
#define CRYPTO_AES_SEL_MASK			(3 <<  CRYPTO_AES_SEL)
#define CRYPTO_AES_SEL_NO			0
#define CRYPTO_AES_SEL_SLOW			1
#define CRYPTO_AES_SEL_FAST			2
#define CRYPTO_AES_SEL_RESERVED			3

/*  F8 definition of CRYPTO_CNTR1_IV1_REG  */
#define CRYPTO_CNTR1_IV1_REG_F8_PKT_CNT		16	/* bit 31 - 16 */
#define CRYPTO_CNTR1_IV1_REG_F8_PKT_CNT_MASK \
		(0xffff << CRYPTO_CNTR1_IV1_REG_F8_PKT_CNT)

#define CRYPTO_CNTR1_IV1_REG_F8_BEARER		0	/* bit 4 - 0 */
#define CRYPTO_CNTR1_IV1_REG_F8_BEARER_MASK \
		(0x1f << CRYPTO_CNTR1_IV1_REG_F8_BEARER)

/* F9 definition of CRYPTO_AUTH_IV4_REG */
#define CRYPTO_AUTH_IV4_REG_F9_VALID_BIS	0	/* bit 2 - 0 */
#define CRYPTO_AUTH_IV4_REG_F9_VALID_BIS_MASK \
		(0x7  << CRYPTO_AUTH_IV4_REG_F9_VALID_BIS)

/* misc  */
#define CRYPTO_AES_RNDKEYS			60

#endif /* _DRIVERS_CRYPTO_MSM_QCRYPTOHW_30_H_ */