xref: /dflybsd-src/sys/dev/crypto/ubsec/ubsecreg.h (revision 86d7f5d305c6adaa56ff4582ece9859d73106103)
1*86d7f5d3SJohn Marino /* $FreeBSD: src/sys/dev/ubsec/ubsecreg.h,v 1.2.2.4 2003/06/04 17:05:11 sam Exp $ */
2*86d7f5d3SJohn Marino /* $DragonFly: src/sys/dev/crypto/ubsec/ubsecreg.h,v 1.2 2003/06/17 04:28:32 dillon Exp $ */
3*86d7f5d3SJohn Marino /*	$OpenBSD: ubsecreg.h,v 1.27 2002/09/11 22:40:31 jason Exp $	*/
4*86d7f5d3SJohn Marino 
5*86d7f5d3SJohn Marino /*
6*86d7f5d3SJohn Marino  * Copyright (c) 2000 Theo de Raadt
7*86d7f5d3SJohn Marino  * Copyright (c) 2001 Patrik Lindergren (patrik@ipunplugged.com)
8*86d7f5d3SJohn Marino  *
9*86d7f5d3SJohn Marino  * Redistribution and use in source and binary forms, with or without
10*86d7f5d3SJohn Marino  * modification, are permitted provided that the following conditions
11*86d7f5d3SJohn Marino  * are met:
12*86d7f5d3SJohn Marino  *
13*86d7f5d3SJohn Marino  * 1. Redistributions of source code must retain the above copyright
14*86d7f5d3SJohn Marino  *    notice, this list of conditions and the following disclaimer.
15*86d7f5d3SJohn Marino  * 2. Redistributions in binary form must reproduce the above copyright
16*86d7f5d3SJohn Marino  *    notice, this list of conditions and the following disclaimer in the
17*86d7f5d3SJohn Marino  *    documentation and/or other materials provided with the distribution.
18*86d7f5d3SJohn Marino  * 3. The name of the author may not be used to endorse or promote products
19*86d7f5d3SJohn Marino  *    derived from this software without specific prior written permission.
20*86d7f5d3SJohn Marino  *
21*86d7f5d3SJohn Marino  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22*86d7f5d3SJohn Marino  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23*86d7f5d3SJohn Marino  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24*86d7f5d3SJohn Marino  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25*86d7f5d3SJohn Marino  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26*86d7f5d3SJohn Marino  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27*86d7f5d3SJohn Marino  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28*86d7f5d3SJohn Marino  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29*86d7f5d3SJohn Marino  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30*86d7f5d3SJohn Marino  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31*86d7f5d3SJohn Marino  *
32*86d7f5d3SJohn Marino  * Effort sponsored in part by the Defense Advanced Research Projects
33*86d7f5d3SJohn Marino  * Agency (DARPA) and Air Force Research Laboratory, Air Force
34*86d7f5d3SJohn Marino  * Materiel Command, USAF, under agreement number F30602-01-2-0537.
35*86d7f5d3SJohn Marino  *
36*86d7f5d3SJohn Marino  */
37*86d7f5d3SJohn Marino 
38*86d7f5d3SJohn Marino /*
39*86d7f5d3SJohn Marino  * Register definitions for 5601 BlueSteel Networks Ubiquitous Broadband
40*86d7f5d3SJohn Marino  * Security "uBSec" chip.  Definitions from revision 2.8 of the product
41*86d7f5d3SJohn Marino  * datasheet.
42*86d7f5d3SJohn Marino  */
43*86d7f5d3SJohn Marino 
44*86d7f5d3SJohn Marino #define BS_BAR			0x10	/* DMA base address register */
45*86d7f5d3SJohn Marino #define	BS_TRDY_TIMEOUT		0x40	/* TRDY timeout */
46*86d7f5d3SJohn Marino #define	BS_RETRY_TIMEOUT	0x41	/* DMA retry timeout */
47*86d7f5d3SJohn Marino 
48*86d7f5d3SJohn Marino #define	PCI_VENDOR_BROADCOM	0x14e4		/* Broadcom */
49*86d7f5d3SJohn Marino #define	PCI_VENDOR_BLUESTEEL	0x15ab		/* Bluesteel Networks */
50*86d7f5d3SJohn Marino #define	PCI_VENDOR_SUN		0x108e		/* Sun Microsystems */
51*86d7f5d3SJohn Marino 
52*86d7f5d3SJohn Marino /* Bluesteel Networks */
53*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BLUESTEEL_5501	0x0000		/* 5501 */
54*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BLUESTEEL_5601	0x5601		/* 5601 */
55*86d7f5d3SJohn Marino 
56*86d7f5d3SJohn Marino /* Broadcom */
57*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_BCM5700	0x1644		/* BCM5700 */
58*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_BCM5701	0x1645		/* BCM5701 */
59*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_5801	0x5801		/* 5801 */
60*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_5802	0x5802		/* 5802 */
61*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_5805	0x5805		/* 5805 */
62*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_5820	0x5820		/* 5820 */
63*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_5821	0x5821		/* 5821 */
64*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_5822	0x5822		/* 5822 */
65*86d7f5d3SJohn Marino #define	PCI_PRODUCT_BROADCOM_5823	0x5823		/* 5823 */
66*86d7f5d3SJohn Marino #define PCI_PRODUCT_BROADCOM_5825	0x5825		/* 5825 */
67*86d7f5d3SJohn Marino 
68*86d7f5d3SJohn Marino /* Sun Microsystems */
69*86d7f5d3SJohn Marino #define PCI_PRODUCT_SUN_5821		0x5454		/* Crypto 5821 */
70*86d7f5d3SJohn Marino #define PCI_PRODUCT_SUN_SCA1K		0x5455		/* Crypto 1K */
71*86d7f5d3SJohn Marino 
72*86d7f5d3SJohn Marino #define	UBS_PCI_RTY_SHIFT			8
73*86d7f5d3SJohn Marino #define	UBS_PCI_RTY_MASK			0xff
74*86d7f5d3SJohn Marino #define	UBS_PCI_RTY(misc) \
75*86d7f5d3SJohn Marino     (((misc) >> UBS_PCI_RTY_SHIFT) & UBS_PCI_RTY_MASK)
76*86d7f5d3SJohn Marino 
77*86d7f5d3SJohn Marino #define	UBS_PCI_TOUT_SHIFT			0
78*86d7f5d3SJohn Marino #define	UBS_PCI_TOUT_MASK			0xff
79*86d7f5d3SJohn Marino #define	UBS_PCI_TOUT(misc) \
80*86d7f5d3SJohn Marino     (((misc) >> PCI_TOUT_SHIFT) & PCI_TOUT_MASK)
81*86d7f5d3SJohn Marino 
82*86d7f5d3SJohn Marino /*
83*86d7f5d3SJohn Marino  * DMA Control & Status Registers (offset from BS_BAR)
84*86d7f5d3SJohn Marino  */
85*86d7f5d3SJohn Marino #define	BS_MCR1		0x00	/* DMA Master Command Record 1 */
86*86d7f5d3SJohn Marino #define	BS_CTRL		0x04	/* DMA Control */
87*86d7f5d3SJohn Marino #define	BS_STAT		0x08	/* DMA Status */
88*86d7f5d3SJohn Marino #define	BS_ERR		0x0c	/* DMA Error Address */
89*86d7f5d3SJohn Marino #define	BS_MCR2		0x10	/* DMA Master Command Record 2 */
90*86d7f5d3SJohn Marino 
91*86d7f5d3SJohn Marino /* BS_CTRL - DMA Control */
92*86d7f5d3SJohn Marino #define	BS_CTRL_RESET		0x80000000	/* hardware reset, 5805/5820 */
93*86d7f5d3SJohn Marino #define	BS_CTRL_MCR2INT		0x40000000	/* enable intr MCR for MCR2 */
94*86d7f5d3SJohn Marino #define	BS_CTRL_MCR1INT		0x20000000	/* enable intr MCR for MCR1 */
95*86d7f5d3SJohn Marino #define	BS_CTRL_OFM		0x10000000	/* Output fragment mode */
96*86d7f5d3SJohn Marino #define	BS_CTRL_BE32		0x08000000	/* big-endian, 32bit bytes */
97*86d7f5d3SJohn Marino #define	BS_CTRL_BE64		0x04000000	/* big-endian, 64bit bytes */
98*86d7f5d3SJohn Marino #define	BS_CTRL_DMAERR		0x02000000	/* enable intr DMA error */
99*86d7f5d3SJohn Marino #define	BS_CTRL_RNG_M		0x01800000	/* RNG mode */
100*86d7f5d3SJohn Marino #define	BS_CTRL_RNG_1		0x00000000	/* 1bit rn/one slow clock */
101*86d7f5d3SJohn Marino #define	BS_CTRL_RNG_4		0x00800000	/* 1bit rn/four slow clocks */
102*86d7f5d3SJohn Marino #define	BS_CTRL_RNG_8		0x01000000	/* 1bit rn/eight slow clocks */
103*86d7f5d3SJohn Marino #define	BS_CTRL_RNG_16		0x01800000	/* 1bit rn/16 slow clocks */
104*86d7f5d3SJohn Marino #define	BS_CTRL_SWNORM		0x00400000	/* 582[01], sw normalization */
105*86d7f5d3SJohn Marino #define	BS_CTRL_FRAG_M		0x0000ffff	/* output fragment size mask */
106*86d7f5d3SJohn Marino #define	BS_CTRL_LITTLE_ENDIAN	(BS_CTRL_BE32 | BS_CTRL_BE64)
107*86d7f5d3SJohn Marino 
108*86d7f5d3SJohn Marino /* BS_STAT - DMA Status */
109*86d7f5d3SJohn Marino #define	BS_STAT_MCR1_BUSY	0x80000000	/* MCR1 is busy */
110*86d7f5d3SJohn Marino #define	BS_STAT_MCR1_FULL	0x40000000	/* MCR1 is full */
111*86d7f5d3SJohn Marino #define	BS_STAT_MCR1_DONE	0x20000000	/* MCR1 is done */
112*86d7f5d3SJohn Marino #define	BS_STAT_DMAERR		0x10000000	/* DMA error */
113*86d7f5d3SJohn Marino #define	BS_STAT_MCR2_FULL	0x08000000	/* MCR2 is full */
114*86d7f5d3SJohn Marino #define	BS_STAT_MCR2_DONE	0x04000000	/* MCR2 is done */
115*86d7f5d3SJohn Marino #define	BS_STAT_MCR1_ALLEMPTY	0x02000000	/* 5821, MCR1 is empty */
116*86d7f5d3SJohn Marino #define	BS_STAT_MCR2_ALLEMPTY	0x01000000	/* 5821, MCR2 is empty */
117*86d7f5d3SJohn Marino 
118*86d7f5d3SJohn Marino /* BS_ERR - DMA Error Address */
119*86d7f5d3SJohn Marino #define	BS_ERR_ADDR		0xfffffffc	/* error address mask */
120*86d7f5d3SJohn Marino #define	BS_ERR_READ		0x00000002	/* fault was on read */
121*86d7f5d3SJohn Marino 
122*86d7f5d3SJohn Marino struct ubsec_pktctx {
123*86d7f5d3SJohn Marino 	u_int32_t	pc_deskey[6];		/* 3DES key */
124*86d7f5d3SJohn Marino 	u_int32_t	pc_hminner[5];		/* hmac inner state */
125*86d7f5d3SJohn Marino 	u_int32_t	pc_hmouter[5];		/* hmac outer state */
126*86d7f5d3SJohn Marino 	u_int32_t	pc_iv[2];		/* [3]DES iv */
127*86d7f5d3SJohn Marino 	u_int16_t	pc_flags;		/* flags, below */
128*86d7f5d3SJohn Marino 	u_int16_t	pc_offset;		/* crypto offset */
129*86d7f5d3SJohn Marino };
130*86d7f5d3SJohn Marino #define	UBS_PKTCTX_ENC_3DES	0x8000		/* use 3des */
131*86d7f5d3SJohn Marino #define	UBS_PKTCTX_ENC_NONE	0x0000		/* no encryption */
132*86d7f5d3SJohn Marino #define	UBS_PKTCTX_INBOUND	0x4000		/* inbound packet */
133*86d7f5d3SJohn Marino #define	UBS_PKTCTX_AUTH		0x3000		/* authentication mask */
134*86d7f5d3SJohn Marino #define	UBS_PKTCTX_AUTH_NONE	0x0000		/* no authentication */
135*86d7f5d3SJohn Marino #define	UBS_PKTCTX_AUTH_MD5	0x1000		/* use hmac-md5 */
136*86d7f5d3SJohn Marino #define	UBS_PKTCTX_AUTH_SHA1	0x2000		/* use hmac-sha1 */
137*86d7f5d3SJohn Marino 
138*86d7f5d3SJohn Marino struct ubsec_pktctx_long {
139*86d7f5d3SJohn Marino 	volatile u_int16_t	pc_len;		/* length of ctx struct */
140*86d7f5d3SJohn Marino 	volatile u_int16_t	pc_type;	/* context type, 0 */
141*86d7f5d3SJohn Marino 	volatile u_int16_t	pc_flags;	/* flags, same as above */
142*86d7f5d3SJohn Marino 	volatile u_int16_t	pc_offset;	/* crypto/auth offset */
143*86d7f5d3SJohn Marino 	volatile u_int32_t	pc_deskey[6];	/* 3DES key */
144*86d7f5d3SJohn Marino 	volatile u_int32_t	pc_iv[2];	/* [3]DES iv */
145*86d7f5d3SJohn Marino 	volatile u_int32_t	pc_hminner[5];	/* hmac inner state */
146*86d7f5d3SJohn Marino 	volatile u_int32_t	pc_hmouter[5];	/* hmac outer state */
147*86d7f5d3SJohn Marino };
148*86d7f5d3SJohn Marino #define	UBS_PKTCTX_TYPE_IPSEC	0x0000
149*86d7f5d3SJohn Marino 
150*86d7f5d3SJohn Marino struct ubsec_pktbuf {
151*86d7f5d3SJohn Marino 	volatile u_int32_t	pb_addr;	/* address of buffer start */
152*86d7f5d3SJohn Marino 	volatile u_int32_t	pb_next;	/* pointer to next pktbuf */
153*86d7f5d3SJohn Marino 	volatile u_int32_t	pb_len;		/* packet length */
154*86d7f5d3SJohn Marino };
155*86d7f5d3SJohn Marino #define	UBS_PKTBUF_LEN		0x0000ffff	/* length mask */
156*86d7f5d3SJohn Marino 
157*86d7f5d3SJohn Marino struct ubsec_mcr {
158*86d7f5d3SJohn Marino 	volatile u_int16_t	mcr_pkts;	/* #pkts in this mcr */
159*86d7f5d3SJohn Marino 	volatile u_int16_t	mcr_flags;	/* mcr flags (below) */
160*86d7f5d3SJohn Marino 	volatile u_int32_t	mcr_cmdctxp;	/* command ctx pointer */
161*86d7f5d3SJohn Marino 	struct ubsec_pktbuf	mcr_ipktbuf;	/* input chain header */
162*86d7f5d3SJohn Marino 	volatile u_int16_t	mcr_reserved;
163*86d7f5d3SJohn Marino 	volatile u_int16_t	mcr_pktlen;
164*86d7f5d3SJohn Marino 	struct ubsec_pktbuf	mcr_opktbuf;	/* output chain header */
165*86d7f5d3SJohn Marino };
166*86d7f5d3SJohn Marino 
167*86d7f5d3SJohn Marino struct ubsec_mcr_add {
168*86d7f5d3SJohn Marino 	volatile u_int32_t	mcr_cmdctxp;	/* command ctx pointer */
169*86d7f5d3SJohn Marino 	struct ubsec_pktbuf	mcr_ipktbuf;	/* input chain header */
170*86d7f5d3SJohn Marino 	volatile u_int16_t	mcr_reserved;
171*86d7f5d3SJohn Marino 	volatile u_int16_t	mcr_pktlen;
172*86d7f5d3SJohn Marino 	struct ubsec_pktbuf	mcr_opktbuf;	/* output chain header */
173*86d7f5d3SJohn Marino };
174*86d7f5d3SJohn Marino 
175*86d7f5d3SJohn Marino #define	UBS_MCR_DONE		0x0001		/* mcr has been processed */
176*86d7f5d3SJohn Marino #define	UBS_MCR_ERROR		0x0002		/* error in processing */
177*86d7f5d3SJohn Marino #define	UBS_MCR_ERRORCODE	0xff00		/* error type */
178*86d7f5d3SJohn Marino 
179*86d7f5d3SJohn Marino struct ubsec_ctx_keyop {
180*86d7f5d3SJohn Marino 	volatile u_int16_t	ctx_len;	/* command length */
181*86d7f5d3SJohn Marino 	volatile u_int16_t	ctx_op;		/* operation code */
182*86d7f5d3SJohn Marino 	volatile u_int8_t	ctx_pad[60];	/* padding */
183*86d7f5d3SJohn Marino };
184*86d7f5d3SJohn Marino #define	UBS_CTXOP_DHPKGEN	0x01		/* dh public key generation */
185*86d7f5d3SJohn Marino #define	UBS_CTXOP_DHSSGEN	0x02		/* dh shared secret gen. */
186*86d7f5d3SJohn Marino #define	UBS_CTXOP_RSAPUB	0x03		/* rsa public key op */
187*86d7f5d3SJohn Marino #define	UBS_CTXOP_RSAPRIV	0x04		/* rsa private key op */
188*86d7f5d3SJohn Marino #define	UBS_CTXOP_DSASIGN	0x05		/* dsa signing op */
189*86d7f5d3SJohn Marino #define	UBS_CTXOP_DSAVRFY	0x06		/* dsa verification */
190*86d7f5d3SJohn Marino #define	UBS_CTXOP_RNGBYPASS	0x41		/* rng direct test mode */
191*86d7f5d3SJohn Marino #define	UBS_CTXOP_RNGSHA1	0x42		/* rng sha1 test mode */
192*86d7f5d3SJohn Marino #define	UBS_CTXOP_MODADD	0x43		/* modular addition */
193*86d7f5d3SJohn Marino #define	UBS_CTXOP_MODSUB	0x44		/* modular subtraction */
194*86d7f5d3SJohn Marino #define	UBS_CTXOP_MODMUL	0x45		/* modular multiplication */
195*86d7f5d3SJohn Marino #define	UBS_CTXOP_MODRED	0x46		/* modular reduction */
196*86d7f5d3SJohn Marino #define	UBS_CTXOP_MODEXP	0x47		/* modular exponentiation */
197*86d7f5d3SJohn Marino #define	UBS_CTXOP_MODINV	0x48		/* modular inverse */
198*86d7f5d3SJohn Marino 
199*86d7f5d3SJohn Marino struct ubsec_ctx_rngbypass {
200*86d7f5d3SJohn Marino 	volatile u_int16_t	rbp_len;	/* command length, 64 */
201*86d7f5d3SJohn Marino 	volatile u_int16_t	rbp_op;		/* rng bypass, 0x41 */
202*86d7f5d3SJohn Marino 	volatile u_int8_t	rbp_pad[60];	/* padding */
203*86d7f5d3SJohn Marino };
204*86d7f5d3SJohn Marino 
205*86d7f5d3SJohn Marino /* modexp: C = (M ^ E) mod N */
206*86d7f5d3SJohn Marino struct ubsec_ctx_modexp {
207*86d7f5d3SJohn Marino 	volatile u_int16_t	me_len;		/* command length */
208*86d7f5d3SJohn Marino 	volatile u_int16_t	me_op;		/* modexp, 0x47 */
209*86d7f5d3SJohn Marino 	volatile u_int16_t	me_E_len;	/* E (bits) */
210*86d7f5d3SJohn Marino 	volatile u_int16_t	me_N_len;	/* N (bits) */
211*86d7f5d3SJohn Marino 	u_int8_t		me_N[2048/8];	/* N */
212*86d7f5d3SJohn Marino };
213*86d7f5d3SJohn Marino 
214*86d7f5d3SJohn Marino struct ubsec_ctx_rsapriv {
215*86d7f5d3SJohn Marino 	volatile u_int16_t	rpr_len;	/* command length */
216*86d7f5d3SJohn Marino 	volatile u_int16_t	rpr_op;		/* rsaprivate, 0x04 */
217*86d7f5d3SJohn Marino 	volatile u_int16_t	rpr_q_len;	/* q (bits) */
218*86d7f5d3SJohn Marino 	volatile u_int16_t	rpr_p_len;	/* p (bits) */
219*86d7f5d3SJohn Marino 	u_int8_t		rpr_buf[5 * 1024 / 8];	/* parameters: */
220*86d7f5d3SJohn Marino 						/* p, q, dp, dq, pinv */
221*86d7f5d3SJohn Marino };
222