xref: /freebsd/lib/libc/rpc/des_soft.c (revision 68895e384f73162045664329bc86c7d5e6bdaf40)
12e322d37SHiroki Sato /*-
22e322d37SHiroki Sato  * Copyright (c) 2009, Sun Microsystems, Inc.
32e322d37SHiroki Sato  * All rights reserved.
4e8636dfdSBill Paul  *
52e322d37SHiroki Sato  * Redistribution and use in source and binary forms, with or without
62e322d37SHiroki Sato  * modification, are permitted provided that the following conditions are met:
72e322d37SHiroki Sato  * - Redistributions of source code must retain the above copyright notice,
82e322d37SHiroki Sato  *   this list of conditions and the following disclaimer.
92e322d37SHiroki Sato  * - Redistributions in binary form must reproduce the above copyright notice,
102e322d37SHiroki Sato  *   this list of conditions and the following disclaimer in the documentation
112e322d37SHiroki Sato  *   and/or other materials provided with the distribution.
122e322d37SHiroki Sato  * - Neither the name of Sun Microsystems, Inc. nor the names of its
132e322d37SHiroki Sato  *   contributors may be used to endorse or promote products derived
142e322d37SHiroki Sato  *   from this software without specific prior written permission.
15e8636dfdSBill Paul  *
162e322d37SHiroki Sato  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
172e322d37SHiroki Sato  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
182e322d37SHiroki Sato  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
192e322d37SHiroki Sato  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
202e322d37SHiroki Sato  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
212e322d37SHiroki Sato  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
222e322d37SHiroki Sato  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
232e322d37SHiroki Sato  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
242e322d37SHiroki Sato  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
252e322d37SHiroki Sato  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
262e322d37SHiroki Sato  * POSSIBILITY OF SUCH DAMAGE.
27e8636dfdSBill Paul  */
28a986ef57SDavid E. O'Brien 
29a986ef57SDavid E. O'Brien #if defined(LIBC_SCCS) && !defined(lint)
30a986ef57SDavid E. O'Brien static char sccsid[] = "@(#)des_soft.c	2.2 88/08/10 4.0 RPCSRC; from 1.13 88/02/08 SMI";
31a986ef57SDavid E. O'Brien #endif
32a986ef57SDavid E. O'Brien #include <sys/cdefs.h>
33a986ef57SDavid E. O'Brien __FBSDID("$FreeBSD$");
34a986ef57SDavid E. O'Brien 
35e8636dfdSBill Paul /*
36e8636dfdSBill Paul  * Table giving odd parity in the low bit for ASCII characters
37e8636dfdSBill Paul  */
38e8636dfdSBill Paul static char partab[128] = {
39e8636dfdSBill Paul 	0x01, 0x01, 0x02, 0x02, 0x04, 0x04, 0x07, 0x07,
40e8636dfdSBill Paul 	0x08, 0x08, 0x0b, 0x0b, 0x0d, 0x0d, 0x0e, 0x0e,
41e8636dfdSBill Paul 	0x10, 0x10, 0x13, 0x13, 0x15, 0x15, 0x16, 0x16,
42e8636dfdSBill Paul 	0x19, 0x19, 0x1a, 0x1a, 0x1c, 0x1c, 0x1f, 0x1f,
43e8636dfdSBill Paul 	0x20, 0x20, 0x23, 0x23, 0x25, 0x25, 0x26, 0x26,
44e8636dfdSBill Paul 	0x29, 0x29, 0x2a, 0x2a, 0x2c, 0x2c, 0x2f, 0x2f,
45e8636dfdSBill Paul 	0x31, 0x31, 0x32, 0x32, 0x34, 0x34, 0x37, 0x37,
46e8636dfdSBill Paul 	0x38, 0x38, 0x3b, 0x3b, 0x3d, 0x3d, 0x3e, 0x3e,
47e8636dfdSBill Paul 	0x40, 0x40, 0x43, 0x43, 0x45, 0x45, 0x46, 0x46,
48e8636dfdSBill Paul 	0x49, 0x49, 0x4a, 0x4a, 0x4c, 0x4c, 0x4f, 0x4f,
49e8636dfdSBill Paul 	0x51, 0x51, 0x52, 0x52, 0x54, 0x54, 0x57, 0x57,
50e8636dfdSBill Paul 	0x58, 0x58, 0x5b, 0x5b, 0x5d, 0x5d, 0x5e, 0x5e,
51e8636dfdSBill Paul 	0x61, 0x61, 0x62, 0x62, 0x64, 0x64, 0x67, 0x67,
52e8636dfdSBill Paul 	0x68, 0x68, 0x6b, 0x6b, 0x6d, 0x6d, 0x6e, 0x6e,
53e8636dfdSBill Paul 	0x70, 0x70, 0x73, 0x73, 0x75, 0x75, 0x76, 0x76,
54e8636dfdSBill Paul 	0x79, 0x79, 0x7a, 0x7a, 0x7c, 0x7c, 0x7f, 0x7f,
55e8636dfdSBill Paul };
56e8636dfdSBill Paul 
57e8636dfdSBill Paul /*
58e8636dfdSBill Paul  * Add odd parity to low bit of 8 byte key
59e8636dfdSBill Paul  */
60e8636dfdSBill Paul void
61*68895e38SCraig Rodrigues des_setparity(char *p)
62e8636dfdSBill Paul {
63e8636dfdSBill Paul 	int i;
64e8636dfdSBill Paul 
65e8636dfdSBill Paul 	for (i = 0; i < 8; i++) {
66e8636dfdSBill Paul 		*p = partab[*p & 0x7f];
67e8636dfdSBill Paul 		p++;
68e8636dfdSBill Paul 	}
69e8636dfdSBill Paul }
70