File Coverage

inc/CryptX_Stream_XChaCha.xs.inc
Criterion Covered Total %
statement 36 41 87.8
branch 15 36 41.6
condition n/a
subroutine n/a
pod n/a
total 51 77 66.2


line stmt bran cond sub pod time code
1             MODULE = CryptX PACKAGE = Crypt::Stream::XChaCha
2              
3             PROTOTYPES: DISABLE
4              
5             Crypt::Stream::XChaCha
6             new(Class, SV * key, SV * nonce, int rounds = 20)
7             CODE:
8             {
9             int rv;
10 7           STRLEN iv_len=0, k_len=0;
11 7           unsigned char *iv=NULL, *k=NULL;
12              
13 7 50         if (!SvPOK_spec(key)) croak("FATAL: key must be string/buffer scalar");
    50          
    0          
    0          
    0          
14 7 50         if (!SvPOK_spec(nonce)) croak("FATAL: nonce must be string/buffer scalar");
    50          
    0          
    0          
    0          
15 7           k = (unsigned char *)SvPVbyte(key, k_len);
16 7           iv = (unsigned char *)SvPVbyte(nonce, iv_len);
17              
18 7           Newz(0, RETVAL, 1, chacha_state);
19 7 50         if (!RETVAL) croak("FATAL: Newz failed");
20              
21 7           rv = xchacha20_setup(RETVAL, k, (unsigned long)k_len, iv, (unsigned long)iv_len, rounds);
22 7 100         if (rv != CRYPT_OK) {
23 1           chacha_done(RETVAL);
24 1           Safefree(RETVAL);
25 1           croak("FATAL: xchacha20_setup failed: %s", error_to_string(rv));
26             }
27             }
28             OUTPUT:
29             RETVAL
30              
31             void
32             DESTROY(Crypt::Stream::XChaCha self)
33             CODE:
34 7           chacha_done(self);
35 7           zeromem(self, sizeof(*self));
36 7           Safefree(self);
37              
38             Crypt::Stream::XChaCha
39             clone(Crypt::Stream::XChaCha self)
40             CODE:
41 1           Newz(0, RETVAL, 1, chacha_state);
42 1 50         if (!RETVAL) croak("FATAL: Newz failed");
43 1           Copy(self, RETVAL, 1, chacha_state);
44             OUTPUT:
45             RETVAL
46              
47             SV *
48             keystream(Crypt::Stream::XChaCha 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 = chacha_keystream(self, out_data, out_len);
64 4 50         if (rv != CRYPT_OK) {
65 0           SvREFCNT_dec(RETVAL);
66 0           croak("FATAL: chacha_keystream failed: %s", error_to_string(rv));
67             }
68             }
69             }
70             OUTPUT:
71             RETVAL
72              
73             SV *
74             crypt(Crypt::Stream::XChaCha 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 = chacha_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: chacha_crypt failed: %s", error_to_string(rv));
94             }
95             }
96             }
97             OUTPUT:
98             RETVAL