]> Sergey Matveev's repositories - public-inbox.git/commitdiff
lei pmdir: fix nproc for <= 4 CPUs
authorEric Wong <e@80x24.org>
Tue, 8 Jun 2021 23:56:13 +0000 (23:56 +0000)
committerEric Wong <e@80x24.org>
Wed, 9 Jun 2021 00:12:22 +0000 (00:12 +0000)
I forgot my FreeBSD VM has 8 cores, actually, and tweaked the
nproc detection on that machine before finalizing commit
10b523eb017162240b1ac3647f8dcbbf2be348a7
("lei import: speed up repeated Maildir imports")

Fixes: 10b523eb01716224 ("lei import: speed up repeated Maildir imports")
lib/PublicInbox/LeiPmdir.pm

index 5efb012e4e8c69ad146f52d59a862999e29da83e..b71efe701e76289c928e92f4f2828ab8f1934040 100644 (file)
@@ -13,14 +13,14 @@ use parent qw(PublicInbox::IPC);
 sub new {
        my ($cls, $lei, $ipt) = @_;
        my $self = bless { -wq_ident => 'lei Maildir worker' }, $cls;
-       my $jobs = $lei->{opt}->{jobs};
+       my $jobs = $lei->{opt}->{jobs} // '';
        $jobs =~ /\A[0-9]+,([0-9]+)\z/ and $jobs = $1;
-       my $nproc = $jobs // do {
-               # untested with >=4 CPUs, though I suspect I/O latency
+       my $nproc = $jobs || do {
+               # barely tested with >=4 CPUs, though I suspect I/O latency
                # of SATA SSD storage will make >=4 processes unnecessary,
                # here.  NVMe users may wish to use '-j'
                my $n = $self->detect_nproc;
-               $n = 4 if $n > 4;
+               $n = $n > 4 ? 4 : $n;
        };
        my ($op_c, $ops) = $lei->workers_start($self, $nproc,
                undef, { ipt => $ipt }); # LeiInput subclass