Merge from vendor branch BSDTAR:
[dragonfly.git] / sys / crypto / des / spr.h
1 /*      $FreeBSD: src/sys/crypto/des/spr.h,v 1.1.2.2 2002/03/26 10:12:25 ume Exp $      */
2 /*      $DragonFly: src/sys/crypto/des/spr.h,v 1.2 2003/06/17 04:28:20 dillon Exp $     */
3 /*      $KAME: spr.h,v 1.4 2001/09/10 04:03:58 itojun Exp $     */
4
5 /* crypto/des/spr.h */
6 /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
7  * All rights reserved.
8  *
9  * This package is an SSL implementation written
10  * by Eric Young (eay@cryptsoft.com).
11  * The implementation was written so as to conform with Netscapes SSL.
12  * 
13  * This library is free for commercial and non-commercial use as long as
14  * the following conditions are aheared to.  The following conditions
15  * apply to all code found in this distribution, be it the RC4, RSA,
16  * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
17  * included with this distribution is covered by the same copyright terms
18  * except that the holder is Tim Hudson (tjh@cryptsoft.com).
19  * 
20  * Copyright remains Eric Young's, and as such any Copyright notices in
21  * the code are not to be removed.
22  * If this package is used in a product, Eric Young should be given attribution
23  * as the author of the parts of the library used.
24  * This can be in the form of a textual message at program startup or
25  * in documentation (online or textual) provided with the package.
26  * 
27  * Redistribution and use in source and binary forms, with or without
28  * modification, are permitted provided that the following conditions
29  * are met:
30  * 1. Redistributions of source code must retain the copyright
31  *    notice, this list of conditions and the following disclaimer.
32  * 2. Redistributions in binary form must reproduce the above copyright
33  *    notice, this list of conditions and the following disclaimer in the
34  *    documentation and/or other materials provided with the distribution.
35  * 3. All advertising materials mentioning features or use of this software
36  *    must display the following acknowledgement:
37  *    "This product includes cryptographic software written by
38  *     Eric Young (eay@cryptsoft.com)"
39  *    The word 'cryptographic' can be left out if the rouines from the library
40  *    being used are not cryptographic related :-).
41  * 4. If you include any Windows specific code (or a derivative thereof) from 
42  *    the apps directory (application code) you must include an acknowledgement:
43  *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
44  * 
45  * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
46  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
47  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
48  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
49  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
50  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
51  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
52  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
53  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
54  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
55  * SUCH DAMAGE.
56  * 
57  * The licence and distribution terms for any publically available version or
58  * derivative of this code cannot be changed.  i.e. this code cannot simply be
59  * copied and put under another distribution licence
60  * [including the GNU Public Licence.]
61  */
62
63 const DES_LONG des_SPtrans[8][64]={
64 {
65 /* nibble 0 */
66 0x02080800L, 0x00080000L, 0x02000002L, 0x02080802L,
67 0x02000000L, 0x00080802L, 0x00080002L, 0x02000002L,
68 0x00080802L, 0x02080800L, 0x02080000L, 0x00000802L,
69 0x02000802L, 0x02000000L, 0x00000000L, 0x00080002L,
70 0x00080000L, 0x00000002L, 0x02000800L, 0x00080800L,
71 0x02080802L, 0x02080000L, 0x00000802L, 0x02000800L,
72 0x00000002L, 0x00000800L, 0x00080800L, 0x02080002L,
73 0x00000800L, 0x02000802L, 0x02080002L, 0x00000000L,
74 0x00000000L, 0x02080802L, 0x02000800L, 0x00080002L,
75 0x02080800L, 0x00080000L, 0x00000802L, 0x02000800L,
76 0x02080002L, 0x00000800L, 0x00080800L, 0x02000002L,
77 0x00080802L, 0x00000002L, 0x02000002L, 0x02080000L,
78 0x02080802L, 0x00080800L, 0x02080000L, 0x02000802L,
79 0x02000000L, 0x00000802L, 0x00080002L, 0x00000000L,
80 0x00080000L, 0x02000000L, 0x02000802L, 0x02080800L,
81 0x00000002L, 0x02080002L, 0x00000800L, 0x00080802L,
82 },{
83 /* nibble 1 */
84 0x40108010L, 0x00000000L, 0x00108000L, 0x40100000L,
85 0x40000010L, 0x00008010L, 0x40008000L, 0x00108000L,
86 0x00008000L, 0x40100010L, 0x00000010L, 0x40008000L,
87 0x00100010L, 0x40108000L, 0x40100000L, 0x00000010L,
88 0x00100000L, 0x40008010L, 0x40100010L, 0x00008000L,
89 0x00108010L, 0x40000000L, 0x00000000L, 0x00100010L,
90 0x40008010L, 0x00108010L, 0x40108000L, 0x40000010L,
91 0x40000000L, 0x00100000L, 0x00008010L, 0x40108010L,
92 0x00100010L, 0x40108000L, 0x40008000L, 0x00108010L,
93 0x40108010L, 0x00100010L, 0x40000010L, 0x00000000L,
94 0x40000000L, 0x00008010L, 0x00100000L, 0x40100010L,
95 0x00008000L, 0x40000000L, 0x00108010L, 0x40008010L,
96 0x40108000L, 0x00008000L, 0x00000000L, 0x40000010L,
97 0x00000010L, 0x40108010L, 0x00108000L, 0x40100000L,
98 0x40100010L, 0x00100000L, 0x00008010L, 0x40008000L,
99 0x40008010L, 0x00000010L, 0x40100000L, 0x00108000L,
100 },{
101 /* nibble 2 */
102 0x04000001L, 0x04040100L, 0x00000100L, 0x04000101L,
103 0x00040001L, 0x04000000L, 0x04000101L, 0x00040100L,
104 0x04000100L, 0x00040000L, 0x04040000L, 0x00000001L,
105 0x04040101L, 0x00000101L, 0x00000001L, 0x04040001L,
106 0x00000000L, 0x00040001L, 0x04040100L, 0x00000100L,
107 0x00000101L, 0x04040101L, 0x00040000L, 0x04000001L,
108 0x04040001L, 0x04000100L, 0x00040101L, 0x04040000L,
109 0x00040100L, 0x00000000L, 0x04000000L, 0x00040101L,
110 0x04040100L, 0x00000100L, 0x00000001L, 0x00040000L,
111 0x00000101L, 0x00040001L, 0x04040000L, 0x04000101L,
112 0x00000000L, 0x04040100L, 0x00040100L, 0x04040001L,
113 0x00040001L, 0x04000000L, 0x04040101L, 0x00000001L,
114 0x00040101L, 0x04000001L, 0x04000000L, 0x04040101L,
115 0x00040000L, 0x04000100L, 0x04000101L, 0x00040100L,
116 0x04000100L, 0x00000000L, 0x04040001L, 0x00000101L,
117 0x04000001L, 0x00040101L, 0x00000100L, 0x04040000L,
118 },{
119 /* nibble 3 */
120 0x00401008L, 0x10001000L, 0x00000008L, 0x10401008L,
121 0x00000000L, 0x10400000L, 0x10001008L, 0x00400008L,
122 0x10401000L, 0x10000008L, 0x10000000L, 0x00001008L,
123 0x10000008L, 0x00401008L, 0x00400000L, 0x10000000L,
124 0x10400008L, 0x00401000L, 0x00001000L, 0x00000008L,
125 0x00401000L, 0x10001008L, 0x10400000L, 0x00001000L,
126 0x00001008L, 0x00000000L, 0x00400008L, 0x10401000L,
127 0x10001000L, 0x10400008L, 0x10401008L, 0x00400000L,
128 0x10400008L, 0x00001008L, 0x00400000L, 0x10000008L,
129 0x00401000L, 0x10001000L, 0x00000008L, 0x10400000L,
130 0x10001008L, 0x00000000L, 0x00001000L, 0x00400008L,
131 0x00000000L, 0x10400008L, 0x10401000L, 0x00001000L,
132 0x10000000L, 0x10401008L, 0x00401008L, 0x00400000L,
133 0x10401008L, 0x00000008L, 0x10001000L, 0x00401008L,
134 0x00400008L, 0x00401000L, 0x10400000L, 0x10001008L,
135 0x00001008L, 0x10000000L, 0x10000008L, 0x10401000L,
136 },{
137 /* nibble 4 */
138 0x08000000L, 0x00010000L, 0x00000400L, 0x08010420L,
139 0x08010020L, 0x08000400L, 0x00010420L, 0x08010000L,
140 0x00010000L, 0x00000020L, 0x08000020L, 0x00010400L,
141 0x08000420L, 0x08010020L, 0x08010400L, 0x00000000L,
142 0x00010400L, 0x08000000L, 0x00010020L, 0x00000420L,
143 0x08000400L, 0x00010420L, 0x00000000L, 0x08000020L,
144 0x00000020L, 0x08000420L, 0x08010420L, 0x00010020L,
145 0x08010000L, 0x00000400L, 0x00000420L, 0x08010400L,
146 0x08010400L, 0x08000420L, 0x00010020L, 0x08010000L,
147 0x00010000L, 0x00000020L, 0x08000020L, 0x08000400L,
148 0x08000000L, 0x00010400L, 0x08010420L, 0x00000000L,
149 0x00010420L, 0x08000000L, 0x00000400L, 0x00010020L,
150 0x08000420L, 0x00000400L, 0x00000000L, 0x08010420L,
151 0x08010020L, 0x08010400L, 0x00000420L, 0x00010000L,
152 0x00010400L, 0x08010020L, 0x08000400L, 0x00000420L,
153 0x00000020L, 0x00010420L, 0x08010000L, 0x08000020L,
154 },{
155 /* nibble 5 */
156 0x80000040L, 0x00200040L, 0x00000000L, 0x80202000L,
157 0x00200040L, 0x00002000L, 0x80002040L, 0x00200000L,
158 0x00002040L, 0x80202040L, 0x00202000L, 0x80000000L,
159 0x80002000L, 0x80000040L, 0x80200000L, 0x00202040L,
160 0x00200000L, 0x80002040L, 0x80200040L, 0x00000000L,
161 0x00002000L, 0x00000040L, 0x80202000L, 0x80200040L,
162 0x80202040L, 0x80200000L, 0x80000000L, 0x00002040L,
163 0x00000040L, 0x00202000L, 0x00202040L, 0x80002000L,
164 0x00002040L, 0x80000000L, 0x80002000L, 0x00202040L,
165 0x80202000L, 0x00200040L, 0x00000000L, 0x80002000L,
166 0x80000000L, 0x00002000L, 0x80200040L, 0x00200000L,
167 0x00200040L, 0x80202040L, 0x00202000L, 0x00000040L,
168 0x80202040L, 0x00202000L, 0x00200000L, 0x80002040L,
169 0x80000040L, 0x80200000L, 0x00202040L, 0x00000000L,
170 0x00002000L, 0x80000040L, 0x80002040L, 0x80202000L,
171 0x80200000L, 0x00002040L, 0x00000040L, 0x80200040L,
172 },{
173 /* nibble 6 */
174 0x00004000L, 0x00000200L, 0x01000200L, 0x01000004L,
175 0x01004204L, 0x00004004L, 0x00004200L, 0x00000000L,
176 0x01000000L, 0x01000204L, 0x00000204L, 0x01004000L,
177 0x00000004L, 0x01004200L, 0x01004000L, 0x00000204L,
178 0x01000204L, 0x00004000L, 0x00004004L, 0x01004204L,
179 0x00000000L, 0x01000200L, 0x01000004L, 0x00004200L,
180 0x01004004L, 0x00004204L, 0x01004200L, 0x00000004L,
181 0x00004204L, 0x01004004L, 0x00000200L, 0x01000000L,
182 0x00004204L, 0x01004000L, 0x01004004L, 0x00000204L,
183 0x00004000L, 0x00000200L, 0x01000000L, 0x01004004L,
184 0x01000204L, 0x00004204L, 0x00004200L, 0x00000000L,
185 0x00000200L, 0x01000004L, 0x00000004L, 0x01000200L,
186 0x00000000L, 0x01000204L, 0x01000200L, 0x00004200L,
187 0x00000204L, 0x00004000L, 0x01004204L, 0x01000000L,
188 0x01004200L, 0x00000004L, 0x00004004L, 0x01004204L,
189 0x01000004L, 0x01004200L, 0x01004000L, 0x00004004L,
190 },{
191 /* nibble 7 */
192 0x20800080L, 0x20820000L, 0x00020080L, 0x00000000L,
193 0x20020000L, 0x00800080L, 0x20800000L, 0x20820080L,
194 0x00000080L, 0x20000000L, 0x00820000L, 0x00020080L,
195 0x00820080L, 0x20020080L, 0x20000080L, 0x20800000L,
196 0x00020000L, 0x00820080L, 0x00800080L, 0x20020000L,
197 0x20820080L, 0x20000080L, 0x00000000L, 0x00820000L,
198 0x20000000L, 0x00800000L, 0x20020080L, 0x20800080L,
199 0x00800000L, 0x00020000L, 0x20820000L, 0x00000080L,
200 0x00800000L, 0x00020000L, 0x20000080L, 0x20820080L,
201 0x00020080L, 0x20000000L, 0x00000000L, 0x00820000L,
202 0x20800080L, 0x20020080L, 0x20020000L, 0x00800080L,
203 0x20820000L, 0x00000080L, 0x00800080L, 0x20020000L,
204 0x20820080L, 0x00800000L, 0x20800000L, 0x20000080L,
205 0x00820000L, 0x00020080L, 0x20020080L, 0x20800000L,
206 0x00000080L, 0x20820000L, 0x00820080L, 0x00000000L,
207 0x20000000L, 0x20800080L, 0x00020000L, 0x00820080L,
208 }};