Blame SOURCES/ntp-4.2.6p5-mlock.patch

473877
diff -up ntp-4.2.6p5/html/ntpd.html.mlock ntp-4.2.6p5/html/ntpd.html
473877
--- ntp-4.2.6p5/html/ntpd.html.mlock	2012-11-23 14:58:15.401693701 +0100
473877
+++ ntp-4.2.6p5/html/ntpd.html	2012-11-23 14:58:15.415693714 +0100
473877
@@ -32,7 +32,7 @@
473877
 		
473877
 		
473877
 		

Synopsis

473877
-		<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>
473877
+		<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>
473877
 		

Description

473877
 		

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.

473877
 		

The <tt>ntpd</tt> program ordinarily requires a configuration file as desccribe 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.

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