Add in a lucent-compatible key generator.

This commit is contained in:
solomon 2003-03-24 16:18:08 +00:00
parent e79b9934a4
commit c735ca5d74
5 changed files with 176 additions and 0 deletions

View file

@ -41,6 +41,7 @@
* Intersil Corporation as part of PRISM(R) chipset product development.
*
* --------------------------------------------------------------------
- Add a Lucent-compatible key-generator in add-ons/lwepgen
- Fix a stack overflow problem. (Pavel Roskin)
- Further monitor mode fix for control frames (Pavel Roskin)
- Cleanups in the dependency generation code

1
THANKS
View file

@ -99,6 +99,7 @@ Ryan Veety <ryan@ryanspc.com>
Michael Hackett <mhackett@kanayo.com>
Pavel Kankovsky <kan@dcit.cz>
Brad Davidson <kiloman@oatmail.org>
Ralf Miunske <miunske@users.sourceforge.net>
[Many, many more. If I've overlooked you and you want to be listed here,
send me e-mail and I'll fix it. I _know_ a bunch of linux-wlan contributors

11
add-ons/lwepgen/Makefile Normal file
View file

@ -0,0 +1,11 @@
default: lwepgen
lwepgen: lwepgen.c
gcc -Wl,/usr/lib/libcrypto.so -o lwepgen lwepgen.c
lwepgen.c:
echo lwepgen.c missing!
false
clean:
rm -rf lwepgen

162
add-ons/lwepgen/lwepgen.c Normal file
View file

@ -0,0 +1,162 @@
/*
* keygen.c
* WEP Key Generators
*
* This program generates WEP keys using de facto standard key
* generators for 40 and 128 bit keys.
*
* Link against OpenSSL's libcrypto.a
*
* I place this code in the public domain.
* May 2001, Tim Newsham
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <openssl/md5.h>
#define WEPKEYSIZE 5
#define WEPSTRONGKEYSIZE 13
#define WEPKEYS 4
#define WEPKEYSTORE (WEPKEYSIZE * WEPKEYS)
/*
* generate four subkeys from a seed using the defacto standard
*/
void
wep_seedkeygen(int val, u_char *keys)
{
int i;
for(i = 0; i < WEPKEYSTORE; i++) {
val *= 0x343fd;
val += 0x269ec3;
keys[i] = val >> 16;
}
return;
}
/*
* generate one key from a string using the de facto standard
*
* resultant key is stored in
* one 128 bit key: keys[0-15]
*
* (NOTE: I'm not sure why, but it seems that only values 0-12 are used,
* resulting in 104 bits of keying, not 128)
*/
void
wep_keygen128(char *str, u_char *keys)
{
MD5_CTX ctx;
u_char buf[64];
int i, j;
/* repeat str until buf is full */
j = 0;
for(i = 0; i < 64; i++) {
if(str[j] == 0)
j = 0;
buf[i] = str[j++];
}
MD5_Init(&ctx);
MD5_Update(&ctx, buf, sizeof buf);
MD5_Final(buf, &ctx);
memcpy(keys, buf, WEPKEYSTORE);
for(i = 0; i < WEPSTRONGKEYSIZE; i++) {
keys[i] = buf[i];
}
for(; i < WEPKEYSTORE; i++) {
keys[i] = 0;
}
return;
}
/*
* generate four subkeys from a string using the defacto standard
*
* resultant keys are stored in
* four 40 bit keys: keys[0-4], keys[5-9], keys[10-14] and keys[15-20]
*/
void
wep_keygen40(char *str, u_char *keys)
{
int val, i, shift;
/*
* seed is generated by xor'ing in the keystring bytes
* into the four bytes of the seed, starting at the little end
*/
val = 0;
for(i = 0; str[i]; i++) {
shift = i & 0x3;
val ^= (str[i] << (shift * 8));
}
wep_seedkeygen(val, keys);
return;
}
void
wep_keyprint(u_char *keys, int strong)
{
int i, printlength, keylength;
char sepchar;
printlength = strong ? WEPSTRONGKEYSIZE : WEPKEYSTORE;
keylength = strong ? WEPSTRONGKEYSIZE : WEPKEYSIZE;
for(i = 0; i < printlength; i++) {
sepchar = (i % keylength == keylength - 1) ? '\n' : ':';
printf("%02x%c", keys[i], sepchar);
}
return;
}
void
usage(char *prog)
{
printf("%s: generates Lucent compatible WEP keys from a string\n", prog);
printf("Usage: %s [-s] keystring\n", prog);
exit(1);
}
int
main(int argc, char **argv)
{
u_char keys[WEPKEYSTORE];
char *prog, *genstr;
int strong, ch;
prog = argv[0];
strong = 0;
while((ch = getopt(argc, argv, "s")) != EOF) {
switch(ch) {
case 's':
strong ++;
break;
default:
usage(prog);
}
}
argc -= optind;
argv += optind;
if(argc != 1)
usage(prog);
genstr = argv[0];
if(strong)
wep_keygen128(genstr, keys);
else
wep_keygen40(genstr, keys);
wep_keyprint(keys, strong);
return 0;
}

View file

@ -17,6 +17,7 @@ dot11ExcludeUnencrypted=true # true|false, in AP this means WEP is required.
# If PRIV_GENSTR is not empty, use PRIV_GENTSTR to generate
# keys (just a convenience)
# add-ons/ in the tarball contains other key generators.
PRIV_GENERATOR=/sbin/nwepgen # nwepgen, Neesus compatible
PRIV_KEY128=false # keylength to generate
PRIV_GENSTR=""