File Coverage

inc/CryptX_Stream_XSalsa20.xs.inc
Criterion Covered Total %
statement 33 41 80.4
branch 14 36 38.8
condition n/a
subroutine n/a
pod n/a
total 47 77 61.0


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