rk_v1crypto.h revision 1.1
1/*	$NetBSD: rk_v1crypto.h,v 1.1 2020/05/17 19:57:25 riastradh Exp $	*/
2
3/*-
4 * Copyright (c) 2020 The NetBSD Foundation, Inc.
5 * All rights reserved.
6 *
7 * This code is derived from software contributed to The NetBSD Foundation
8 * by Taylor R. Campbell.
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 *    notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 *    notice, this list of conditions and the following disclaimer in the
17 *    documentation and/or other materials provided with the distribution.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
30 */
31
32#ifndef	_ARM_ROCKCHIP_RK_V1CRYPTO_H
33#define	_ARM_ROCKCHIP_RK_V1CRYPTO_H
34
35#define	RK_V1CRYPTO_INTSTS	0x0000 /* Interrupt Status */
36#define	RK_V1CRYPTO_INTSTS_PKA_DONE	__BIT(5)
37#define	RK_V1CRYPTO_INTSTS_HASH_DONE	__BIT(4)
38#define	RK_V1CRYPTO_INTSTS_HRDMA_ERR	__BIT(3)
39#define	RK_V1CRYPTO_INTSTS_HRDMA_DONE	__BIT(2)
40#define	RK_V1CRYPTO_INTSTS_BCDMA_ERR	__BIT(1)
41#define	RK_V1CRYPTO_INTSTS_BCDMA_DONE	__BIT(0)
42
43#define	RK_V1CRYPTO_INTENA	0x0004 /* Interrupt Enable */
44#define	RK_V1CRYPTO_INTENA_PKA_DONE	__BIT(5)
45#define	RK_V1CRYPTO_INTENA_HASH_DONE	__BIT(4)
46#define	RK_V1CRYPTO_INTENA_HRDMA_ERR	__BIT(3)
47#define	RK_V1CRYPTO_INTENA_HRDMA_DONE	__BIT(2)
48#define	RK_V1CRYPTO_INTENA_BCDMA_ERR	__BIT(1)
49#define	RK_V1CRYPTO_INTENA_BCDMA_DONE	__BIT(0)
50
51#define	RK_V1CRYPTO_CTRL	0x0008 /* Control */
52#define	RK_V1CRYPTO_CTRL_MASK		__BITS(31,16)
53#define	RK_V1CRYPTO_CTRL_TRNG_FLUSH	__BIT(9)
54#define	RK_V1CRYPTO_CTRL_TRNG_START	__BIT(8)
55#define	RK_V1CRYPTO_CTRL_PKA_FLUSH	__BIT(7)
56#define	RK_V1CRYPTO_CTRL_HASH_FLUSH	__BIT(6)
57#define	RK_V1CRYPTO_CTRL_BLOCK_FLUSH	__BIT(5)
58#define	RK_V1CRYPTO_CTRL_PKA_START	__BIT(4)
59#define	RK_V1CRYPTO_CTRL_HASH_START	__BIT(3)
60#define	RK_V1CRYPTO_CTRL_BLOCK_START	__BIT(2)
61#define	RK_V1CRYPTO_CTRL_TDES_START	__BIT(1)
62#define	RK_V1CRYPTO_CTRL_AES_START	__BIT(0)
63
64#define	RK_V1CRYPTO_CONF	0x000c /* ? */
65#define	RK_V1CRYPTO_CONF_HR_ADDR_MODE	__BIT(8)
66#define	RK_V1CRYPTO_CONF_BT_ADDR_MODE	__BIT(7)
67#define	RK_V1CRYPTO_CONF_BR_ADDR_MODE	__BIT(6)
68#define	RK_V1CRYPTO_CONF_MODE_FIX		1
69#define	RK_V1CRYPTO_CONF_MODE_INCR		0
70#define	RK_V1CRYPTO_CONF_BYTESWAP_HRFIFO __BIT(5)
71#define	RK_V1CRYPTO_CONF_BYTESWAP_BTFIFO __BIT(4)
72#define	RK_V1CRYPTO_CONF_BYTESWAP_BRFIFO __BIT(3)
73#define	RK_V1CRYPTO_CONF_DESSEL		__BIT(2)
74#define	RK_V1CRYPTO_CONF_DESSEL_AES		0
75#define	RK_V1CRYPTO_CONF_DESSEL_DES		1 /* 3DES? */
76#define	RK_V1CRYPTO_CONF_HASHINSEL	__BITS(1,0)
77#define	RK_V1CRYPTO_CONF_HASHINSEL_INDEP	0
78#define	RK_V1CRYPTO_CONF_HASHINSEL_BLKIN	1
79#define	RK_V1CRYPTO_CONF_HASHINSEL_BLKOUT	2
80
81#define	RK_V1CRYPTO_BRDMAS	0x0010 /* Block Rx DMA Start */
82#define	RK_V1CRYPTO_BTDMAS	0x0014 /* Block Tx DMA Start */
83#define	RK_V1CRYPTO_BRDMAL	0x0018 /* Block Rx DMA Length */
84#define	RK_V1CRYPTO_BTDMAL	0x0020 /* Block Tx DMA Length */
85#define	RK_V1CRYPTO_HRDMAS	0x001c /* Hash Rx DMA Start */
86#define	RK_V1CRYPTO_HRDMAL	0x0020 /* Hash Rx DMA Length */
87
88#define	RK_V1CRYPTO_AES_CTRL	0x0080 /* AES Control */
89#define	RK_V1CRYPTO_AES_CTRL_BYTESWAP_CNT __BIT(11)
90#define	RK_V1CRYPTO_AES_CTRL_BYTESWAP_KEY __BIT(10)
91#define	RK_V1CRYPTO_AES_CTRL_BYTESWAP_IV __BIT(9)
92#define	RK_V1CRYPTO_AES_CTRL_BYTESWAP_DO __BIT(8)
93#define	RK_V1CRYPTO_AES_CTRL_BYTESWAP_DI __BIT(7)
94#define	RK_V1CRYPTO_AES_CTRL_KEYCHANGE	__BIT(6)
95#define	RK_V1CRYPTO_AES_CTRL_MODE	__BITS(5,4)
96#define	RK_V1CRYPTO_AES_CTRL_MODE_ECB		0
97#define	RK_V1CRYPTO_AES_CTRL_MODE_CBC		1
98#define	RK_V1CRYPTO_AES_CTRL_MODE_CTR		2
99#define	RK_V1CRYPTO_AES_CTRL_KEYSIZE	__BITS(3,2)
100#define	RK_V1CRYPTO_AES_CTRL_KEYSIZE_128	0
101#define	RK_V1CRYPTO_AES_CTRL_KEYSIZE_192	1
102#define	RK_V1CRYPTO_AES_CTRL_KEYSIZE_256	2
103#define	RK_V1CRYPTO_AES_CTRL_FIFOMODE	__BIT(1)
104#define	RK_V1CRYPTO_AES_CTRL_DIR	__BIT(0)
105#define	RK_V1CRYPTO_AES_CTRL_DIR_ENC		0
106#define	RK_V1CRYPTO_AES_CTRL_DIR_DEC		1
107
108#define	RK_V1CRYPTO_AES_STS	0x0084 /* AES Status */
109#define	RK_V1CRYPTO_AES_STS_DONE	__BIT(0)
110
111#define	RK_V1CRYPTO_AES_DIN(n)  (0x0088 + 4*(n)) /* AES Input */
112#define	RK_V1CRYPTO_AES_DOUT(n) (0x0098 + 4*(n)) /* AES Output */
113#define	RK_V1CRYPTO_AES_IV(n)   (0x00a8 + 4*(n)) /* AES IV */
114#define	RK_V1CRYPTO_AES_KEY(n)  (0x00b8 + 4*(n)) /* AES Key */
115#define	RK_V1CRYPTO_AES_CNT(n)  (0x00d8 + 4*(n)) /* AES Input Counter */
116
117#define	RK_V1CRYPTO_TDES_CTRL	0x0100 /* 3DES Control */
118#define	RK_V1CRYPTO_TDES_CTRL_BYTESWAP_KEY __BIT(8)
119#define	RK_V1CRYPTO_TDES_CTRL_BYTESWAP_IV __BIT(7)
120#define	RK_V1CRYPTO_TDES_CTRL_BYTESWAP_DO __BIT(6)
121#define	RK_V1CRYPTO_TDES_CTRL_BYTESWAP_DI __BIT(5)
122#define	RK_V1CRYPTO_TDES_CTRL_MODE	__BIT(4)
123#define	RK_V1CRYPTO_TDES_CTRL_MODE_ECB		0
124#define	RK_V1CRYPTO_TDES_CTRL_MODE_CBC		1
125#define	RK_V1CRYPTO_TDES_CTRL_KEYMODE	__BIT(3)
126#define	RK_V1CRYPTO_TDES_CTRL_KEYMODE_EDE	0
127#define	RK_V1CRYPTO_TDES_CTRL_KEYMODE_EEE	1
128#define	RK_V1CRYPTO_TDES_CTRL_SELECT	__BIT(2)
129#define	RK_V1CRYPTO_TDES_CTRL_SELECT_DES	0
130#define	RK_V1CRYPTO_TDES_CTRL_SELECT_TDES	1
131#define	RK_V1CRYPTO_TDES_CTRL_FIFOMODE	__BIT(1)
132#define	RK_V1CRYPTO_TDES_CTRL_DIR	__BIT(0)
133#define	RK_V1CRYPTO_TDES_CTRL_DIR_ENC		0
134#define	RK_V1CRYPTO_TDES_CTRL_DIR_DEC		1
135
136#define	RK_V1CRYPTO_TDES_STS	0x0104 /* 3DES Status */
137#define	RK_V1CRYPTO_TDES_STS_DONE	__BIT(0)
138
139#define	RK_V1CRYPTO_TDES_DIN(n) (0x0108 + 4*(n)) /* 3DES Input */
140#define	RK_V1CRYPTO_TDES_DOUT(n)(0x0110 + 4*(n)) /* 3DES Output */
141#define	RK_V1CRYPTO_TDES_IV(n)  (0x0118 + 4*(n)) /* 3DES IV */
142#define	RK_V1CRYPTO_TDES_KEY(n) (0x0120 + 4*(n)) /* 3DES Key(1,2,3) */
143
144#define	RK_V1CRYPTO_HASH_CTRL	0x0180 /* Hash Control */
145#define	RK_V1CRYPTO_HASH_SWAP_DO	__BIT(3)
146#define	RK_V1CRYPTO_HASH_SWAP_DI	__BIT(2)
147#define	RK_V1CRYPTO_HASH_SELECT		__BITS(1,0)
148#define	RK_V1CRYPTO_HASH_SELECT_SHA1		0
149#define	RK_V1CRYPTO_HASH_SELECT_MD5		1
150#define	RK_V1CRYPTO_HASH_SELECT_SHA256		2
151#define	RK_V1CRYPTO_HASH_SELECT_PRNG		3 /* ??? */
152
153#define	RK_V1CRYPTO_HASH_STS	0x0184 /* Hash Status */
154#define	RK_V1CRYPTO_HASH_STS_DONE	__BIT(0)
155
156#define	RK_V1CRYPTO_HASH_MSG_LEN	0x0188 /* Hash Message Len */
157#define	RK_V1CRYPTO_HASH_DOUT(n)(0x018c + 4*(n)) /* Hash Result */
158#define	RK_V1CRYPTO_HASH_SEED(n)(0x01ac + 4*(n)) /* HMAC/PRNG key */
159
160#define	RK_V1CRYPTO_TRNG_CTRL	0x0200 /* TRNG Control */
161#define	RK_V1CRYPTO_TRNG_CTRL_OSC_ENABLE __BIT(16)
162#define	RK_V1CRYPTO_TRNG_CTRL_CYCLES	__BITS(15,0)
163
164#define	RK_V1CRYPTO_TRNG_DOUT(n)(0x0204 + 4*(n)) /* TRNG Output */
165#define	RK_V1CRYPTO_TRNG_NOUT		8	/* up to 8 32-bit */
166
167#define	RK_V1CRYPTO_PKA_CTRL	0x0280 /* PKA Control (RSA?) */
168#define	RK_V1CRYPTO_PKA_CTRL_SIZE	__BITS(1,0)
169#define	RK_V1CRYPTO_PKA_CTRL_SIZE_512		0
170#define	RK_V1CRYPTO_PKA_CTRL_SIZE_1024		1
171#define	RK_V1CRYPTO_PKA_CTRL_SIZE_2048		2
172
173#define	RK_V1CRYPTO_M		0x0400 /* RSA `message' */
174#define	RK_V1CRYPTO_C		0x0500 /* 2^(2 ceil(lg n) + 2) mod n */
175#define	RK_V1CRYPTO_N		0x0600 /* RSA modulus? */
176#define	RK_V1CRYPTO_E		0x0700 /* RSA exponent? */
177
178#endif	/* _ARM_ROCKCHIP_RK_V1CRYPTO_H */
179