diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/lib/libc/crypt/bcrypt.c | 31 | ||||
| -rw-r--r-- | src/lib/libc/crypt/blowfish.c | 43 |
2 files changed, 59 insertions, 15 deletions
diff --git a/src/lib/libc/crypt/bcrypt.c b/src/lib/libc/crypt/bcrypt.c index 66daa4e2df..d2b7cd888c 100644 --- a/src/lib/libc/crypt/bcrypt.c +++ b/src/lib/libc/crypt/bcrypt.c | |||
| @@ -1,11 +1,32 @@ | |||
| 1 | /* $OpenBSD: bcrypt.c,v 1.1 1997/02/13 16:31:16 provos Exp $ */ | 1 | /* $OpenBSD: bcrypt.c,v 1.2 1997/02/14 18:40:14 provos Exp $ */ |
| 2 | /* | 2 | /* |
| 3 | * Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de> | 3 | * Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de> |
| 4 | * All rights reserved. | ||
| 4 | * | 5 | * |
| 5 | * Modification and redistribution in source and binary forms is | 6 | * Redistribution and use in source and binary forms, with or without |
| 6 | * permitted provided that due credit is given to the author and the | 7 | * modification, are permitted provided that the following conditions |
| 7 | * OpenBSD project (for instance by leaving this copyright notice | 8 | * are met: |
| 8 | * intact). | 9 | * 1. Redistributions of source code must retain the above copyright |
| 10 | * notice, this list of conditions and the following disclaimer. | ||
| 11 | * 2. Redistributions in binary form must reproduce the above copyright | ||
| 12 | * notice, this list of conditions and the following disclaimer in the | ||
| 13 | * documentation and/or other materials provided with the distribution. | ||
| 14 | * 3. All advertising materials mentioning features or use of this software | ||
| 15 | * must display the following acknowledgement: | ||
| 16 | * This product includes software developed by Theo de Raadt. | ||
| 17 | * 4. The name of the author may not be used to endorse or promote products | ||
| 18 | * derived from this software without specific prior written permission. | ||
| 19 | * | ||
| 20 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | ||
| 21 | * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | ||
| 22 | * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. | ||
| 23 | * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | ||
| 24 | * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | ||
| 25 | * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
| 26 | * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||
| 27 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
| 28 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||
| 29 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
| 9 | */ | 30 | */ |
| 10 | 31 | ||
| 11 | /* This password hashing algorithm was designed by David Mazieres | 32 | /* This password hashing algorithm was designed by David Mazieres |
diff --git a/src/lib/libc/crypt/blowfish.c b/src/lib/libc/crypt/blowfish.c index cce6e85901..558d6d7b38 100644 --- a/src/lib/libc/crypt/blowfish.c +++ b/src/lib/libc/crypt/blowfish.c | |||
| @@ -1,12 +1,35 @@ | |||
| 1 | /* $OpenBSD: blowfish.c,v 1.1 1997/02/13 16:28:33 provos Exp $ */ | 1 | /* $OpenBSD: blowfish.c,v 1.2 1997/02/14 18:40:18 provos Exp $ */ |
| 2 | /* | 2 | /* |
| 3 | * Blowfish block cipher for OpenBSD | 3 | * Blowfish block cipher for OpenBSD |
| 4 | * Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de> | 4 | * Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de> |
| 5 | * All rights reserved. | ||
| 6 | * | ||
| 5 | * Implementation advice by David Mazieres <dm@lcs.mit.edu>. | 7 | * Implementation advice by David Mazieres <dm@lcs.mit.edu>. |
| 6 | * Modification and redistribution in source and binary forms is | 8 | * |
| 7 | * permitted provided that due credit is given to the author and the | 9 | * Redistribution and use in source and binary forms, with or without |
| 8 | * OpenBSD project (for instance by leaving this copyright notice | 10 | * modification, are permitted provided that the following conditions |
| 9 | * intact). | 11 | * are met: |
| 12 | * 1. Redistributions of source code must retain the above copyright | ||
| 13 | * notice, this list of conditions and the following disclaimer. | ||
| 14 | * 2. Redistributions in binary form must reproduce the above copyright | ||
| 15 | * notice, this list of conditions and the following disclaimer in the | ||
| 16 | * documentation and/or other materials provided with the distribution. | ||
| 17 | * 3. All advertising materials mentioning features or use of this software | ||
| 18 | * must display the following acknowledgement: | ||
| 19 | * This product includes software developed by Theo de Raadt. | ||
| 20 | * 4. The name of the author may not be used to endorse or promote products | ||
| 21 | * derived from this software without specific prior written permission. | ||
| 22 | * | ||
| 23 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | ||
| 24 | * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | ||
| 25 | * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. | ||
| 26 | * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | ||
| 27 | * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | ||
| 28 | * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
| 29 | * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||
| 30 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
| 31 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | ||
| 32 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
| 10 | */ | 33 | */ |
| 11 | 34 | ||
| 12 | /* | 35 | /* |
| @@ -35,14 +58,14 @@ static inline u_int32_t F __P((blf_ctx * bc, u_int32_t x)); | |||
| 35 | 58 | ||
| 36 | /* Standard Blowfish */ | 59 | /* Standard Blowfish */ |
| 37 | 60 | ||
| 38 | void blf_key __P((blf_ctx * c, u_int8_t * k, u_int16_t len)); | 61 | void blf_key __P((blf_ctx * c, u_int8_t * k, u_int16_t len)); |
| 39 | void blf_enc __P((blf_ctx * c, u_int32_t * data, u_int16_t blocks)); | 62 | void blf_enc __P((blf_ctx * c, u_int32_t * data, u_int16_t blocks)); |
| 40 | void blf_dec __P((blf_ctx * c, u_int32_t * data, u_int16_t blocks)); | 63 | void blf_dec __P((blf_ctx * c, u_int32_t * data, u_int16_t blocks)); |
| 41 | 64 | ||
| 42 | /* Function for Feistel Networks */ | 65 | /* Function for Feistel Networks */ |
| 43 | 66 | ||
| 44 | static inline u_int32_t | 67 | static inline u_int32_t |
| 45 | F(bc, x) | 68 | F(bc, x) |
| 46 | blf_ctx *bc; | 69 | blf_ctx *bc; |
| 47 | u_int32_t x; | 70 | u_int32_t x; |
| 48 | { | 71 | { |
