#include "proto.h"
#include <stdlib.h>
Go to the source code of this file.
◆ smb_arc4_crypt_ntlmssp()
| void smb_arc4_crypt_ntlmssp |
( |
unsigned char | arc4_state_inout[258], |
|
|
unsigned char * | data, |
|
|
size_t | len ) |
Definition at line 47 of file arc4.c.
49{
50 unsigned char index_i = arc4_state_inout[256];
51 unsigned char index_j = arc4_state_inout[257];
52 size_t ind;
53
54 for (ind = 0; ind <
len; ind++)
55 {
56 unsigned char tc;
57 unsigned char t;
58
59 index_i++;
60 index_j += arc4_state_inout[index_i];
61
62 tc = arc4_state_inout[index_i];
63 arc4_state_inout[index_i] = arc4_state_inout[index_j];
64 arc4_state_inout[index_j] = tc;
65
66 t = arc4_state_inout[index_i] + arc4_state_inout[index_j];
67 data[ind] = data[ind] ^ arc4_state_inout[t];
68 }
69
70 arc4_state_inout[256] = index_i;
71 arc4_state_inout[257] = index_j;
72}
References len.
Referenced by generate_random_buffer_ntlmssp().
◆ smb_arc4_init_ntlmssp()
| void smb_arc4_init_ntlmssp |
( |
unsigned char | arc4_state_out[258], |
|
|
const unsigned char * | key, |
|
|
size_t | keylen ) |
Definition at line 16 of file arc4.c.
18{
19 size_t ind;
20 unsigned char j = 0;
21
22 for (ind = 0; ind < 256; ind++)
23 {
24 arc4_state_out[ind] = (unsigned char) ind;
25 }
26
27 for (ind = 0; ind < 256; ind++)
28 {
29 unsigned char tc;
30
31 j += (arc4_state_out[ind] + key[ind % keylen]);
32
33 tc = arc4_state_out[ind];
34 arc4_state_out[ind] = arc4_state_out[j];
35 arc4_state_out[j] = tc;
36 }
37 arc4_state_out[256] = 0;
38 arc4_state_out[257] = 0;
39}
Referenced by do_reseed_ntlmssp().