diff options
author | Mark Haines <mjark@negativecurvature.net> | 2015-02-26 16:43:06 +0000 |
---|---|---|
committer | Mark Haines <mjark@negativecurvature.net> | 2015-02-26 16:43:06 +0000 |
commit | 15bb93321fdf9c5ec2c75e03f9a1bb5fdf8b7e10 (patch) | |
tree | d754f9776a62095d5adfb257134f7bcff54c1157 /lib/crypto-algorithms/arcfour.c | |
parent | 6c56bcf2fd3db38c679b9cf9345051a7309fa02f (diff) | |
parent | c61e5359cb454ae20c0b7b057c3a7b53e2beefd6 (diff) |
Merge commit 'c61e5359cb454ae20c0b7b057c3a7b53e2beefd6' as 'lib/crypto-algorithms'
Diffstat (limited to 'lib/crypto-algorithms/arcfour.c')
-rw-r--r-- | lib/crypto-algorithms/arcfour.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/lib/crypto-algorithms/arcfour.c b/lib/crypto-algorithms/arcfour.c new file mode 100644 index 0000000..aa7544a --- /dev/null +++ b/lib/crypto-algorithms/arcfour.c @@ -0,0 +1,45 @@ +/********************************************************************* +* Filename: arcfour.c +* Author: Brad Conte (brad AT bradconte.com) +* Copyright: +* Disclaimer: This code is presented "as is" without any guarantees. +* Details: Implementation of the ARCFOUR encryption algorithm. + Algorithm specification can be found here: + * http://en.wikipedia.org/wiki/RC4 +*********************************************************************/ + +/*************************** HEADER FILES ***************************/ +#include <stdlib.h> +#include "arcfour.h" + +/*********************** FUNCTION DEFINITIONS ***********************/ +void arcfour_key_setup(BYTE state[], const BYTE key[], int len) +{ + int i, j; + BYTE t; + + for (i = 0; i < 256; ++i) + state[i] = i; + for (i = 0, j = 0; i < 256; ++i) { + j = (j + state[i] + key[i % len]) % 256; + t = state[i]; + state[i] = state[j]; + state[j] = t; + } +} + +void arcfour_generate_stream(BYTE state[], BYTE out[], size_t len) +{ + int i, j; + size_t idx; + BYTE t; + + for (idx = 0, i = 0, j = 0; idx < len; ++idx) { + i = (i + 1) % 256; + j = (j + state[i]) % 256; + t = state[i]; + state[i] = state[j]; + state[j] = t; + out[idx] = state[(state[i] + state[j]) % 256]; + } +} |