summaryrefslogtreecommitdiffstats
path: root/libexec
diff options
context:
space:
mode:
authormjg <mjg@FreeBSD.org>2012-10-30 19:46:00 +0000
committermjg <mjg@FreeBSD.org>2012-10-30 19:46:00 +0000
commitcc3711d225761fc1541c2ba1d5e2414482ae8df5 (patch)
treee662af11d5018b7eab997fdb5ee2567ef276d6f3 /libexec
parent4d5ce1183116adb20e55ae320db533852b23008d (diff)
downloadFreeBSD-src-cc3711d225761fc1541c2ba1d5e2414482ae8df5.zip
FreeBSD-src-cc3711d225761fc1541c2ba1d5e2414482ae8df5.tar.gz
atrun(8): scale default load average limit with the number of CPUs
Previously atrun refused to run jobs if load average was not below fixed limit of 1.5. PR: 173175 Reviewed by: peterj Approved by: trasz (mentor) MFC after: 2 weeks
Diffstat (limited to 'libexec')
-rw-r--r--libexec/atrun/atrun.c19
-rw-r--r--libexec/atrun/atrun.man4
2 files changed, 21 insertions, 2 deletions
diff --git a/libexec/atrun/atrun.c b/libexec/atrun/atrun.c
index 0b6acbe..8b0315e 100644
--- a/libexec/atrun/atrun.c
+++ b/libexec/atrun/atrun.c
@@ -33,6 +33,9 @@ static const char rcsid[] =
#include <sys/fcntl.h>
#include <sys/types.h>
#include <sys/stat.h>
+#ifdef __FreeBSD__
+#include <sys/sysctl.h>
+#endif
#include <sys/wait.h>
#include <sys/param.h>
#include <ctype.h>
@@ -454,7 +457,12 @@ main(int argc, char *argv[])
gid_t batch_gid;
int c;
int run_batch;
+#ifdef __FreeBSD__
+ size_t ncpu, ncpusz;
+ double load_avg = -1;
+#else
double load_avg = LOADAVG_MX;
+#endif
/* We don't need root privileges all the time; running under uid and gid daemon
* is fine.
@@ -472,8 +480,10 @@ main(int argc, char *argv[])
case 'l':
if (sscanf(optarg, "%lf", &load_avg) != 1)
perr("garbled option -l");
+#ifndef __FreeBSD__
if (load_avg <= 0.)
load_avg = LOADAVG_MX;
+#endif
break;
case 'd':
@@ -489,6 +499,15 @@ main(int argc, char *argv[])
if (chdir(ATJOB_DIR) != 0)
perr("cannot change to %s", ATJOB_DIR);
+#ifdef __FreeBSD__
+ if (load_avg <= 0.) {
+ ncpusz = sizeof(size_t);
+ if (sysctlbyname("hw.ncpu", &ncpu, &ncpusz, NULL, 0) < 0)
+ ncpu = 1;
+ load_avg = LOADAVG_MX * ncpu;
+ }
+#endif
+
/* Main loop. Open spool directory for reading and look over all the
* files in there. If the filename indicates that the job should be run
* and the x bit is set, fork off a child which sets its user and group
diff --git a/libexec/atrun/atrun.man b/libexec/atrun/atrun.man
index ec373b3..cea322f 100644
--- a/libexec/atrun/atrun.man
+++ b/libexec/atrun/atrun.man
@@ -1,5 +1,5 @@
.\" $FreeBSD$
-.Dd June 17, 2007
+.Dd October 30, 2012
.Dt ATRUN 8
.Os
.Sh NAME
@@ -45,7 +45,7 @@ e.g., locked out or expired.
.Bl -tag -width indent
.It Fl l Ar load_avg
Specify a limiting load factor, over which batch jobs should
-not be run, instead of the compiled in default of 1.5.
+not be run, instead of the default of 1.5 * number of active CPUs.
.It Fl d
Debug; print error messages to standard error instead of using
.Xr syslog 3 .
OpenPOWER on IntegriCloud