tstellar / rpms / ntp

Forked from rpms/ntp 3 years ago
Clone
dc06478
diff -up ntp-4.2.6p5/html/ntpd.html.mlock ntp-4.2.6p5/html/ntpd.html
dc06478
--- ntp-4.2.6p5/html/ntpd.html.mlock	2012-11-23 14:58:15.401693701 +0100
dc06478
+++ ntp-4.2.6p5/html/ntpd.html	2012-11-23 14:58:15.415693714 +0100
dc06478
@@ -32,7 +32,7 @@
dc06478
 		
dc06478
 		
dc06478
 		

Synopsis

dc06478
-		<tt>ntpd [ -46aAbdDgLnNqx ] [ -c conffile ] [ -f driftfile ] [ -i jaildir ] [ -I iface ] [ -k keyfile ] [ -l logfile ] [ -p pidfile ] [ -P priority ] [ -r broadcastdelay ] [ -s statsdir ] [ -t key ] [ -u user[:group] ] [ -U interface_update_interval ] [ -v variable ] [ -V variable ]</tt>
dc06478
+		<tt>ntpd [ -46aAbdDgLmnNqx ] [ -c conffile ] [ -f driftfile ] [ -i jaildir ] [ -I iface ] [ -k keyfile ] [ -l logfile ] [ -p pidfile ] [ -P priority ] [ -r broadcastdelay ] [ -s statsdir ] [ -t key ] [ -u user[:group] ] [ -U interface_update_interval ] [ -v variable ] [ -V variable ]</tt>
dc06478
 		

Description

dc06478
 		

The <tt>ntpd</tt> program is an operating system daemon that synchronises the system clock with remote NTP time servers or local reference clocks. It is a complete implementation of the Network Time Protocol (NTP) version 4, but also retains compatibility with version 3, as defined by RFC-1305, and version 1 and 2, as defined by RFC-1059 and RFC-1119, respectively. The program can operate in any of several modes, as described on the Association Management page, and with both symmetric key and public key cryptography, as described on the Authentication Options page.

2ed58ab
 		

The <tt>ntpd</tt> program ordinarily requires a configuration file as described on the Configuration Commands and Options collection above. However a client can discover remote servers and configure them automatically. This makes it possible to deploy a fleet of workstations without specifying configuration details specific to the local environment. Further details are on the Automatic Server Discovery page.

dc06478
@@ -123,6 +123,8 @@
dc06478
 			
Do not listen to virtual interfaces, defined as those with names containing a colon. This option is deprecated. Please consider using the configuration file interface command, which is more versatile.
dc06478
 			
<tt>-M</tt>
dc06478
 			
Raise scheduler precision to its maximum (1 msec) using timeBeginPeriod. (Windows only)
dc06478
+			
<tt>-m</tt>
dc06478
+			
Lock memory.
dc06478
 			
<tt>-n</tt>
dc06478
 			
Don't fork.
dc06478
 			
<tt>-N</tt>
dc06478
diff -up ntp-4.2.6p5/ntpd/ntpd.c.mlock ntp-4.2.6p5/ntpd/ntpd.c
dc06478
--- ntp-4.2.6p5/ntpd/ntpd.c.mlock	2012-11-23 14:58:15.369693666 +0100
dc06478
+++ ntp-4.2.6p5/ntpd/ntpd.c	2012-11-23 14:58:15.416693715 +0100
dc06478
@@ -723,7 +723,8 @@ ntpdmain(
dc06478
 	}
dc06478
 #endif
dc06478
 
dc06478
-#if defined(HAVE_MLOCKALL) && defined(MCL_CURRENT) && defined(MCL_FUTURE)
dc06478
+#if defined(MCL_CURRENT) && defined(MCL_FUTURE)
dc06478
+    if (HAVE_OPT( MLOCK )) {
dc06478
 # ifdef HAVE_SETRLIMIT
dc06478
 	/*
dc06478
 	 * Set the stack limit to something smaller, so that we don't lock a lot
dc06478
@@ -749,7 +750,7 @@ ntpdmain(
dc06478
 	     * fail if we drop root privlege.  To be useful the value
dc06478
 	     * has to be larger than the largest ntpd resident set size.
dc06478
 	     */
dc06478
-	    rl.rlim_cur = rl.rlim_max = 32*1024*1024;
71e78f1
+	    rl.rlim_cur = rl.rlim_max = 128*1024*1024;
dc06478
 	    if (setrlimit(RLIMIT_MEMLOCK, &rl) == -1) {
dc06478
 		msyslog(LOG_ERR, "Cannot set RLIMIT_MEMLOCK: %m");
dc06478
 	    }
dc06478
@@ -761,6 +762,7 @@ ntpdmain(
dc06478
 	 */
dc06478
 	if (mlockall(MCL_CURRENT|MCL_FUTURE) < 0)
dc06478
 		msyslog(LOG_ERR, "mlockall(): %m");
dc06478
+    }
dc06478
 #else /* not (HAVE_MLOCKALL && MCL_CURRENT && MCL_FUTURE) */
dc06478
 # ifdef HAVE_PLOCK
dc06478
 #  ifdef PROCLOCK
dc06478
diff -up ntp-4.2.6p5/ntpd/ntpdbase-opts.def.mlock ntp-4.2.6p5/ntpd/ntpdbase-opts.def
dc06478
--- ntp-4.2.6p5/ntpd/ntpdbase-opts.def.mlock	2009-12-09 08:36:35.000000000 +0100
dc06478
+++ ntp-4.2.6p5/ntpd/ntpdbase-opts.def	2012-11-23 15:07:16.960261421 +0100
dc06478
@@ -226,6 +226,14 @@ flag = {
dc06478
 };
dc06478
 
dc06478
 flag = {
dc06478
+    name      = mlock;
dc06478
+    value     = m;
dc06478
+    descrip   = "Lock memory";
dc06478
+    doc = <<-  _EndOfDoc_
dc06478
+	_EndOfDoc_;
dc06478
+};
dc06478
+
dc06478
+flag = {
dc06478
     ifdef     = SYS_WINNT;
dc06478
     name      = modifymmtimer;
dc06478
     value     = M;