From 641405320f4601f50e0d728805e14fb6f8196710 Mon Sep 17 00:00:00 2001 From: rsc Date: Tue, 8 Feb 2005 21:02:40 +0000 Subject: add crypt --- src/lib9/crypt.c | 68 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ src/lib9/mkfile | 1 + 2 files changed, 69 insertions(+) create mode 100755 src/lib9/crypt.c (limited to 'src/lib9') diff --git a/src/lib9/crypt.c b/src/lib9/crypt.c new file mode 100755 index 00000000..0524c942 --- /dev/null +++ b/src/lib9/crypt.c @@ -0,0 +1,68 @@ +/* + * Data Encryption Standard + * D.P.Mitchell 83/06/08. + * + * block_cipher(key, block, decrypting) + * + * these routines use the non-standard 7 byte format + * for DES keys. + */ +#include +#include +#include +#include + +/* + * destructively encrypt the buffer, which + * must be at least 8 characters long. + */ +int +encrypt(void *key, void *vbuf, int n) +{ + ulong ekey[32]; + uchar *buf; + int i, r; + + if(n < 8) + return 0; + key_setup(key, ekey); + buf = vbuf; + n--; + r = n % 7; + n /= 7; + for(i = 0; i < n; i++){ + block_cipher(ekey, buf, 0); + buf += 7; + } + if(r) + block_cipher(ekey, buf - 7 + r, 0); + return 1; +} + +/* + * destructively decrypt the buffer, which + * must be at least 8 characters long. + */ +int +decrypt(void *key, void *vbuf, int n) +{ + ulong ekey[128]; + uchar *buf; + int i, r; + + if(n < 8) + return 0; + key_setup(key, ekey); + buf = vbuf; + n--; + r = n % 7; + n /= 7; + buf += n * 7; + if(r) + block_cipher(ekey, buf - 7 + r, 1); + for(i = 0; i < n; i++){ + buf -= 7; + block_cipher(ekey, buf, 1); + } + return 1; +} diff --git a/src/lib9/mkfile b/src/lib9/mkfile index 361ab5b7..3ed220ab 100644 --- a/src/lib9/mkfile +++ b/src/lib9/mkfile @@ -84,6 +84,7 @@ LIB9OFILES=\ convM2S.$O\ convS2M.$O\ create.$O\ + crypt.$O\ ctime.$O\ date.$O\ dial.$O\ -- cgit v1.2.3