tweak memory handling to make it less special: treat -M as an override_prop
as we should. Use core methods to access the memory threshold. UI simplification: -M can take a suffix, default is K, but you can just say -M 520M or -M 2G now.
This commit is contained in:
parent
cd3023d079
commit
c259d653cc
@ -1,7 +1,7 @@
|
|||||||
#! /usr/bin/perl
|
#! /usr/bin/perl
|
||||||
|
|
||||||
# ex:ts=8 sw=4:
|
# ex:ts=8 sw=4:
|
||||||
# $OpenBSD: dpb,v 1.79 2013/01/28 09:56:00 espie Exp $
|
# $OpenBSD: dpb,v 1.80 2013/01/28 10:14:17 espie Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -155,9 +155,6 @@ sub handle_options
|
|||||||
$state->{random} = 1;
|
$state->{random} = 1;
|
||||||
$state->heuristics->random;
|
$state->heuristics->random;
|
||||||
},
|
},
|
||||||
M => sub {
|
|
||||||
$state->heuristics->set_threshold(shift);
|
|
||||||
},
|
|
||||||
P => sub {
|
P => sub {
|
||||||
push(@{$state->{paths}}, shift);
|
push(@{$state->{paths}}, shift);
|
||||||
},
|
},
|
||||||
@ -291,6 +288,9 @@ sub start_cores
|
|||||||
if ($state->defines("ALWAYS_CLEAN")) {
|
if ($state->defines("ALWAYS_CLEAN")) {
|
||||||
$override_prop->{always_clean} = 1;
|
$override_prop->{always_clean} = 1;
|
||||||
}
|
}
|
||||||
|
if ($state->opt('M')) {
|
||||||
|
$override_prop->{mem} = $state->opt('M');
|
||||||
|
}
|
||||||
|
|
||||||
my $default_prop = {
|
my $default_prop = {
|
||||||
junk => 150,
|
junk => 150,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# ex:ts=8 sw=4:
|
# ex:ts=8 sw=4:
|
||||||
# $OpenBSD: Core.pm,v 1.30 2013/01/27 17:54:45 espie Exp $
|
# $OpenBSD: Core.pm,v 1.31 2013/01/28 10:14:17 espie Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -31,6 +31,16 @@ sub new
|
|||||||
if (defined $prop->{stuck}) {
|
if (defined $prop->{stuck}) {
|
||||||
$prop->{stuck_timeout} = $prop->{stuck} * $prop->{sf};
|
$prop->{stuck_timeout} = $prop->{stuck} * $prop->{sf};
|
||||||
}
|
}
|
||||||
|
if (defined $prop->{mem}) {
|
||||||
|
my $_ = $prop->{mem};
|
||||||
|
if (s/K$//) {
|
||||||
|
} elsif (s/M$//) {
|
||||||
|
$_ *= 1024;
|
||||||
|
} elsif (s/G$//) {
|
||||||
|
$_ *= 1024 * 1024;
|
||||||
|
}
|
||||||
|
$prop->{memory} = $_;
|
||||||
|
}
|
||||||
$prop->{small} //= 120;
|
$prop->{small} //= 120;
|
||||||
$prop->{small_timeout} = $prop->{small} * $prop->{sf};
|
$prop->{small_timeout} = $prop->{small} * $prop->{sf};
|
||||||
# if ($class->name_is_localhost($name)) {
|
# if ($class->name_is_localhost($name)) {
|
||||||
@ -789,9 +799,6 @@ sub parse_hosts_file
|
|||||||
if (defined $prop->{arch} && $prop->{arch} ne $state->arch) {
|
if (defined $prop->{arch} && $prop->{arch} ne $state->arch) {
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
if (defined $prop->{mem}) {
|
|
||||||
$prop->{memory} = $prop->{mem};
|
|
||||||
}
|
|
||||||
if ($host eq 'DEFAULT') {
|
if ($host eq 'DEFAULT') {
|
||||||
$default = { %$prop };
|
$default = { %$prop };
|
||||||
next;
|
next;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# ex:ts=8 sw=4:
|
# ex:ts=8 sw=4:
|
||||||
# $OpenBSD: Engine.pm,v 1.71 2013/01/10 10:30:13 espie Exp $
|
# $OpenBSD: Engine.pm,v 1.72 2013/01/28 10:14:17 espie Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -337,8 +337,7 @@ sub already_done
|
|||||||
sub start_build
|
sub start_build
|
||||||
{
|
{
|
||||||
my ($self, $v, $core, $lock) = @_;
|
my ($self, $v, $core, $lock) = @_;
|
||||||
my $special = $self->{engine}{heuristics}->
|
my $special = $self->{engine}{heuristics}->special_parameters($core, $v);
|
||||||
special_parameters($core->host, $v);
|
|
||||||
$self->log('J', $v, " ".$core->hostname." ".$special);
|
$self->log('J', $v, " ".$core->hostname." ".$special);
|
||||||
$self->{engine}{affinity}->start($v, $core);
|
$self->{engine}{affinity}->start($v, $core);
|
||||||
$self->{builder}->build($v, $core, $special,
|
$self->{builder}->build($v, $core, $special,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# ex:ts=8 sw=4:
|
# ex:ts=8 sw=4:
|
||||||
# $OpenBSD: Heuristics.pm,v 1.16 2013/01/10 22:42:21 espie Exp $
|
# $OpenBSD: Heuristics.pm,v 1.17 2013/01/28 10:14:17 espie Exp $
|
||||||
#
|
#
|
||||||
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
# Copyright (c) 2010 Marc Espie <espie@openbsd.org>
|
||||||
#
|
#
|
||||||
@ -78,13 +78,6 @@ sub equates
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
my $threshold;
|
|
||||||
sub set_threshold
|
|
||||||
{
|
|
||||||
my ($self, $t) = @_;
|
|
||||||
$threshold = $t;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub add_size_info
|
sub add_size_info
|
||||||
{
|
{
|
||||||
my ($self, $path, $sz) = @_;
|
my ($self, $path, $sz) = @_;
|
||||||
@ -96,12 +89,13 @@ my $used_per_host = {};
|
|||||||
|
|
||||||
sub special_parameters
|
sub special_parameters
|
||||||
{
|
{
|
||||||
my ($self, $host, $v) = @_;
|
my ($self, $core, $v) = @_;
|
||||||
my $t = $host->{prop}->{memory} // $threshold;
|
my $t = $core->memory;
|
||||||
|
return 0 if !defined $t;
|
||||||
my $p = $v->pkgpath_and_flavors;
|
my $p = $v->pkgpath_and_flavors;
|
||||||
# we build in memory if we know this port and it's light enough
|
# we build in memory if we know this port and it's light enough
|
||||||
if (defined $t && defined $wrkdir{$p}) {
|
if (defined $t && defined $wrkdir{$p}) {
|
||||||
my $hostname = $host->name;
|
my $hostname = $core->hostname;
|
||||||
$used_per_host->{$hostname} //= 0;
|
$used_per_host->{$hostname} //= 0;
|
||||||
if ($used_per_host->{$hostname} + $wrkdir{$p} <= $t) {
|
if ($used_per_host->{$hostname} + $wrkdir{$p} <= $t) {
|
||||||
$used_per_host->{$hostname} += $wrkdir{$p};
|
$used_per_host->{$hostname} += $wrkdir{$p};
|
||||||
|
Loading…
Reference in New Issue
Block a user