File Coverage

inc/CryptX_Stream_Salsa20.xs.inc
Criterion Covered Total %
statement 39 45 86.6
branch 17 38 44.7
condition n/a
subroutine n/a
pod n/a
total 56 83 67.4


line stmt bran cond sub pod time code
1             MODULE = CryptX PACKAGE = Crypt::Stream::Salsa20
2              
3             PROTOTYPES: DISABLE
4              
5             Crypt::Stream::Salsa20
6             new(Class, SV * key, SV * nonce, UV counter = 0, int rounds = 20)
7             CODE:
8             {
9             int rv;
10 589           STRLEN iv_len=0, k_len=0;
11 589           unsigned char *iv=NULL, *k=NULL;
12              
13 589 50         if (!SvPOK_spec(key)) croak("FATAL: key must be string/buffer scalar");
    50          
    0          
    0          
    0          
14 589 50         if (!SvPOK_spec(nonce)) croak("FATAL: nonce must be string/buffer scalar");
    50          
    0          
    0          
    0          
15 589           k = (unsigned char *)SvPVbyte(key, k_len);
16 589           iv = (unsigned char *)SvPVbyte(nonce, iv_len);
17              
18 589           Newz(0, RETVAL, 1, salsa20_state);
19 589 50         if (!RETVAL) croak("FATAL: Newz failed");
20              
21 589           rv = salsa20_setup(RETVAL, k, (unsigned long)k_len, rounds);
22 589 50         if (rv != CRYPT_OK) {
23 0           Safefree(RETVAL);
24 0           croak("FATAL: salsa20_setup failed: %s", error_to_string(rv));
25             }
26              
27 589           rv = salsa20_ivctr64(RETVAL, iv, (unsigned long)iv_len, (ulong64)counter);
28 589 100         if (rv != CRYPT_OK) {
29 1           salsa20_done(RETVAL);
30 1           Safefree(RETVAL);
31 1           croak("FATAL: salsa20_ivctr64 failed: %s", error_to_string(rv));
32             }
33             }
34             OUTPUT:
35             RETVAL
36              
37             void
38             DESTROY(Crypt::Stream::Salsa20 self)
39             CODE:
40 590           salsa20_done(self);
41 590           zeromem(self, sizeof(*self));
42 590           Safefree(self);
43              
44             Crypt::Stream::Salsa20
45             clone(Crypt::Stream::Salsa20 self)
46             CODE:
47 2           Newz(0, RETVAL, 1, salsa20_state);
48 2 50         if (!RETVAL) croak("FATAL: Newz failed");
49 2           Copy(self, RETVAL, 1, salsa20_state);
50             OUTPUT:
51             RETVAL
52              
53             SV *
54             keystream(Crypt::Stream::Salsa20 self, unsigned long out_len)
55             CODE:
56             {
57             int rv;
58             unsigned char *out_data;
59              
60 5 100         if (out_len == 0) {
61 1           RETVAL = newSVpvn("", 0);
62             }
63             else {
64 4 100         if (out_len == ULONG_MAX) croak("FATAL: output length too large");
65 2           RETVAL = NEWSV(0, out_len); /* avoid zero! */
66 2           SvPOK_only(RETVAL);
67 2           SvCUR_set(RETVAL, out_len);
68 2           out_data = (unsigned char *)SvPVX(RETVAL);
69 2           rv = salsa20_keystream(self, out_data, out_len);
70 2 50         if (rv != CRYPT_OK) {
71 0           SvREFCNT_dec(RETVAL);
72 0           croak("FATAL: salsa20_keystream failed: %s", error_to_string(rv));
73             }
74             }
75             }
76             OUTPUT:
77             RETVAL
78              
79             SV *
80             crypt(Crypt::Stream::Salsa20 self, SV * data)
81             CODE:
82             {
83             int rv;
84             STRLEN in_data_len;
85             unsigned char *in_data, *out_data;
86              
87 587           in_data = (unsigned char *)SvPVbyte(data, in_data_len);
88 587 100         if (in_data_len == 0) {
89 1           RETVAL = newSVpvn("", 0);
90             }
91             else {
92 586           RETVAL = NEWSV(0, in_data_len); /* avoid zero! */
93 586           SvPOK_only(RETVAL);
94 586           SvCUR_set(RETVAL, in_data_len);
95 586           out_data = (unsigned char *)SvPVX(RETVAL);
96 586           rv = salsa20_crypt(self, in_data, (unsigned long)in_data_len, out_data);
97 586 50         if (rv != CRYPT_OK) {
98 0           SvREFCNT_dec(RETVAL);
99 0           croak("FATAL: salsa20_crypt failed: %s", error_to_string(rv));
100             }
101             }
102             }
103             OUTPUT:
104             RETVAL