document earlier documentation additions
[alioth/early-rng-init-tools.git] / arcfour_ksa.c
1 /*-
2  * Copyright (c) 2010
3  *      mirabilos <m@mirbsd.org>
4  *
5  * Provided that these terms and disclaimer and all copyright notices
6  * are retained or reproduced in an accompanying document, permission
7  * is granted to deal in this work without restriction, including un-
8  * limited rights to use, publicly perform, distribute, sell, modify,
9  * merge, give away, or sublicence.
10  *
11  * This work is provided "AS IS" and WITHOUT WARRANTY of any kind, to
12  * the utmost extent permitted by applicable law, neither express nor
13  * implied; without malicious intent or gross negligence. In no event
14  * may a licensor, author or contributor be held liable for indirect,
15  * direct, other damage, loss, or other issues arising in any way out
16  * of dealing in the work, even if advised of the possibility of such
17  * damage or existence of a defect, except proven that it results out
18  * of said person's immediate fault when using the work as intended.
19  *-
20  * Arcfour cipher re-implementation from (alledged) spec description.
21  * Normal key scheduling algorithm.
22  */
23
24 #include <stdint.h>
25 #include <stdlib.h>
26
27 #include "irc4random.h"
28
29 void
30 arcfour_ksa(struct arcfour_status *c, const uint8_t *key, size_t keylen)
31 {
32         register uint8_t i, j, si, n = 0;
33
34         i = c->i - 1;
35         j = c->j;
36         do {
37                 ++i;
38                 si = c->S[i];
39                 j = (uint8_t)(j + si + key[n++ % keylen]);
40                 c->S[i] = c->S[j];
41                 c->S[j] = si;
42         } while (n);
43         c->j = c->i = i + 1;
44 }