OpenVAS Scanner  22.7.9
arc4.c File Reference
#include "proto.h"
#include <stdlib.h>
Include dependency graph for arc4.c:

Go to the source code of this file.

Functions

void smb_arc4_init_ntlmssp (unsigned char arc4_state_out[258], const unsigned char *key, size_t keylen)
 
void smb_arc4_crypt_ntlmssp (unsigned char arc4_state_inout[258], unsigned char *data, size_t len)
 

Function Documentation

◆ 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().

Here is the caller graph for this function:

◆ 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().

Here is the caller graph for this function:
len
uint8_t len
Definition: nasl_packet_forgery.c:1