File Coverage

blib/lib/Linux/Perl/getrandom.pm
Criterion Covered Total %
statement 22 26 84.6
branch 3 6 50.0
condition 0 3 0.0
subroutine 5 5 100.0
pod 0 1 0.0
total 30 41 73.1


line stmt bran cond sub pod time code
1             package Linux::Perl::getrandom;
2              
3 1     1   2700 use strict;
  1         2  
  1         29  
4 1     1   5 use warnings;
  1         2  
  1         27  
5              
6             =encoding utf-8
7              
8             =head1 NAME
9              
10             Linux::Perl::getrandom
11              
12             =head1 SYNOPSIS
13              
14             my $numbytes = Linux::Perl::getrandom::x86_64->getrandom(
15             buffer => \$buffer,
16             flags => [ 'RANDOM', 'NONBLOCK' ],
17             );
18              
19             # … or, platform-neutral:
20             my $numbytes = Linux::Perl::getrandom->getrandom(
21             buffer => \$buffer,
22             flags => [ 'RANDOM', 'NONBLOCK' ],
23             );
24              
25             =head1 DESCRIPTION
26              
27             This is an interface to Linux’s C system call. This system
28             call is documented only for kernel 3.17 and after; however, it appears
29             to be present in some earlier kernel versions.
30              
31             =cut
32              
33 1     1   397 use Linux::Perl;
  1         2  
  1         28  
34 1     1   366 use Linux::Perl::Pointer;
  1         2  
  1         221  
35              
36             my %FLAG_VALUE = (
37             NONBLOCK => 1,
38             RANDOM => 2,
39             );
40              
41             sub getrandom {
42 1     1 0 293 my ($class, %opts) = @_;
43              
44 1 50       12 if (!$class->can('NR_getrandom')) {
45 1         408 require Linux::Perl::ArchLoader;
46 1         4 $class = Linux::Perl::ArchLoader::get_arch_module($class);
47             }
48              
49 1         3 my $flags = 0;
50 1 50       5 if ($opts{'flags'}) {
51 0         0 for my $f ( @{ $opts{'flags'} } ) {
  0         0  
52 0   0     0 $flags |= $FLAG_VALUE{$f} || do {
53             die "Invalid flag: “$f”!";
54             };
55             }
56             }
57              
58 1 50       5 if ('SCALAR' ne ref $opts{'buffer'}) {
59 0         0 die "“buffer” must be a scalar reference, not “$opts{'buffer'}”!";
60             }
61              
62             return Linux::Perl::call(
63             $class->NR_getrandom(),
64 1         5 Linux::Perl::Pointer::get_address( ${ $opts{'buffer'} } ),
65 1         11 length( ${ $opts{'buffer'} } ),
  1         6  
66             0 + $flags,
67             );
68             }
69              
70             1;