NetBSD/lib/libdes/rand_key.c

59 lines
2.0 KiB
C
Raw Normal View History

2003-07-23 09:57:01 +04:00
/* $NetBSD: rand_key.c,v 1.3 2003/07/23 05:57:01 itojun Exp $ */
/*
* Copyright (C) 2003 WIDE Project.
* All rights reserved.
2003-07-23 08:57:33 +04:00
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
2003-07-23 08:57:33 +04:00
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name of the project nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
2003-07-23 08:57:33 +04:00
*/
#include "des_locl.h"
2003-07-23 08:57:33 +04:00
void des_random_seed(des_cblock *key)
{
}
2003-07-23 08:57:33 +04:00
int des_random_key(des_cblock *ret)
{
u_int32_t v;
u_int8_t *p, *ep;
do {
p = (u_int8_t *)ret;
ep = (u_int8_t *)(ret + sizeof(*ret));
while (p + sizeof(v) <= ep) {
v = arc4random();
*(u_int32_t *)p = v;
p += sizeof(v);
}
if (ep - p) {
v = arc4random();
memcpy(p, &v, ep - p);
}
} while (des_is_weak_key(ret));
2003-07-23 08:57:33 +04:00
des_set_odd_parity(ret);
2003-07-23 09:57:01 +04:00
return (1);
}