From: ian Date: Wed, 30 Dec 1998 19:27:22 +0000 (+0000) Subject: Found blowfishspeed.[ X-Git-Tag: branchpoint-1996-06-19-retrospective-beforeuserv~23 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=userv-utils.git;a=commitdiff_plain;h=3ef5750459cf85928dfb275b2c72001e3553cf3c;ds=sidebyside Found blowfishspeed.[ --- diff --git a/ipif/blowfishspeed.c b/ipif/blowfishspeed.c new file mode 100644 index 0000000..aaaf622 --- /dev/null +++ b/ipif/blowfishspeed.c @@ -0,0 +1,37 @@ +/**/ + +#include +#include +#include + +#include "blowfish.h" + +static void checkrw(int r, int exp_r, const char *op, FILE *f) { + if (ferror(f)) { perror(op); exit(3); } + if (feof(f)) { fprintf(stderr,"unexpected eof on %s\n",op); exit(2); } + assert(r==exp_r); +} + +int main(void) { + struct blowfish_cbc_state cbc; + unsigned char keybuf[BLOWFISH_MAXKEYBYTES], ivbuf[BLOWFISH_BLOCKBYTES]; + unsigned char ibuf[BLOWFISH_BLOCKBYTES], obuf[BLOWFISH_BLOCKBYTES]; + int r; + + r= fread(keybuf,1,sizeof(keybuf),stdin); checkrw(r,sizeof(keybuf),"input",stdin); + blowfish_loadkey(&cbc.ek,keybuf,sizeof(keybuf)); + + r= fread(ibuf,1,sizeof(ivbuf),stdin); checkrw(r,sizeof(ivbuf),"input",stdin); + blowfish_cbc_setiv(&cbc,ivbuf); + + for (;;) { + r= fread(ibuf,1,sizeof(ibuf),stdin); if (r=0) break; + checkrw(r,sizeof(ibuf),"input",stdin); + blowfish_cbc_encrypt(&cbc,ibuf,obuf); + r= fwrite(obuf,1,sizeof(obuf),stdout); checkrw(r,sizeof(obuf),"output",stdout); + } + memset(ibuf+r,sizeof(ibuf)-r,sizeof(ibuf)-r); + blowfish_cbc_encrypt(&cbc,ibuf,obuf); + r= fwrite(obuf,1,sizeof(obuf),stdout); checkrw(r,sizeof(obuf),"output",stdout); + return 0; +};