1/* -*- Mode: Text -*- */ 2 3autogen definitions options; 4 5#include copyright.def 6 7// We want the synopsis to be "/etc/ntp.conf" but we need the prog-name 8// to be ntp.conf - the latter is also how autogen produces the output 9// file name. 10prog-name = "ntp.conf"; 11file-path = "/etc/ntp.conf"; 12prog-title = "Network Time Protocol (NTP) daemon configuration file format"; 13 14/* explain: Additional information whenever the usage routine is invoked */ 15explain = <<- _END_EXPLAIN 16 _END_EXPLAIN; 17 18doc-section = { 19 ds-type = 'DESCRIPTION'; 20 ds-format = 'mdoc'; 21 ds-text = <<- _END_PROG_MDOC_DESCRIP 22The 23.Nm 24configuration file is read at initial startup by the 25.Xr ntpd 1ntpdmdoc 26daemon in order to specify the synchronization sources, 27modes and other related information. 28Usually, it is installed in the 29.Pa /etc 30directory, 31but could be installed elsewhere 32(see the daemon's 33.Fl c 34command line option). 35.Pp 36The file format is similar to other 37.Ux 38configuration files. 39Comments begin with a 40.Ql # 41character and extend to the end of the line; 42blank lines are ignored. 43Configuration commands consist of an initial keyword 44followed by a list of arguments, 45some of which may be optional, separated by whitespace. 46Commands may not be continued over multiple lines. 47Arguments may be host names, 48host addresses written in numeric, dotted-quad form, 49integers, floating point numbers (when specifying times in seconds) 50and text strings. 51.Pp 52The rest of this page describes the configuration and control options. 53The 54.Qq Notes on Configuring NTP and Setting up an NTP Subnet 55page 56(available as part of the HTML documentation 57provided in 58.Pa /usr/share/doc/ntp ) 59contains an extended discussion of these options. 60In addition to the discussion of general 61.Sx Configuration Options , 62there are sections describing the following supported functionality 63and the options used to control it: 64.Bl -bullet -offset indent 65.It 66.Sx Authentication Support 67.It 68.Sx Monitoring Support 69.It 70.Sx Access Control Support 71.It 72.Sx Automatic NTP Configuration Options 73.It 74.Sx Reference Clock Support 75.It 76.Sx Miscellaneous Options 77.El 78.Pp 79Following these is a section describing 80.Sx Miscellaneous Options . 81While there is a rich set of options available, 82the only required option is one or more 83.Ic pool , 84.Ic server , 85.Ic peer , 86.Ic broadcast 87or 88.Ic manycastclient 89commands. 90.Sh Configuration Support 91Following is a description of the configuration commands in 92NTPv4. 93These commands have the same basic functions as in NTPv3 and 94in some cases new functions and new arguments. 95There are two 96classes of commands, configuration commands that configure a 97persistent association with a remote server or peer or reference 98clock, and auxiliary commands that specify environmental variables 99that control various related operations. 100.Ss Configuration Commands 101The various modes are determined by the command keyword and the 102type of the required IP address. 103Addresses are classed by type as 104(s) a remote server or peer (IPv4 class A, B and C), (b) the 105broadcast address of a local interface, (m) a multicast address (IPv4 106class D), or (r) a reference clock address (127.127.x.x). 107Note that 108only those options applicable to each command are listed below. 109Use 110of options not listed may not be caught as an error, but may result 111in some weird and even destructive behavior. 112.Pp 113If the Basic Socket Interface Extensions for IPv6 (RFC-2553) 114is detected, support for the IPv6 address family is generated 115in addition to the default support of the IPv4 address family. 116In a few cases, including the 117.Cm reslist 118billboard generated 119by 120.Xr ntpq 1ntpqmdoc 121or 122.Xr ntpdc 1ntpdcmdoc , 123IPv6 addresses are automatically generated. 124IPv6 addresses can be identified by the presence of colons 125.Dq \&: 126in the address field. 127IPv6 addresses can be used almost everywhere where 128IPv4 addresses can be used, 129with the exception of reference clock addresses, 130which are always IPv4. 131.Pp 132Note that in contexts where a host name is expected, a 133.Fl 4 134qualifier preceding 135the host name forces DNS resolution to the IPv4 namespace, 136while a 137.Fl 6 138qualifier forces DNS resolution to the IPv6 namespace. 139See IPv6 references for the 140equivalent classes for that address family. 141.Bl -tag -width indent 142.It Xo Ic pool Ar address 143.Op Cm burst 144.Op Cm iburst 145.Op Cm version Ar version 146.Op Cm prefer 147.Op Cm minpoll Ar minpoll 148.Op Cm maxpoll Ar maxpoll 149.Xc 150.It Xo Ic server Ar address 151.Op Cm key Ar key \&| Cm autokey 152.Op Cm burst 153.Op Cm iburst 154.Op Cm version Ar version 155.Op Cm prefer 156.Op Cm minpoll Ar minpoll 157.Op Cm maxpoll Ar maxpoll 158.Op Cm true 159.Xc 160.It Xo Ic peer Ar address 161.Op Cm key Ar key \&| Cm autokey 162.Op Cm version Ar version 163.Op Cm prefer 164.Op Cm minpoll Ar minpoll 165.Op Cm maxpoll Ar maxpoll 166.Op Cm true 167.Op Cm xleave 168.Xc 169.It Xo Ic broadcast Ar address 170.Op Cm key Ar key \&| Cm autokey 171.Op Cm version Ar version 172.Op Cm prefer 173.Op Cm minpoll Ar minpoll 174.Op Cm ttl Ar ttl 175.Op Cm xleave 176.Xc 177.It Xo Ic manycastclient Ar address 178.Op Cm key Ar key \&| Cm autokey 179.Op Cm version Ar version 180.Op Cm prefer 181.Op Cm minpoll Ar minpoll 182.Op Cm maxpoll Ar maxpoll 183.Op Cm ttl Ar ttl 184.Xc 185.El 186.Pp 187These five commands specify the time server name or address to 188be used and the mode in which to operate. 189The 190.Ar address 191can be 192either a DNS name or an IP address in dotted-quad notation. 193Additional information on association behavior can be found in the 194.Qq Association Management 195page 196(available as part of the HTML documentation 197provided in 198.Pa /usr/share/doc/ntp ) . 199.Bl -tag -width indent 200.It Ic pool 201For type s addresses, this command mobilizes a persistent 202client mode association with a number of remote servers. 203In this mode the local clock can synchronized to the 204remote server, but the remote server can never be synchronized to 205the local clock. 206.It Ic server 207For type s and r addresses, this command mobilizes a persistent 208client mode association with the specified remote server or local 209radio clock. 210In this mode the local clock can synchronized to the 211remote server, but the remote server can never be synchronized to 212the local clock. 213This command should 214.Em not 215be used for type 216b or m addresses. 217.It Ic peer 218For type s addresses (only), this command mobilizes a 219persistent symmetric-active mode association with the specified 220remote peer. 221In this mode the local clock can be synchronized to 222the remote peer or the remote peer can be synchronized to the local 223clock. 224This is useful in a network of servers where, depending on 225various failure scenarios, either the local or remote peer may be 226the better source of time. 227This command should NOT be used for type 228b, m or r addresses. 229.It Ic broadcast 230For type b and m addresses (only), this 231command mobilizes a persistent broadcast mode association. 232Multiple 233commands can be used to specify multiple local broadcast interfaces 234(subnets) and/or multiple multicast groups. 235Note that local 236broadcast messages go only to the interface associated with the 237subnet specified, but multicast messages go to all interfaces. 238In broadcast mode the local server sends periodic broadcast 239messages to a client population at the 240.Ar address 241specified, which is usually the broadcast address on (one of) the 242local network(s) or a multicast address assigned to NTP. 243The IANA 244has assigned the multicast group address IPv4 224.0.1.1 and 245IPv6 ff05::101 (site local) exclusively to 246NTP, but other nonconflicting addresses can be used to contain the 247messages within administrative boundaries. 248Ordinarily, this 249specification applies only to the local server operating as a 250sender; for operation as a broadcast client, see the 251.Ic broadcastclient 252or 253.Ic multicastclient 254commands 255below. 256.It Ic manycastclient 257For type m addresses (only), this command mobilizes a 258manycast client mode association for the multicast address 259specified. 260In this case a specific address must be supplied which 261matches the address used on the 262.Ic manycastserver 263command for 264the designated manycast servers. 265The NTP multicast address 266224.0.1.1 assigned by the IANA should NOT be used, unless specific 267means are taken to avoid spraying large areas of the Internet with 268these messages and causing a possibly massive implosion of replies 269at the sender. 270The 271.Ic manycastserver 272command specifies that the local server 273is to operate in client mode with the remote servers that are 274discovered as the result of broadcast/multicast messages. 275The 276client broadcasts a request message to the group address associated 277with the specified 278.Ar address 279and specifically enabled 280servers respond to these messages. 281The client selects the servers 282providing the best time and continues as with the 283.Ic server 284command. 285The remaining servers are discarded as if never 286heard. 287.El 288.Pp 289Options: 290.Bl -tag -width indent 291.It Cm autokey 292All packets sent to and received from the server or peer are to 293include authentication fields encrypted using the autokey scheme 294described in 295.Sx Authentication Options . 296.It Cm burst 297when the server is reachable, send a burst of eight packets 298instead of the usual one. 299The packet spacing is normally 2 s; 300however, the spacing between the first and second packets 301can be changed with the 302.Ic calldelay 303command to allow 304additional time for a modem or ISDN call to complete. 305This is designed to improve timekeeping quality 306with the 307.Ic server 308command and s addresses. 309.It Cm iburst 310When the server is unreachable, send a burst of eight packets 311instead of the usual one. 312The packet spacing is normally 2 s; 313however, the spacing between the first two packets can be 314changed with the 315.Ic calldelay 316command to allow 317additional time for a modem or ISDN call to complete. 318This is designed to speed the initial synchronization 319acquisition with the 320.Ic server 321command and s addresses and when 322.Xr ntpd 1ntpdmdoc 323is started with the 324.Fl q 325option. 326.It Cm key Ar key 327All packets sent to and received from the server or peer are to 328include authentication fields encrypted using the specified 329.Ar key 330identifier with values from 1 to 65534, inclusive. 331The 332default is to include no encryption field. 333.It Cm minpoll Ar minpoll 334.It Cm maxpoll Ar maxpoll 335These options specify the minimum and maximum poll intervals 336for NTP messages, as a power of 2 in seconds 337The maximum poll 338interval defaults to 10 (1,024 s), but can be increased by the 339.Cm maxpoll 340option to an upper limit of 17 (36.4 h). 341The 342minimum poll interval defaults to 6 (64 s), but can be decreased by 343the 344.Cm minpoll 345option to a lower limit of 4 (16 s). 346.It Cm noselect 347Marks the server as unused, except for display purposes. 348The server is discarded by the selection algroithm. 349.It Cm preempt 350Says the association can be preempted. 351.It Cm true 352Marks the server as a truechimer. 353Use this option only for testing. 354.It Cm prefer 355Marks the server as preferred. 356All other things being equal, 357this host will be chosen for synchronization among a set of 358correctly operating hosts. 359See the 360.Qq Mitigation Rules and the prefer Keyword 361page 362(available as part of the HTML documentation 363provided in 364.Pa /usr/share/doc/ntp ) 365for further information. 366.It Cm true 367Forces the association to always survive the selection and clustering algorithms. 368This option should almost certainly 369.Em only 370be used while testing an association. 371.It Cm ttl Ar ttl 372This option is used only with broadcast server and manycast 373client modes. 374It specifies the time-to-live 375.Ar ttl 376to 377use on broadcast server and multicast server and the maximum 378.Ar ttl 379for the expanding ring search with manycast 380client packets. 381Selection of the proper value, which defaults to 382127, is something of a black art and should be coordinated with the 383network administrator. 384.It Cm version Ar version 385Specifies the version number to be used for outgoing NTP 386packets. 387Versions 1-4 are the choices, with version 4 the 388default. 389.It Cm xleave 390Valid in 391.Cm peer 392and 393.Cm broadcast 394modes only, this flag enables interleave mode. 395.El 396.Ss Auxiliary Commands 397.Bl -tag -width indent 398.It Ic broadcastclient 399This command enables reception of broadcast server messages to 400any local interface (type b) address. 401Upon receiving a message for 402the first time, the broadcast client measures the nominal server 403propagation delay using a brief client/server exchange with the 404server, then enters the broadcast client mode, in which it 405synchronizes to succeeding broadcast messages. 406Note that, in order 407to avoid accidental or malicious disruption in this mode, both the 408server and client should operate using symmetric-key or public-key 409authentication as described in 410.Sx Authentication Options . 411.It Ic manycastserver Ar address ... 412This command enables reception of manycast client messages to 413the multicast group address(es) (type m) specified. 414At least one 415address is required, but the NTP multicast address 224.0.1.1 416assigned by the IANA should NOT be used, unless specific means are 417taken to limit the span of the reply and avoid a possibly massive 418implosion at the original sender. 419Note that, in order to avoid 420accidental or malicious disruption in this mode, both the server 421and client should operate using symmetric-key or public-key 422authentication as described in 423.Sx Authentication Options . 424.It Ic multicastclient Ar address ... 425This command enables reception of multicast server messages to 426the multicast group address(es) (type m) specified. 427Upon receiving 428a message for the first time, the multicast client measures the 429nominal server propagation delay using a brief client/server 430exchange with the server, then enters the broadcast client mode, in 431which it synchronizes to succeeding multicast messages. 432Note that, 433in order to avoid accidental or malicious disruption in this mode, 434both the server and client should operate using symmetric-key or 435public-key authentication as described in 436.Sx Authentication Options . 437.It Ic mdnstries Ar number 438If we are participating in mDNS, 439after we have synched for the first time 440we attempt to register with the mDNS system. 441If that registration attempt fails, 442we try again at one minute intervals for up to 443.Ic mdnstries 444times. 445After all, 446.Ic ntpd 447may be starting before mDNS. 448The default value for 449.Ic mdnstries 450is 5. 451.El 452.Sh Authentication Support 453Authentication support allows the NTP client to verify that the 454server is in fact known and trusted and not an intruder intending 455accidentally or on purpose to masquerade as that server. 456The NTPv3 457specification RFC-1305 defines a scheme which provides 458cryptographic authentication of received NTP packets. 459Originally, 460this was done using the Data Encryption Standard (DES) algorithm 461operating in Cipher Block Chaining (CBC) mode, commonly called 462DES-CBC. 463Subsequently, this was replaced by the RSA Message Digest 4645 (MD5) algorithm using a private key, commonly called keyed-MD5. 465Either algorithm computes a message digest, or one-way hash, which 466can be used to verify the server has the correct private key and 467key identifier. 468.Pp 469NTPv4 retains the NTPv3 scheme, properly described as symmetric key 470cryptography and, in addition, provides a new Autokey scheme 471based on public key cryptography. 472Public key cryptography is generally considered more secure 473than symmetric key cryptography, since the security is based 474on a private value which is generated by each server and 475never revealed. 476With Autokey all key distribution and 477management functions involve only public values, which 478considerably simplifies key distribution and storage. 479Public key management is based on X.509 certificates, 480which can be provided by commercial services or 481produced by utility programs in the OpenSSL software library 482or the NTPv4 distribution. 483.Pp 484While the algorithms for symmetric key cryptography are 485included in the NTPv4 distribution, public key cryptography 486requires the OpenSSL software library to be installed 487before building the NTP distribution. 488Directions for doing that 489are on the Building and Installing the Distribution page. 490.Pp 491Authentication is configured separately for each association 492using the 493.Cm key 494or 495.Cm autokey 496subcommand on the 497.Ic peer , 498.Ic server , 499.Ic broadcast 500and 501.Ic manycastclient 502configuration commands as described in 503.Sx Configuration Options 504page. 505The authentication 506options described below specify the locations of the key files, 507if other than default, which symmetric keys are trusted 508and the interval between various operations, if other than default. 509.Pp 510Authentication is always enabled, 511although ineffective if not configured as 512described below. 513If a NTP packet arrives 514including a message authentication 515code (MAC), it is accepted only if it 516passes all cryptographic checks. 517The 518checks require correct key ID, key value 519and message digest. 520If the packet has 521been modified in any way or replayed 522by an intruder, it will fail one or more 523of these checks and be discarded. 524Furthermore, the Autokey scheme requires a 525preliminary protocol exchange to obtain 526the server certificate, verify its 527credentials and initialize the protocol 528.Pp 529The 530.Cm auth 531flag controls whether new associations or 532remote configuration commands require cryptographic authentication. 533This flag can be set or reset by the 534.Ic enable 535and 536.Ic disable 537commands and also by remote 538configuration commands sent by a 539.Xr ntpdc 1ntpdcmdoc 540program running on 541another machine. 542If this flag is enabled, which is the default 543case, new broadcast client and symmetric passive associations and 544remote configuration commands must be cryptographically 545authenticated using either symmetric key or public key cryptography. 546If this 547flag is disabled, these operations are effective 548even if not cryptographic 549authenticated. 550It should be understood 551that operating with the 552.Ic auth 553flag disabled invites a significant vulnerability 554where a rogue hacker can 555masquerade as a falseticker and seriously 556disrupt system timekeeping. 557It is 558important to note that this flag has no purpose 559other than to allow or disallow 560a new association in response to new broadcast 561and symmetric active messages 562and remote configuration commands and, in particular, 563the flag has no effect on 564the authentication process itself. 565.Pp 566An attractive alternative where multicast support is available 567is manycast mode, in which clients periodically troll 568for servers as described in the 569.Sx Automatic NTP Configuration Options 570page. 571Either symmetric key or public key 572cryptographic authentication can be used in this mode. 573The principle advantage 574of manycast mode is that potential servers need not be 575configured in advance, 576since the client finds them during regular operation, 577and the configuration 578files for all clients can be identical. 579.Pp 580The security model and protocol schemes for 581both symmetric key and public key 582cryptography are summarized below; 583further details are in the briefings, papers 584and reports at the NTP project page linked from 585.Li http://www.ntp.org/ . 586.Ss Symmetric-Key Cryptography 587The original RFC-1305 specification allows any one of possibly 58865,534 keys, each distinguished by a 32-bit key identifier, to 589authenticate an association. 590The servers and clients involved must 591agree on the key and key identifier to 592authenticate NTP packets. 593Keys and 594related information are specified in a key 595file, usually called 596.Pa ntp.keys , 597which must be distributed and stored using 598secure means beyond the scope of the NTP protocol itself. 599Besides the keys used 600for ordinary NTP associations, 601additional keys can be used as passwords for the 602.Xr ntpq 1ntpqmdoc 603and 604.Xr ntpdc 1ntpdcmdoc 605utility programs. 606.Pp 607When 608.Xr ntpd 1ntpdmdoc 609is first started, it reads the key file specified in the 610.Ic keys 611configuration command and installs the keys 612in the key cache. 613However, 614individual keys must be activated with the 615.Ic trusted 616command before use. 617This 618allows, for instance, the installation of possibly 619several batches of keys and 620then activating or deactivating each batch 621remotely using 622.Xr ntpdc 1ntpdcmdoc . 623This also provides a revocation capability that can be used 624if a key becomes compromised. 625The 626.Ic requestkey 627command selects the key used as the password for the 628.Xr ntpdc 1ntpdcmdoc 629utility, while the 630.Ic controlkey 631command selects the key used as the password for the 632.Xr ntpq 1ntpqmdoc 633utility. 634.Ss Public Key Cryptography 635NTPv4 supports the original NTPv3 symmetric key scheme 636described in RFC-1305 and in addition the Autokey protocol, 637which is based on public key cryptography. 638The Autokey Version 2 protocol described on the Autokey Protocol 639page verifies packet integrity using MD5 message digests 640and verifies the source with digital signatures and any of several 641digest/signature schemes. 642Optional identity schemes described on the Identity Schemes 643page and based on cryptographic challenge/response algorithms 644are also available. 645Using all of these schemes provides strong security against 646replay with or without modification, spoofing, masquerade 647and most forms of clogging attacks. 648.\" .Pp 649.\" The cryptographic means necessary for all Autokey operations 650.\" is provided by the OpenSSL software library. 651.\" This library is available from http://www.openssl.org/ 652.\" and can be installed using the procedures outlined 653.\" in the Building and Installing the Distribution page. 654.\" Once installed, 655.\" the configure and build 656.\" process automatically detects the library and links 657.\" the library routines required. 658.Pp 659The Autokey protocol has several modes of operation 660corresponding to the various NTP modes supported. 661Most modes use a special cookie which can be 662computed independently by the client and server, 663but encrypted in transmission. 664All modes use in addition a variant of the S-KEY scheme, 665in which a pseudo-random key list is generated and used 666in reverse order. 667These schemes are described along with an executive summary, 668current status, briefing slides and reading list on the 669.Sx Autonomous Authentication 670page. 671.Pp 672The specific cryptographic environment used by Autokey servers 673and clients is determined by a set of files 674and soft links generated by the 675.Xr ntp-keygen 1ntpkeygenmdoc 676program. 677This includes a required host key file, 678required certificate file and optional sign key file, 679leapsecond file and identity scheme files. 680The 681digest/signature scheme is specified in the X.509 certificate 682along with the matching sign key. 683There are several schemes 684available in the OpenSSL software library, each identified 685by a specific string such as 686.Cm md5WithRSAEncryption , 687which stands for the MD5 message digest with RSA 688encryption scheme. 689The current NTP distribution supports 690all the schemes in the OpenSSL library, including 691those based on RSA and DSA digital signatures. 692.Pp 693NTP secure groups can be used to define cryptographic compartments 694and security hierarchies. 695It is important that every host 696in the group be able to construct a certificate trail to one 697or more trusted hosts in the same group. 698Each group 699host runs the Autokey protocol to obtain the certificates 700for all hosts along the trail to one or more trusted hosts. 701This requires the configuration file in all hosts to be 702engineered so that, even under anticipated failure conditions, 703the NTP subnet will form such that every group host can find 704a trail to at least one trusted host. 705.Ss Naming and Addressing 706It is important to note that Autokey does not use DNS to 707resolve addresses, since DNS can't be completely trusted 708until the name servers have synchronized clocks. 709The cryptographic name used by Autokey to bind the host identity 710credentials and cryptographic values must be independent 711of interface, network and any other naming convention. 712The name appears in the host certificate in either or both 713the subject and issuer fields, so protection against 714DNS compromise is essential. 715.Pp 716By convention, the name of an Autokey host is the name returned 717by the Unix 718.Xr gethostname 2 719system call or equivalent in other systems. 720By the system design 721model, there are no provisions to allow alternate names or aliases. 722However, this is not to say that DNS aliases, different names 723for each interface, etc., are constrained in any way. 724.Pp 725It is also important to note that Autokey verifies authenticity 726using the host name, network address and public keys, 727all of which are bound together by the protocol specifically 728to deflect masquerade attacks. 729For this reason Autokey 730includes the source and destination IP addresses in message digest 731computations and so the same addresses must be available 732at both the server and client. 733For this reason operation 734with network address translation schemes is not possible. 735This reflects the intended robust security model where government 736and corporate NTP servers are operated outside firewall perimeters. 737.Ss Operation 738A specific combination of authentication scheme (none, 739symmetric key, public key) and identity scheme is called 740a cryptotype, although not all combinations are compatible. 741There may be management configurations where the clients, 742servers and peers may not all support the same cryptotypes. 743A secure NTPv4 subnet can be configured in many ways while 744keeping in mind the principles explained above and 745in this section. 746Note however that some cryptotype 747combinations may successfully interoperate with each other, 748but may not represent good security practice. 749.Pp 750The cryptotype of an association is determined at the time 751of mobilization, either at configuration time or some time 752later when a message of appropriate cryptotype arrives. 753When mobilized by a 754.Ic server 755or 756.Ic peer 757configuration command and no 758.Ic key 759or 760.Ic autokey 761subcommands are present, the association is not 762authenticated; if the 763.Ic key 764subcommand is present, the association is authenticated 765using the symmetric key ID specified; if the 766.Ic autokey 767subcommand is present, the association is authenticated 768using Autokey. 769.Pp 770When multiple identity schemes are supported in the Autokey 771protocol, the first message exchange determines which one is used. 772The client request message contains bits corresponding 773to which schemes it has available. 774The server response message 775contains bits corresponding to which schemes it has available. 776Both server and client match the received bits with their own 777and select a common scheme. 778.Pp 779Following the principle that time is a public value, 780a server responds to any client packet that matches 781its cryptotype capabilities. 782Thus, a server receiving 783an unauthenticated packet will respond with an unauthenticated 784packet, while the same server receiving a packet of a cryptotype 785it supports will respond with packets of that cryptotype. 786However, unconfigured broadcast or manycast client 787associations or symmetric passive associations will not be 788mobilized unless the server supports a cryptotype compatible 789with the first packet received. 790By default, unauthenticated associations will not be mobilized 791unless overridden in a decidedly dangerous way. 792.Pp 793Some examples may help to reduce confusion. 794Client Alice has no specific cryptotype selected. 795Server Bob has both a symmetric key file and minimal Autokey files. 796Alice's unauthenticated messages arrive at Bob, who replies with 797unauthenticated messages. 798Cathy has a copy of Bob's symmetric 799key file and has selected key ID 4 in messages to Bob. 800Bob verifies the message with his key ID 4. 801If it's the 802same key and the message is verified, Bob sends Cathy a reply 803authenticated with that key. 804If verification fails, 805Bob sends Cathy a thing called a crypto-NAK, which tells her 806something broke. 807She can see the evidence using the 808.Xr ntpq 1ntpqmdoc 809program. 810.Pp 811Denise has rolled her own host key and certificate. 812She also uses one of the identity schemes as Bob. 813She sends the first Autokey message to Bob and they 814both dance the protocol authentication and identity steps. 815If all comes out okay, Denise and Bob continue as described above. 816.Pp 817It should be clear from the above that Bob can support 818all the girls at the same time, as long as he has compatible 819authentication and identity credentials. 820Now, Bob can act just like the girls in his own choice of servers; 821he can run multiple configured associations with multiple different 822servers (or the same server, although that might not be useful). 823But, wise security policy might preclude some cryptotype 824combinations; for instance, running an identity scheme 825with one server and no authentication with another might not be wise. 826.Ss Key Management 827The cryptographic values used by the Autokey protocol are 828incorporated as a set of files generated by the 829.Xr ntp-keygen 1ntpkeygenmdoc 830utility program, including symmetric key, host key and 831public certificate files, as well as sign key, identity parameters 832and leapseconds files. 833Alternatively, host and sign keys and 834certificate files can be generated by the OpenSSL utilities 835and certificates can be imported from public certificate 836authorities. 837Note that symmetric keys are necessary for the 838.Xr ntpq 1ntpqmdoc 839and 840.Xr ntpdc 1ntpdcmdoc 841utility programs. 842The remaining files are necessary only for the 843Autokey protocol. 844.Pp 845Certificates imported from OpenSSL or public certificate 846authorities have certian limitations. 847The certificate should be in ASN.1 syntax, X.509 Version 3 848format and encoded in PEM, which is the same format 849used by OpenSSL. 850The overall length of the certificate encoded 851in ASN.1 must not exceed 1024 bytes. 852The subject distinguished 853name field (CN) is the fully qualified name of the host 854on which it is used; the remaining subject fields are ignored. 855The certificate extension fields must not contain either 856a subject key identifier or a issuer key identifier field; 857however, an extended key usage field for a trusted host must 858contain the value 859.Cm trustRoot ; . 860Other extension fields are ignored. 861.Ss Authentication Commands 862.Bl -tag -width indent 863.It Ic autokey Op Ar logsec 864Specifies the interval between regenerations of the session key 865list used with the Autokey protocol. 866Note that the size of the key 867list for each association depends on this interval and the current 868poll interval. 869The default value is 12 (4096 s or about 1.1 hours). 870For poll intervals above the specified interval, a session key list 871with a single entry will be regenerated for every message 872sent. 873.It Ic controlkey Ar key 874Specifies the key identifier to use with the 875.Xr ntpq 1ntpqmdoc 876utility, which uses the standard 877protocol defined in RFC-1305. 878The 879.Ar key 880argument is 881the key identifier for a trusted key, where the value can be in the 882range 1 to 65,534, inclusive. 883.It Xo Ic crypto 884.Op Cm cert Ar file 885.Op Cm leap Ar file 886.Op Cm randfile Ar file 887.Op Cm host Ar file 888.Op Cm sign Ar file 889.Op Cm gq Ar file 890.Op Cm gqpar Ar file 891.Op Cm iffpar Ar file 892.Op Cm mvpar Ar file 893.Op Cm pw Ar password 894.Xc 895This command requires the OpenSSL library. 896It activates public key 897cryptography, selects the message digest and signature 898encryption scheme and loads the required private and public 899values described above. 900If one or more files are left unspecified, 901the default names are used as described above. 902Unless the complete path and name of the file are specified, the 903location of a file is relative to the keys directory specified 904in the 905.Ic keysdir 906command or default 907.Pa /usr/local/etc . 908Following are the subcommands: 909.Bl -tag -width indent 910.It Cm cert Ar file 911Specifies the location of the required host public certificate file. 912This overrides the link 913.Pa ntpkey_cert_ Ns Ar hostname 914in the keys directory. 915.It Cm gqpar Ar file 916Specifies the location of the optional GQ parameters file. 917This 918overrides the link 919.Pa ntpkey_gq_ Ns Ar hostname 920in the keys directory. 921.It Cm host Ar file 922Specifies the location of the required host key file. 923This overrides 924the link 925.Pa ntpkey_key_ Ns Ar hostname 926in the keys directory. 927.It Cm iffpar Ar file 928Specifies the location of the optional IFF parameters file. 929This overrides the link 930.Pa ntpkey_iff_ Ns Ar hostname 931in the keys directory. 932.It Cm leap Ar file 933Specifies the location of the optional leapsecond file. 934This overrides the link 935.Pa ntpkey_leap 936in the keys directory. 937.It Cm mvpar Ar file 938Specifies the location of the optional MV parameters file. 939This overrides the link 940.Pa ntpkey_mv_ Ns Ar hostname 941in the keys directory. 942.It Cm pw Ar password 943Specifies the password to decrypt files containing private keys and 944identity parameters. 945This is required only if these files have been 946encrypted. 947.It Cm randfile Ar file 948Specifies the location of the random seed file used by the OpenSSL 949library. 950The defaults are described in the main text above. 951.It Cm sign Ar file 952Specifies the location of the optional sign key file. 953This overrides 954the link 955.Pa ntpkey_sign_ Ns Ar hostname 956in the keys directory. 957If this file is 958not found, the host key is also the sign key. 959.El 960.It Ic keys Ar keyfile 961Specifies the complete path and location of the MD5 key file 962containing the keys and key identifiers used by 963.Xr ntpd 1ntpdmdoc , 964.Xr ntpq 1ntpqmdoc 965and 966.Xr ntpdc 1ntpdcmdoc 967when operating with symmetric key cryptography. 968This is the same operation as the 969.Fl k 970command line option. 971.It Ic keysdir Ar path 972This command specifies the default directory path for 973cryptographic keys, parameters and certificates. 974The default is 975.Pa /usr/local/etc/ . 976.It Ic requestkey Ar key 977Specifies the key identifier to use with the 978.Xr ntpdc 1ntpdcmdoc 979utility program, which uses a 980proprietary protocol specific to this implementation of 981.Xr ntpd 1ntpdmdoc . 982The 983.Ar key 984argument is a key identifier 985for the trusted key, where the value can be in the range 1 to 98665,534, inclusive. 987.It Ic revoke Ar logsec 988Specifies the interval between re-randomization of certain 989cryptographic values used by the Autokey scheme, as a power of 2 in 990seconds. 991These values need to be updated frequently in order to 992deflect brute-force attacks on the algorithms of the scheme; 993however, updating some values is a relatively expensive operation. 994The default interval is 16 (65,536 s or about 18 hours). 995For poll 996intervals above the specified interval, the values will be updated 997for every message sent. 998.It Ic trustedkey Ar key ... 999Specifies the key identifiers which are trusted for the 1000purposes of authenticating peers with symmetric key cryptography, 1001as well as keys used by the 1002.Xr ntpq 1ntpqmdoc 1003and 1004.Xr ntpdc 1ntpdcmdoc 1005programs. 1006The authentication procedures require that both the local 1007and remote servers share the same key and key identifier for this 1008purpose, although different keys can be used with different 1009servers. 1010The 1011.Ar key 1012arguments are 32-bit unsigned 1013integers with values from 1 to 65,534. 1014.El 1015.Ss Error Codes 1016The following error codes are reported via the NTP control 1017and monitoring protocol trap mechanism. 1018.Bl -tag -width indent 1019.It 101 1020.Pq bad field format or length 1021The packet has invalid version, length or format. 1022.It 102 1023.Pq bad timestamp 1024The packet timestamp is the same or older than the most recent received. 1025This could be due to a replay or a server clock time step. 1026.It 103 1027.Pq bad filestamp 1028The packet filestamp is the same or older than the most recent received. 1029This could be due to a replay or a key file generation error. 1030.It 104 1031.Pq bad or missing public key 1032The public key is missing, has incorrect format or is an unsupported type. 1033.It 105 1034.Pq unsupported digest type 1035The server requires an unsupported digest/signature scheme. 1036.It 106 1037.Pq mismatched digest types 1038Not used. 1039.It 107 1040.Pq bad signature length 1041The signature length does not match the current public key. 1042.It 108 1043.Pq signature not verified 1044The message fails the signature check. 1045It could be bogus or signed by a 1046different private key. 1047.It 109 1048.Pq certificate not verified 1049The certificate is invalid or signed with the wrong key. 1050.It 110 1051.Pq certificate not verified 1052The certificate is not yet valid or has expired or the signature could not 1053be verified. 1054.It 111 1055.Pq bad or missing cookie 1056The cookie is missing, corrupted or bogus. 1057.It 112 1058.Pq bad or missing leapseconds table 1059The leapseconds table is missing, corrupted or bogus. 1060.It 113 1061.Pq bad or missing certificate 1062The certificate is missing, corrupted or bogus. 1063.It 114 1064.Pq bad or missing identity 1065The identity key is missing, corrupt or bogus. 1066.El 1067.Sh Monitoring Support 1068.Xr ntpd 1ntpdmdoc 1069includes a comprehensive monitoring facility suitable 1070for continuous, long term recording of server and client 1071timekeeping performance. 1072See the 1073.Ic statistics 1074command below 1075for a listing and example of each type of statistics currently 1076supported. 1077Statistic files are managed using file generation sets 1078and scripts in the 1079.Pa ./scripts 1080directory of the source code distribution. 1081Using 1082these facilities and 1083.Ux 1084.Xr cron 8 1085jobs, the data can be 1086automatically summarized and archived for retrospective analysis. 1087.Ss Monitoring Commands 1088.Bl -tag -width indent 1089.It Ic statistics Ar name ... 1090Enables writing of statistics records. 1091Currently, eight kinds of 1092.Ar name 1093statistics are supported. 1094.Bl -tag -width indent 1095.It Cm clockstats 1096Enables recording of clock driver statistics information. 1097Each update 1098received from a clock driver appends a line of the following form to 1099the file generation set named 1100.Cm clockstats : 1101.Bd -literal 110249213 525.624 127.127.4.1 93 226 00:08:29.606 D 1103.Ed 1104.Pp 1105The first two fields show the date (Modified Julian Day) and time 1106(seconds and fraction past UTC midnight). 1107The next field shows the 1108clock address in dotted-quad notation. 1109The final field shows the last 1110timecode received from the clock in decoded ASCII format, where 1111meaningful. 1112In some clock drivers a good deal of additional information 1113can be gathered and displayed as well. 1114See information specific to each 1115clock for further details. 1116.It Cm cryptostats 1117This option requires the OpenSSL cryptographic software library. 1118It 1119enables recording of cryptographic public key protocol information. 1120Each message received by the protocol module appends a line of the 1121following form to the file generation set named 1122.Cm cryptostats : 1123.Bd -literal 112449213 525.624 127.127.4.1 message 1125.Ed 1126.Pp 1127The first two fields show the date (Modified Julian Day) and time 1128(seconds and fraction past UTC midnight). 1129The next field shows the peer 1130address in dotted-quad notation, The final message field includes the 1131message type and certain ancillary information. 1132See the 1133.Sx Authentication Options 1134section for further information. 1135.It Cm loopstats 1136Enables recording of loop filter statistics information. 1137Each 1138update of the local clock outputs a line of the following form to 1139the file generation set named 1140.Cm loopstats : 1141.Bd -literal 114250935 75440.031 0.000006019 13.778190 0.000351733 0.0133806 1143.Ed 1144.Pp 1145The first two fields show the date (Modified Julian Day) and 1146time (seconds and fraction past UTC midnight). 1147The next five fields 1148show time offset (seconds), frequency offset (parts per million - 1149PPM), RMS jitter (seconds), Allan deviation (PPM) and clock 1150discipline time constant. 1151.It Cm peerstats 1152Enables recording of peer statistics information. 1153This includes 1154statistics records of all peers of a NTP server and of special 1155signals, where present and configured. 1156Each valid update appends a 1157line of the following form to the current element of a file 1158generation set named 1159.Cm peerstats : 1160.Bd -literal 116148773 10847.650 127.127.4.1 9714 -0.001605376 0.000000000 0.001424877 0.000958674 1162.Ed 1163.Pp 1164The first two fields show the date (Modified Julian Day) and 1165time (seconds and fraction past UTC midnight). 1166The next two fields 1167show the peer address in dotted-quad notation and status, 1168respectively. 1169The status field is encoded in hex in the format 1170described in Appendix A of the NTP specification RFC 1305. 1171The final four fields show the offset, 1172delay, dispersion and RMS jitter, all in seconds. 1173.It Cm rawstats 1174Enables recording of raw-timestamp statistics information. 1175This 1176includes statistics records of all peers of a NTP server and of 1177special signals, where present and configured. 1178Each NTP message 1179received from a peer or clock driver appends a line of the 1180following form to the file generation set named 1181.Cm rawstats : 1182.Bd -literal 118350928 2132.543 128.4.1.1 128.4.1.20 3102453281.584327000 3102453281.58622800031 02453332.540806000 3102453332.541458000 1184.Ed 1185.Pp 1186The first two fields show the date (Modified Julian Day) and 1187time (seconds and fraction past UTC midnight). 1188The next two fields 1189show the remote peer or clock address followed by the local address 1190in dotted-quad notation. 1191The final four fields show the originate, 1192receive, transmit and final NTP timestamps in order. 1193The timestamp 1194values are as received and before processing by the various data 1195smoothing and mitigation algorithms. 1196.It Cm sysstats 1197Enables recording of ntpd statistics counters on a periodic basis. 1198Each 1199hour a line of the following form is appended to the file generation 1200set named 1201.Cm sysstats : 1202.Bd -literal 120350928 2132.543 36000 81965 0 9546 56 71793 512 540 10 147 1204.Ed 1205.Pp 1206The first two fields show the date (Modified Julian Day) and time 1207(seconds and fraction past UTC midnight). 1208The remaining ten fields show 1209the statistics counter values accumulated since the last generated 1210line. 1211.Bl -tag -width indent 1212.It Time since restart Cm 36000 1213Time in hours since the system was last rebooted. 1214.It Packets received Cm 81965 1215Total number of packets received. 1216.It Packets processed Cm 0 1217Number of packets received in response to previous packets sent 1218.It Current version Cm 9546 1219Number of packets matching the current NTP version. 1220.It Previous version Cm 56 1221Number of packets matching the previous NTP version. 1222.It Bad version Cm 71793 1223Number of packets matching neither NTP version. 1224.It Access denied Cm 512 1225Number of packets denied access for any reason. 1226.It Bad length or format Cm 540 1227Number of packets with invalid length, format or port number. 1228.It Bad authentication Cm 10 1229Number of packets not verified as authentic. 1230.It Rate exceeded Cm 147 1231Number of packets discarded due to rate limitation. 1232.El 1233.It Cm statsdir Ar directory_path 1234Indicates the full path of a directory where statistics files 1235should be created (see below). 1236This keyword allows 1237the (otherwise constant) 1238.Cm filegen 1239filename prefix to be modified for file generation sets, which 1240is useful for handling statistics logs. 1241.It Cm filegen Ar name Xo 1242.Op Cm file Ar filename 1243.Op Cm type Ar typename 1244.Op Cm link | nolink 1245.Op Cm enable | disable 1246.Xc 1247Configures setting of generation file set name. 1248Generation 1249file sets provide a means for handling files that are 1250continuously growing during the lifetime of a server. 1251Server statistics are a typical example for such files. 1252Generation file sets provide access to a set of files used 1253to store the actual data. 1254At any time at most one element 1255of the set is being written to. 1256The type given specifies 1257when and how data will be directed to a new element of the set. 1258This way, information stored in elements of a file set 1259that are currently unused are available for administrational 1260operations without the risk of disturbing the operation of ntpd. 1261(Most important: they can be removed to free space for new data 1262produced.) 1263.Pp 1264Note that this command can be sent from the 1265.Xr ntpdc 1ntpdcmdoc 1266program running at a remote location. 1267.Bl -tag -width indent 1268.It Cm name 1269This is the type of the statistics records, as shown in the 1270.Cm statistics 1271command. 1272.It Cm file Ar filename 1273This is the file name for the statistics records. 1274Filenames of set 1275members are built from three concatenated elements 1276.Ar Cm prefix , 1277.Ar Cm filename 1278and 1279.Ar Cm suffix : 1280.Bl -tag -width indent 1281.It Cm prefix 1282This is a constant filename path. 1283It is not subject to 1284modifications via the 1285.Ar filegen 1286option. 1287It is defined by the 1288server, usually specified as a compile-time constant. 1289It may, 1290however, be configurable for individual file generation sets 1291via other commands. 1292For example, the prefix used with 1293.Ar loopstats 1294and 1295.Ar peerstats 1296generation can be configured using the 1297.Ar statsdir 1298option explained above. 1299.It Cm filename 1300This string is directly concatenated to the prefix mentioned 1301above (no intervening 1302.Ql / ) . 1303This can be modified using 1304the file argument to the 1305.Ar filegen 1306statement. 1307No 1308.Pa .. 1309elements are 1310allowed in this component to prevent filenames referring to 1311parts outside the filesystem hierarchy denoted by 1312.Ar prefix . 1313.It Cm suffix 1314This part is reflects individual elements of a file set. 1315It is 1316generated according to the type of a file set. 1317.El 1318.It Cm type Ar typename 1319A file generation set is characterized by its type. 1320The following 1321types are supported: 1322.Bl -tag -width indent 1323.It Cm none 1324The file set is actually a single plain file. 1325.It Cm pid 1326One element of file set is used per incarnation of a ntpd 1327server. 1328This type does not perform any changes to file set 1329members during runtime, however it provides an easy way of 1330separating files belonging to different 1331.Xr ntpd 1ntpdmdoc 1332server incarnations. 1333The set member filename is built by appending a 1334.Ql \&. 1335to concatenated 1336.Ar prefix 1337and 1338.Ar filename 1339strings, and 1340appending the decimal representation of the process ID of the 1341.Xr ntpd 1ntpdmdoc 1342server process. 1343.It Cm day 1344One file generation set element is created per day. 1345A day is 1346defined as the period between 00:00 and 24:00 UTC. 1347The file set 1348member suffix consists of a 1349.Ql \&. 1350and a day specification in 1351the form 1352.Cm YYYYMMdd . 1353.Cm YYYY 1354is a 4-digit year number (e.g., 1992). 1355.Cm MM 1356is a two digit month number. 1357.Cm dd 1358is a two digit day number. 1359Thus, all information written at 10 December 1992 would end up 1360in a file named 1361.Ar prefix 1362.Ar filename Ns .19921210 . 1363.It Cm week 1364Any file set member contains data related to a certain week of 1365a year. 1366The term week is defined by computing day-of-year 1367modulo 7. 1368Elements of such a file generation set are 1369distinguished by appending the following suffix to the file set 1370filename base: A dot, a 4-digit year number, the letter 1371.Cm W , 1372and a 2-digit week number. 1373For example, information from January, 137410th 1992 would end up in a file with suffix 1375.No . Ns Ar 1992W1 . 1376.It Cm month 1377One generation file set element is generated per month. 1378The 1379file name suffix consists of a dot, a 4-digit year number, and 1380a 2-digit month. 1381.It Cm year 1382One generation file element is generated per year. 1383The filename 1384suffix consists of a dot and a 4 digit year number. 1385.It Cm age 1386This type of file generation sets changes to a new element of 1387the file set every 24 hours of server operation. 1388The filename 1389suffix consists of a dot, the letter 1390.Cm a , 1391and an 8-digit number. 1392This number is taken to be the number of seconds the server is 1393running at the start of the corresponding 24-hour period. 1394Information is only written to a file generation by specifying 1395.Cm enable ; 1396output is prevented by specifying 1397.Cm disable . 1398.El 1399.It Cm link | nolink 1400It is convenient to be able to access the current element of a file 1401generation set by a fixed name. 1402This feature is enabled by 1403specifying 1404.Cm link 1405and disabled using 1406.Cm nolink . 1407If link is specified, a 1408hard link from the current file set element to a file without 1409suffix is created. 1410When there is already a file with this name and 1411the number of links of this file is one, it is renamed appending a 1412dot, the letter 1413.Cm C , 1414and the pid of the 1415.Xr ntpd 1ntpdmdoc 1416server process. 1417When the 1418number of links is greater than one, the file is unlinked. 1419This 1420allows the current file to be accessed by a constant name. 1421.It Cm enable \&| Cm disable 1422Enables or disables the recording function. 1423.El 1424.El 1425.El 1426.Sh Access Control Support 1427The 1428.Xr ntpd 1ntpdmdoc 1429daemon implements a general purpose address/mask based restriction 1430list. 1431The list contains address/match entries sorted first 1432by increasing address values and and then by increasing mask values. 1433A match occurs when the bitwise AND of the mask and the packet 1434source address is equal to the bitwise AND of the mask and 1435address in the list. 1436The list is searched in order with the 1437last match found defining the restriction flags associated 1438with the entry. 1439Additional information and examples can be found in the 1440.Qq Notes on Configuring NTP and Setting up a NTP Subnet 1441page 1442(available as part of the HTML documentation 1443provided in 1444.Pa /usr/share/doc/ntp ) . 1445.Pp 1446The restriction facility was implemented in conformance 1447with the access policies for the original NSFnet backbone 1448time servers. 1449Later the facility was expanded to deflect 1450cryptographic and clogging attacks. 1451While this facility may 1452be useful for keeping unwanted or broken or malicious clients 1453from congesting innocent servers, it should not be considered 1454an alternative to the NTP authentication facilities. 1455Source address based restrictions are easily circumvented 1456by a determined cracker. 1457.Pp 1458Clients can be denied service because they are explicitly 1459included in the restrict list created by the 1460.Ic restrict 1461command 1462or implicitly as the result of cryptographic or rate limit 1463violations. 1464Cryptographic violations include certificate 1465or identity verification failure; rate limit violations generally 1466result from defective NTP implementations that send packets 1467at abusive rates. 1468Some violations cause denied service 1469only for the offending packet, others cause denied service 1470for a timed period and others cause the denied service for 1471an indefinite period. 1472When a client or network is denied access 1473for an indefinite period, the only way at present to remove 1474the restrictions is by restarting the server. 1475.Ss The Kiss-of-Death Packet 1476Ordinarily, packets denied service are simply dropped with no 1477further action except incrementing statistics counters. 1478Sometimes a 1479more proactive response is needed, such as a server message that 1480explicitly requests the client to stop sending and leave a message 1481for the system operator. 1482A special packet format has been created 1483for this purpose called the "kiss-of-death" (KoD) packet. 1484KoD packets have the leap bits set unsynchronized and stratum set 1485to zero and the reference identifier field set to a four-byte 1486ASCII code. 1487If the 1488.Cm noserve 1489or 1490.Cm notrust 1491flag of the matching restrict list entry is set, 1492the code is "DENY"; if the 1493.Cm limited 1494flag is set and the rate limit 1495is exceeded, the code is "RATE". 1496Finally, if a cryptographic violation occurs, the code is "CRYP". 1497.Pp 1498A client receiving a KoD performs a set of sanity checks to 1499minimize security exposure, then updates the stratum and 1500reference identifier peer variables, sets the access 1501denied (TEST4) bit in the peer flash variable and sends 1502a message to the log. 1503As long as the TEST4 bit is set, 1504the client will send no further packets to the server. 1505The only way at present to recover from this condition is 1506to restart the protocol at both the client and server. 1507This 1508happens automatically at the client when the association times out. 1509It will happen at the server only if the server operator cooperates. 1510.Ss Access Control Commands 1511.Bl -tag -width indent 1512.It Xo Ic discard 1513.Op Cm average Ar avg 1514.Op Cm minimum Ar min 1515.Op Cm monitor Ar prob 1516.Xc 1517Set the parameters of the 1518.Cm limited 1519facility which protects the server from 1520client abuse. 1521The 1522.Cm average 1523subcommand specifies the minimum average packet 1524spacing, while the 1525.Cm minimum 1526subcommand specifies the minimum packet spacing. 1527Packets that violate these minima are discarded 1528and a kiss-o'-death packet returned if enabled. 1529The default 1530minimum average and minimum are 5 and 2, respectively. 1531The 1532.Ic monitor 1533subcommand specifies the probability of discard 1534for packets that overflow the rate-control window. 1535.It Xo Ic restrict address 1536.Op Cm mask Ar mask 1537.Op Cm ippeerlimit Ar int 1538.Op Ar flag ... 1539.Xc 1540The 1541.Ar address 1542argument expressed in 1543dotted-quad form is the address of a host or network. 1544Alternatively, the 1545.Ar address 1546argument can be a valid host DNS name. 1547The 1548.Ar mask 1549argument expressed in dotted-quad form defaults to 1550.Cm 255.255.255.255 , 1551meaning that the 1552.Ar address 1553is treated as the address of an individual host. 1554A default entry (address 1555.Cm 0.0.0.0 , 1556mask 1557.Cm 0.0.0.0 ) 1558is always included and is always the first entry in the list. 1559Note that text string 1560.Cm default , 1561with no mask option, may 1562be used to indicate the default entry. 1563The 1564.Cm ippeerlimit 1565directive limits the number of peer requests for each IP to 1566.Ar int , 1567where a value of -1 means "unlimited", the current default. 1568A value of 0 means "none". 1569There would usually be at most 1 peering request per IP, 1570but if the remote peering requests are behind a proxy 1571there could well be more than 1 per IP. 1572In the current implementation, 1573.Cm flag 1574always 1575restricts access, i.e., an entry with no flags indicates that free 1576access to the server is to be given. 1577The flags are not orthogonal, 1578in that more restrictive flags will often make less restrictive 1579ones redundant. 1580The flags can generally be classed into two 1581categories, those which restrict time service and those which 1582restrict informational queries and attempts to do run-time 1583reconfiguration of the server. 1584One or more of the following flags 1585may be specified: 1586.Bl -tag -width indent 1587.It Cm ignore 1588Deny packets of all kinds, including 1589.Xr ntpq 1ntpqmdoc 1590and 1591.Xr ntpdc 1ntpdcmdoc 1592queries. 1593.It Cm kod 1594If this flag is set when an access violation occurs, a kiss-o'-death 1595(KoD) packet is sent. 1596KoD packets are rate limited to no more than one 1597per second. 1598If another KoD packet occurs within one second after the 1599last one, the packet is dropped. 1600.It Cm limited 1601Deny service if the packet spacing violates the lower limits specified 1602in the 1603.Ic discard 1604command. 1605A history of clients is kept using the 1606monitoring capability of 1607.Xr ntpd 1ntpdmdoc . 1608Thus, monitoring is always active as 1609long as there is a restriction entry with the 1610.Cm limited 1611flag. 1612.It Cm lowpriotrap 1613Declare traps set by matching hosts to be low priority. 1614The 1615number of traps a server can maintain is limited (the current limit 1616is 3). 1617Traps are usually assigned on a first come, first served 1618basis, with later trap requestors being denied service. 1619This flag 1620modifies the assignment algorithm by allowing low priority traps to 1621be overridden by later requests for normal priority traps. 1622.It Cm noepeer 1623Deny ephemeral peer requests, 1624even if they come from an authenticated source. 1625Note that the ability to use a symmetric key for authentication may be restricted to 1626one or more IPs or subnets via the third field of the 1627.Pa ntp.keys 1628file. 1629This restriction is not enabled by default, 1630to maintain backward compatability. 1631Expect 1632.Cm noepeer 1633to become the default in ntp-4.4. 1634.It Cm nomodify 1635Deny 1636.Xr ntpq 1ntpqmdoc 1637and 1638.Xr ntpdc 1ntpdcmdoc 1639queries which attempt to modify the state of the 1640server (i.e., run time reconfiguration). 1641Queries which return 1642information are permitted. 1643.It Cm noquery 1644Deny 1645.Xr ntpq 1ntpqmdoc 1646and 1647.Xr ntpdc 1ntpdcmdoc 1648queries. 1649Time service is not affected. 1650.It Cm nopeer 1651Deny unauthenticated packets which would result in mobilizing a new association. 1652This includes 1653broadcast and symmetric active packets 1654when a configured association does not exist. 1655It also includes 1656.Cm pool 1657associations, so if you want to use servers from a 1658.Cm pool 1659directive and also want to use 1660.Cm nopeer 1661by default, you'll want a 1662.Cm "restrict source ..." 1663line as well that does 1664.Em not 1665include the 1666.Cm nopeer 1667directive. 1668.It Cm noserve 1669Deny all packets except 1670.Xr ntpq 1ntpqmdoc 1671and 1672.Xr ntpdc 1ntpdcmdoc 1673queries. 1674.It Cm notrap 1675Decline to provide mode 6 control message trap service to matching 1676hosts. 1677The trap service is a subsystem of the 1678.Xr ntpq 1ntpqmdoc 1679control message 1680protocol which is intended for use by remote event logging programs. 1681.It Cm notrust 1682Deny service unless the packet is cryptographically authenticated. 1683.It Cm ntpport 1684This is actually a match algorithm modifier, rather than a 1685restriction flag. 1686Its presence causes the restriction entry to be 1687matched only if the source port in the packet is the standard NTP 1688UDP port (123). 1689Both 1690.Cm ntpport 1691and 1692.Cm non-ntpport 1693may 1694be specified. 1695The 1696.Cm ntpport 1697is considered more specific and 1698is sorted later in the list. 1699.It Cm version 1700Deny packets that do not match the current NTP version. 1701.El 1702.Pp 1703Default restriction list entries with the flags ignore, interface, 1704ntpport, for each of the local host's interface addresses are 1705inserted into the table at startup to prevent the server 1706from attempting to synchronize to its own time. 1707A default entry is also always present, though if it is 1708otherwise unconfigured; no flags are associated 1709with the default entry (i.e., everything besides your own 1710NTP server is unrestricted). 1711.El 1712.Sh Automatic NTP Configuration Options 1713.Ss Manycasting 1714Manycasting is a automatic discovery and configuration paradigm 1715new to NTPv4. 1716It is intended as a means for a multicast client 1717to troll the nearby network neighborhood to find cooperating 1718manycast servers, validate them using cryptographic means 1719and evaluate their time values with respect to other servers 1720that might be lurking in the vicinity. 1721The intended result is that each manycast client mobilizes 1722client associations with some number of the "best" 1723of the nearby manycast servers, yet automatically reconfigures 1724to sustain this number of servers should one or another fail. 1725.Pp 1726Note that the manycasting paradigm does not coincide 1727with the anycast paradigm described in RFC-1546, 1728which is designed to find a single server from a clique 1729of servers providing the same service. 1730The manycast paradigm is designed to find a plurality 1731of redundant servers satisfying defined optimality criteria. 1732.Pp 1733Manycasting can be used with either symmetric key 1734or public key cryptography. 1735The public key infrastructure (PKI) 1736offers the best protection against compromised keys 1737and is generally considered stronger, at least with relatively 1738large key sizes. 1739It is implemented using the Autokey protocol and 1740the OpenSSL cryptographic library available from 1741.Li http://www.openssl.org/ . 1742The library can also be used with other NTPv4 modes 1743as well and is highly recommended, especially for broadcast modes. 1744.Pp 1745A persistent manycast client association is configured 1746using the 1747.Ic manycastclient 1748command, which is similar to the 1749.Ic server 1750command but with a multicast (IPv4 class 1751.Cm D 1752or IPv6 prefix 1753.Cm FF ) 1754group address. 1755The IANA has designated IPv4 address 224.1.1.1 1756and IPv6 address FF05::101 (site local) for NTP. 1757When more servers are needed, it broadcasts manycast 1758client messages to this address at the minimum feasible rate 1759and minimum feasible time-to-live (TTL) hops, depending 1760on how many servers have already been found. 1761There can be as many manycast client associations 1762as different group address, each one serving as a template 1763for a future ephemeral unicast client/server association. 1764.Pp 1765Manycast servers configured with the 1766.Ic manycastserver 1767command listen on the specified group address for manycast 1768client messages. 1769Note the distinction between manycast client, 1770which actively broadcasts messages, and manycast server, 1771which passively responds to them. 1772If a manycast server is 1773in scope of the current TTL and is itself synchronized 1774to a valid source and operating at a stratum level equal 1775to or lower than the manycast client, it replies to the 1776manycast client message with an ordinary unicast server message. 1777.Pp 1778The manycast client receiving this message mobilizes 1779an ephemeral client/server association according to the 1780matching manycast client template, but only if cryptographically 1781authenticated and the server stratum is less than or equal 1782to the client stratum. 1783Authentication is explicitly required 1784and either symmetric key or public key (Autokey) can be used. 1785Then, the client polls the server at its unicast address 1786in burst mode in order to reliably set the host clock 1787and validate the source. 1788This normally results 1789in a volley of eight client/server at 2-s intervals 1790during which both the synchronization and cryptographic 1791protocols run concurrently. 1792Following the volley, 1793the client runs the NTP intersection and clustering 1794algorithms, which act to discard all but the "best" 1795associations according to stratum and synchronization 1796distance. 1797The surviving associations then continue 1798in ordinary client/server mode. 1799.Pp 1800The manycast client polling strategy is designed to reduce 1801as much as possible the volume of manycast client messages 1802and the effects of implosion due to near-simultaneous 1803arrival of manycast server messages. 1804The strategy is determined by the 1805.Ic manycastclient , 1806.Ic tos 1807and 1808.Ic ttl 1809configuration commands. 1810The manycast poll interval is 1811normally eight times the system poll interval, 1812which starts out at the 1813.Cm minpoll 1814value specified in the 1815.Ic manycastclient , 1816command and, under normal circumstances, increments to the 1817.Cm maxpolll 1818value specified in this command. 1819Initially, the TTL is 1820set at the minimum hops specified by the 1821.Ic ttl 1822command. 1823At each retransmission the TTL is increased until reaching 1824the maximum hops specified by this command or a sufficient 1825number client associations have been found. 1826Further retransmissions use the same TTL. 1827.Pp 1828The quality and reliability of the suite of associations 1829discovered by the manycast client is determined by the NTP 1830mitigation algorithms and the 1831.Cm minclock 1832and 1833.Cm minsane 1834values specified in the 1835.Ic tos 1836configuration command. 1837At least 1838.Cm minsane 1839candidate servers must be available and the mitigation 1840algorithms produce at least 1841.Cm minclock 1842survivors in order to synchronize the clock. 1843Byzantine agreement principles require at least four 1844candidates in order to correctly discard a single falseticker. 1845For legacy purposes, 1846.Cm minsane 1847defaults to 1 and 1848.Cm minclock 1849defaults to 3. 1850For manycast service 1851.Cm minsane 1852should be explicitly set to 4, assuming at least that 1853number of servers are available. 1854.Pp 1855If at least 1856.Cm minclock 1857servers are found, the manycast poll interval is immediately 1858set to eight times 1859.Cm maxpoll . 1860If less than 1861.Cm minclock 1862servers are found when the TTL has reached the maximum hops, 1863the manycast poll interval is doubled. 1864For each transmission 1865after that, the poll interval is doubled again until 1866reaching the maximum of eight times 1867.Cm maxpoll . 1868Further transmissions use the same poll interval and 1869TTL values. 1870Note that while all this is going on, 1871each client/server association found is operating normally 1872it the system poll interval. 1873.Pp 1874Administratively scoped multicast boundaries are normally 1875specified by the network router configuration and, 1876in the case of IPv6, the link/site scope prefix. 1877By default, the increment for TTL hops is 32 starting 1878from 31; however, the 1879.Ic ttl 1880configuration command can be 1881used to modify the values to match the scope rules. 1882.Pp 1883It is often useful to narrow the range of acceptable 1884servers which can be found by manycast client associations. 1885Because manycast servers respond only when the client 1886stratum is equal to or greater than the server stratum, 1887primary (stratum 1) servers fill find only primary servers 1888in TTL range, which is probably the most common objective. 1889However, unless configured otherwise, all manycast clients 1890in TTL range will eventually find all primary servers 1891in TTL range, which is probably not the most common 1892objective in large networks. 1893The 1894.Ic tos 1895command can be used to modify this behavior. 1896Servers with stratum below 1897.Cm floor 1898or above 1899.Cm ceiling 1900specified in the 1901.Ic tos 1902command are strongly discouraged during the selection 1903process; however, these servers may be temporally 1904accepted if the number of servers within TTL range is 1905less than 1906.Cm minclock . 1907.Pp 1908The above actions occur for each manycast client message, 1909which repeats at the designated poll interval. 1910However, once the ephemeral client association is mobilized, 1911subsequent manycast server replies are discarded, 1912since that would result in a duplicate association. 1913If during a poll interval the number of client associations 1914falls below 1915.Cm minclock , 1916all manycast client prototype associations are reset 1917to the initial poll interval and TTL hops and operation 1918resumes from the beginning. 1919It is important to avoid 1920frequent manycast client messages, since each one requires 1921all manycast servers in TTL range to respond. 1922The result could well be an implosion, either minor or major, 1923depending on the number of servers in range. 1924The recommended value for 1925.Cm maxpoll 1926is 12 (4,096 s). 1927.Pp 1928It is possible and frequently useful to configure a host 1929as both manycast client and manycast server. 1930A number of hosts configured this way and sharing a common 1931group address will automatically organize themselves 1932in an optimum configuration based on stratum and 1933synchronization distance. 1934For example, consider an NTP 1935subnet of two primary servers and a hundred or more 1936dependent clients. 1937With two exceptions, all servers 1938and clients have identical configuration files including both 1939.Ic multicastclient 1940and 1941.Ic multicastserver 1942commands using, for instance, multicast group address 1943239.1.1.1. 1944The only exception is that each primary server 1945configuration file must include commands for the primary 1946reference source such as a GPS receiver. 1947.Pp 1948The remaining configuration files for all secondary 1949servers and clients have the same contents, except for the 1950.Ic tos 1951command, which is specific for each stratum level. 1952For stratum 1 and stratum 2 servers, that command is 1953not necessary. 1954For stratum 3 and above servers the 1955.Cm floor 1956value is set to the intended stratum number. 1957Thus, all stratum 3 configuration files are identical, 1958all stratum 4 files are identical and so forth. 1959.Pp 1960Once operations have stabilized in this scenario, 1961the primary servers will find the primary reference source 1962and each other, since they both operate at the same 1963stratum (1), but not with any secondary server or client, 1964since these operate at a higher stratum. 1965The secondary 1966servers will find the servers at the same stratum level. 1967If one of the primary servers loses its GPS receiver, 1968it will continue to operate as a client and other clients 1969will time out the corresponding association and 1970re-associate accordingly. 1971.Pp 1972Some administrators prefer to avoid running 1973.Xr ntpd 1ntpdmdoc 1974continuously and run either 1975.Xr sntp 1sntpmdoc 1976or 1977.Xr ntpd 1ntpdmdoc 1978.Fl q 1979as a cron job. 1980In either case the servers must be 1981configured in advance and the program fails if none are 1982available when the cron job runs. 1983A really slick 1984application of manycast is with 1985.Xr ntpd 1ntpdmdoc 1986.Fl q . 1987The program wakes up, scans the local landscape looking 1988for the usual suspects, selects the best from among 1989the rascals, sets the clock and then departs. 1990Servers do not have to be configured in advance and 1991all clients throughout the network can have the same 1992configuration file. 1993.Ss Manycast Interactions with Autokey 1994Each time a manycast client sends a client mode packet 1995to a multicast group address, all manycast servers 1996in scope generate a reply including the host name 1997and status word. 1998The manycast clients then run 1999the Autokey protocol, which collects and verifies 2000all certificates involved. 2001Following the burst interval 2002all but three survivors are cast off, 2003but the certificates remain in the local cache. 2004It often happens that several complete signing trails 2005from the client to the primary servers are collected in this way. 2006.Pp 2007About once an hour or less often if the poll interval 2008exceeds this, the client regenerates the Autokey key list. 2009This is in general transparent in client/server mode. 2010However, about once per day the server private value 2011used to generate cookies is refreshed along with all 2012manycast client associations. 2013In this case all 2014cryptographic values including certificates is refreshed. 2015If a new certificate has been generated since 2016the last refresh epoch, it will automatically revoke 2017all prior certificates that happen to be in the 2018certificate cache. 2019At the same time, the manycast 2020scheme starts all over from the beginning and 2021the expanding ring shrinks to the minimum and increments 2022from there while collecting all servers in scope. 2023.Ss Broadcast Options 2024.Bl -tag -width indent 2025.It Xo Ic tos 2026.Oo 2027.Cm bcpollbstep Ar gate 2028.Oc 2029.Xc 2030This command provides a way to delay, 2031by the specified number of broadcast poll intervals, 2032believing backward time steps from a broadcast server. 2033Broadcast time networks are expected to be trusted. 2034In the event a broadcast server's time is stepped backwards, 2035there is clear benefit to having the clients notice this change 2036as soon as possible. 2037Attacks such as replay attacks can happen, however, 2038and even though there are a number of protections built in to 2039broadcast mode, attempts to perform a replay attack are possible. 2040This value defaults to 0, but can be changed 2041to any number of poll intervals between 0 and 4. 2042.El 2043.Ss Manycast Options 2044.Bl -tag -width indent 2045.It Xo Ic tos 2046.Oo 2047.Cm ceiling Ar ceiling | 2048.Cm cohort { 0 | 1 } | 2049.Cm floor Ar floor | 2050.Cm minclock Ar minclock | 2051.Cm minsane Ar minsane 2052.Oc 2053.Xc 2054This command affects the clock selection and clustering 2055algorithms. 2056It can be used to select the quality and 2057quantity of peers used to synchronize the system clock 2058and is most useful in manycast mode. 2059The variables operate 2060as follows: 2061.Bl -tag -width indent 2062.It Cm ceiling Ar ceiling 2063Peers with strata above 2064.Cm ceiling 2065will be discarded if there are at least 2066.Cm minclock 2067peers remaining. 2068This value defaults to 15, but can be changed 2069to any number from 1 to 15. 2070.It Cm cohort Bro 0 | 1 Brc 2071This is a binary flag which enables (0) or disables (1) 2072manycast server replies to manycast clients with the same 2073stratum level. 2074This is useful to reduce implosions where 2075large numbers of clients with the same stratum level 2076are present. 2077The default is to enable these replies. 2078.It Cm floor Ar floor 2079Peers with strata below 2080.Cm floor 2081will be discarded if there are at least 2082.Cm minclock 2083peers remaining. 2084This value defaults to 1, but can be changed 2085to any number from 1 to 15. 2086.It Cm minclock Ar minclock 2087The clustering algorithm repeatedly casts out outlier 2088associations until no more than 2089.Cm minclock 2090associations remain. 2091This value defaults to 3, 2092but can be changed to any number from 1 to the number of 2093configured sources. 2094.It Cm minsane Ar minsane 2095This is the minimum number of candidates available 2096to the clock selection algorithm in order to produce 2097one or more truechimers for the clustering algorithm. 2098If fewer than this number are available, the clock is 2099undisciplined and allowed to run free. 2100The default is 1 2101for legacy purposes. 2102However, according to principles of 2103Byzantine agreement, 2104.Cm minsane 2105should be at least 4 in order to detect and discard 2106a single falseticker. 2107.El 2108.It Cm ttl Ar hop ... 2109This command specifies a list of TTL values in increasing 2110order, up to 8 values can be specified. 2111In manycast mode these values are used in turn 2112in an expanding-ring search. 2113The default is eight 2114multiples of 32 starting at 31. 2115.El 2116.Sh Reference Clock Support 2117The NTP Version 4 daemon supports some three dozen different radio, 2118satellite and modem reference clocks plus a special pseudo-clock 2119used for backup or when no other clock source is available. 2120Detailed descriptions of individual device drivers and options can 2121be found in the 2122.Qq Reference Clock Drivers 2123page 2124(available as part of the HTML documentation 2125provided in 2126.Pa /usr/share/doc/ntp ) . 2127Additional information can be found in the pages linked 2128there, including the 2129.Qq Debugging Hints for Reference Clock Drivers 2130and 2131.Qq How To Write a Reference Clock Driver 2132pages 2133(available as part of the HTML documentation 2134provided in 2135.Pa /usr/share/doc/ntp ) . 2136In addition, support for a PPS 2137signal is available as described in the 2138.Qq Pulse-per-second (PPS) Signal Interfacing 2139page 2140(available as part of the HTML documentation 2141provided in 2142.Pa /usr/share/doc/ntp ) . 2143Many 2144drivers support special line discipline/streams modules which can 2145significantly improve the accuracy using the driver. 2146These are 2147described in the 2148.Qq Line Disciplines and Streams Drivers 2149page 2150(available as part of the HTML documentation 2151provided in 2152.Pa /usr/share/doc/ntp ) . 2153.Pp 2154A reference clock will generally (though not always) be a radio 2155timecode receiver which is synchronized to a source of standard 2156time such as the services offered by the NRC in Canada and NIST and 2157USNO in the US. 2158The interface between the computer and the timecode 2159receiver is device dependent, but is usually a serial port. 2160A 2161device driver specific to each reference clock must be selected and 2162compiled in the distribution; however, most common radio, satellite 2163and modem clocks are included by default. 2164Note that an attempt to 2165configure a reference clock when the driver has not been compiled 2166or the hardware port has not been appropriately configured results 2167in a scalding remark to the system log file, but is otherwise non 2168hazardous. 2169.Pp 2170For the purposes of configuration, 2171.Xr ntpd 1ntpdmdoc 2172treats 2173reference clocks in a manner analogous to normal NTP peers as much 2174as possible. 2175Reference clocks are identified by a syntactically 2176correct but invalid IP address, in order to distinguish them from 2177normal NTP peers. 2178Reference clock addresses are of the form 2179.Sm off 2180.Li 127.127. Ar t . Ar u , 2181.Sm on 2182where 2183.Ar t 2184is an integer 2185denoting the clock type and 2186.Ar u 2187indicates the unit 2188number in the range 0-3. 2189While it may seem overkill, it is in fact 2190sometimes useful to configure multiple reference clocks of the same 2191type, in which case the unit numbers must be unique. 2192.Pp 2193The 2194.Ic server 2195command is used to configure a reference 2196clock, where the 2197.Ar address 2198argument in that command 2199is the clock address. 2200The 2201.Cm key , 2202.Cm version 2203and 2204.Cm ttl 2205options are not used for reference clock support. 2206The 2207.Cm mode 2208option is added for reference clock support, as 2209described below. 2210The 2211.Cm prefer 2212option can be useful to 2213persuade the server to cherish a reference clock with somewhat more 2214enthusiasm than other reference clocks or peers. 2215Further 2216information on this option can be found in the 2217.Qq Mitigation Rules and the prefer Keyword 2218(available as part of the HTML documentation 2219provided in 2220.Pa /usr/share/doc/ntp ) 2221page. 2222The 2223.Cm minpoll 2224and 2225.Cm maxpoll 2226options have 2227meaning only for selected clock drivers. 2228See the individual clock 2229driver document pages for additional information. 2230.Pp 2231The 2232.Ic fudge 2233command is used to provide additional 2234information for individual clock drivers and normally follows 2235immediately after the 2236.Ic server 2237command. 2238The 2239.Ar address 2240argument specifies the clock address. 2241The 2242.Cm refid 2243and 2244.Cm stratum 2245options can be used to 2246override the defaults for the device. 2247There are two optional 2248device-dependent time offsets and four flags that can be included 2249in the 2250.Ic fudge 2251command as well. 2252.Pp 2253The stratum number of a reference clock is by default zero. 2254Since the 2255.Xr ntpd 1ntpdmdoc 2256daemon adds one to the stratum of each 2257peer, a primary server ordinarily displays an external stratum of 2258one. 2259In order to provide engineered backups, it is often useful to 2260specify the reference clock stratum as greater than zero. 2261The 2262.Cm stratum 2263option is used for this purpose. 2264Also, in cases 2265involving both a reference clock and a pulse-per-second (PPS) 2266discipline signal, it is useful to specify the reference clock 2267identifier as other than the default, depending on the driver. 2268The 2269.Cm refid 2270option is used for this purpose. 2271Except where noted, 2272these options apply to all clock drivers. 2273.Ss Reference Clock Commands 2274.Bl -tag -width indent 2275.It Xo Ic server 2276.Sm off 2277.Li 127.127. Ar t . Ar u 2278.Sm on 2279.Op Cm prefer 2280.Op Cm mode Ar int 2281.Op Cm minpoll Ar int 2282.Op Cm maxpoll Ar int 2283.Xc 2284This command can be used to configure reference clocks in 2285special ways. 2286The options are interpreted as follows: 2287.Bl -tag -width indent 2288.It Cm prefer 2289Marks the reference clock as preferred. 2290All other things being 2291equal, this host will be chosen for synchronization among a set of 2292correctly operating hosts. 2293See the 2294.Qq Mitigation Rules and the prefer Keyword 2295page 2296(available as part of the HTML documentation 2297provided in 2298.Pa /usr/share/doc/ntp ) 2299for further information. 2300.It Cm mode Ar int 2301Specifies a mode number which is interpreted in a 2302device-specific fashion. 2303For instance, it selects a dialing 2304protocol in the ACTS driver and a device subtype in the 2305parse 2306drivers. 2307.It Cm minpoll Ar int 2308.It Cm maxpoll Ar int 2309These options specify the minimum and maximum polling interval 2310for reference clock messages, as a power of 2 in seconds 2311For 2312most directly connected reference clocks, both 2313.Cm minpoll 2314and 2315.Cm maxpoll 2316default to 6 (64 s). 2317For modem reference clocks, 2318.Cm minpoll 2319defaults to 10 (17.1 m) and 2320.Cm maxpoll 2321defaults to 14 (4.5 h). 2322The allowable range is 4 (16 s) to 17 (36.4 h) inclusive. 2323.El 2324.It Xo Ic fudge 2325.Sm off 2326.Li 127.127. Ar t . Ar u 2327.Sm on 2328.Op Cm time1 Ar sec 2329.Op Cm time2 Ar sec 2330.Op Cm stratum Ar int 2331.Op Cm refid Ar string 2332.Op Cm mode Ar int 2333.Op Cm flag1 Cm 0 \&| Cm 1 2334.Op Cm flag2 Cm 0 \&| Cm 1 2335.Op Cm flag3 Cm 0 \&| Cm 1 2336.Op Cm flag4 Cm 0 \&| Cm 1 2337.Xc 2338This command can be used to configure reference clocks in 2339special ways. 2340It must immediately follow the 2341.Ic server 2342command which configures the driver. 2343Note that the same capability 2344is possible at run time using the 2345.Xr ntpdc 1ntpdcmdoc 2346program. 2347The options are interpreted as 2348follows: 2349.Bl -tag -width indent 2350.It Cm time1 Ar sec 2351Specifies a constant to be added to the time offset produced by 2352the driver, a fixed-point decimal number in seconds. 2353This is used 2354as a calibration constant to adjust the nominal time offset of a 2355particular clock to agree with an external standard, such as a 2356precision PPS signal. 2357It also provides a way to correct a 2358systematic error or bias due to serial port or operating system 2359latencies, different cable lengths or receiver internal delay. 2360The 2361specified offset is in addition to the propagation delay provided 2362by other means, such as internal DIPswitches. 2363Where a calibration 2364for an individual system and driver is available, an approximate 2365correction is noted in the driver documentation pages. 2366Note: in order to facilitate calibration when more than one 2367radio clock or PPS signal is supported, a special calibration 2368feature is available. 2369It takes the form of an argument to the 2370.Ic enable 2371command described in 2372.Sx Miscellaneous Options 2373page and operates as described in the 2374.Qq Reference Clock Drivers 2375page 2376(available as part of the HTML documentation 2377provided in 2378.Pa /usr/share/doc/ntp ) . 2379.It Cm time2 Ar secs 2380Specifies a fixed-point decimal number in seconds, which is 2381interpreted in a driver-dependent way. 2382See the descriptions of 2383specific drivers in the 2384.Qq Reference Clock Drivers 2385page 2386(available as part of the HTML documentation 2387provided in 2388.Pa /usr/share/doc/ntp ). 2389.It Cm stratum Ar int 2390Specifies the stratum number assigned to the driver, an integer 2391between 0 and 15. 2392This number overrides the default stratum number 2393ordinarily assigned by the driver itself, usually zero. 2394.It Cm refid Ar string 2395Specifies an ASCII string of from one to four characters which 2396defines the reference identifier used by the driver. 2397This string 2398overrides the default identifier ordinarily assigned by the driver 2399itself. 2400.It Cm mode Ar int 2401Specifies a mode number which is interpreted in a 2402device-specific fashion. 2403For instance, it selects a dialing 2404protocol in the ACTS driver and a device subtype in the 2405parse 2406drivers. 2407.It Cm flag1 Cm 0 \&| Cm 1 2408.It Cm flag2 Cm 0 \&| Cm 1 2409.It Cm flag3 Cm 0 \&| Cm 1 2410.It Cm flag4 Cm 0 \&| Cm 1 2411These four flags are used for customizing the clock driver. 2412The 2413interpretation of these values, and whether they are used at all, 2414is a function of the particular clock driver. 2415However, by 2416convention 2417.Cm flag4 2418is used to enable recording monitoring 2419data to the 2420.Cm clockstats 2421file configured with the 2422.Ic filegen 2423command. 2424Further information on the 2425.Ic filegen 2426command can be found in 2427.Sx Monitoring Options . 2428.El 2429.El 2430.Sh Miscellaneous Options 2431.Bl -tag -width indent 2432.It Ic broadcastdelay Ar seconds 2433The broadcast and multicast modes require a special calibration 2434to determine the network delay between the local and remote 2435servers. 2436Ordinarily, this is done automatically by the initial 2437protocol exchanges between the client and server. 2438In some cases, 2439the calibration procedure may fail due to network or server access 2440controls, for example. 2441This command specifies the default delay to 2442be used under these circumstances. 2443Typically (for Ethernet), a 2444number between 0.003 and 0.007 seconds is appropriate. 2445The default 2446when this command is not used is 0.004 seconds. 2447.It Ic calldelay Ar delay 2448This option controls the delay in seconds between the first and second 2449packets sent in burst or iburst mode to allow additional time for a modem 2450or ISDN call to complete. 2451.It Ic driftfile Ar driftfile 2452This command specifies the complete path and name of the file used to 2453record the frequency of the local clock oscillator. 2454This is the same 2455operation as the 2456.Fl f 2457command line option. 2458If the file exists, it is read at 2459startup in order to set the initial frequency and then updated once per 2460hour with the current frequency computed by the daemon. 2461If the file name is 2462specified, but the file itself does not exist, the starts with an initial 2463frequency of zero and creates the file when writing it for the first time. 2464If this command is not given, the daemon will always start with an initial 2465frequency of zero. 2466.Pp 2467The file format consists of a single line containing a single 2468floating point number, which records the frequency offset measured 2469in parts-per-million (PPM). 2470The file is updated by first writing 2471the current drift value into a temporary file and then renaming 2472this file to replace the old version. 2473This implies that 2474.Xr ntpd 1ntpdmdoc 2475must have write permission for the directory the 2476drift file is located in, and that file system links, symbolic or 2477otherwise, should be avoided. 2478.It Ic dscp Ar value 2479This option specifies the Differentiated Services Control Point (DSCP) value, 2480a 6-bit code. 2481The default value is 46, signifying Expedited Forwarding. 2482.It Xo Ic enable 2483.Oo 2484.Cm auth | Cm bclient | 2485.Cm calibrate | Cm kernel | 2486.Cm mode7 | Cm monitor | 2487.Cm ntp | Cm stats | 2488.Cm peer_clear_digest_early | 2489.Cm unpeer_crypto_early | Cm unpeer_crypto_nak_early | Cm unpeer_digest_early 2490.Oc 2491.Xc 2492.It Xo Ic disable 2493.Oo 2494.Cm auth | Cm bclient | 2495.Cm calibrate | Cm kernel | 2496.Cm mode7 | Cm monitor | 2497.Cm ntp | Cm stats | 2498.Cm peer_clear_digest_early | 2499.Cm unpeer_crypto_early | Cm unpeer_crypto_nak_early | Cm unpeer_digest_early 2500.Oc 2501.Xc 2502Provides a way to enable or disable various server options. 2503Flags not mentioned are unaffected. 2504Note that all of these flags 2505can be controlled remotely using the 2506.Xr ntpdc 1ntpdcmdoc 2507utility program. 2508.Bl -tag -width indent 2509.It Cm auth 2510Enables the server to synchronize with unconfigured peers only if the 2511peer has been correctly authenticated using either public key or 2512private key cryptography. 2513The default for this flag is 2514.Ic enable . 2515.It Cm bclient 2516Enables the server to listen for a message from a broadcast or 2517multicast server, as in the 2518.Ic multicastclient 2519command with default 2520address. 2521The default for this flag is 2522.Ic disable . 2523.It Cm calibrate 2524Enables the calibrate feature for reference clocks. 2525The default for 2526this flag is 2527.Ic disable . 2528.It Cm kernel 2529Enables the kernel time discipline, if available. 2530The default for this 2531flag is 2532.Ic enable 2533if support is available, otherwise 2534.Ic disable . 2535.It Cm mode7 2536Enables processing of NTP mode 7 implementation-specific requests 2537which are used by the deprecated 2538.Xr ntpdc 1ntpdcmdoc 2539program. 2540The default for this flag is disable. 2541This flag is excluded from runtime configuration using 2542.Xr ntpq 1ntpqmdoc . 2543The 2544.Xr ntpq 1ntpqmdoc 2545program provides the same capabilities as 2546.Xr ntpdc 1ntpdcmdoc 2547using standard mode 6 requests. 2548.It Cm monitor 2549Enables the monitoring facility. 2550See the 2551.Xr ntpdc 1ntpdcmdoc 2552program 2553and the 2554.Ic monlist 2555command or further information. 2556The 2557default for this flag is 2558.Ic enable . 2559.It Cm ntp 2560Enables time and frequency discipline. 2561In effect, this switch opens and 2562closes the feedback loop, which is useful for testing. 2563The default for 2564this flag is 2565.Ic enable . 2566.It Cm peer_clear_digest_early 2567By default, if 2568.Xr ntpd 1ntpdmdoc 2569is using autokey and it 2570receives a crypto-NAK packet that 2571passes the duplicate packet and origin timestamp checks 2572the peer variables are immediately cleared. 2573While this is generally a feature 2574as it allows for quick recovery if a server key has changed, 2575a properly forged and appropriately delivered crypto-NAK packet 2576can be used in a DoS attack. 2577If you have active noticable problems with this type of DoS attack 2578then you should consider 2579disabling this option. 2580You can check your 2581.Cm peerstats 2582file for evidence of any of these attacks. 2583The 2584default for this flag is 2585.Ic enable . 2586.It Cm stats 2587Enables the statistics facility. 2588See the 2589.Sx Monitoring Options 2590section for further information. 2591The default for this flag is 2592.Ic disable . 2593.It Cm unpeer_crypto_early 2594By default, if 2595.Xr ntpd 1ntpdmdoc 2596receives an autokey packet that fails TEST9, 2597a crypto failure, 2598the association is immediately cleared. 2599This is almost certainly a feature, 2600but if, in spite of the current recommendation of not using autokey, 2601you are 2602.B still 2603using autokey 2604.B and 2605you are seeing this sort of DoS attack 2606disabling this flag will delay 2607tearing down the association until the reachability counter 2608becomes zero. 2609You can check your 2610.Cm peerstats 2611file for evidence of any of these attacks. 2612The 2613default for this flag is 2614.Ic enable . 2615.It Cm unpeer_crypto_nak_early 2616By default, if 2617.Xr ntpd 1ntpdmdoc 2618receives a crypto-NAK packet that 2619passes the duplicate packet and origin timestamp checks 2620the association is immediately cleared. 2621While this is generally a feature 2622as it allows for quick recovery if a server key has changed, 2623a properly forged and appropriately delivered crypto-NAK packet 2624can be used in a DoS attack. 2625If you have active noticable problems with this type of DoS attack 2626then you should consider 2627disabling this option. 2628You can check your 2629.Cm peerstats 2630file for evidence of any of these attacks. 2631The 2632default for this flag is 2633.Ic enable . 2634.It Cm unpeer_digest_early 2635By default, if 2636.Xr ntpd 1ntpdmdoc 2637receives what should be an authenticated packet 2638that passes other packet sanity checks but 2639contains an invalid digest 2640the association is immediately cleared. 2641While this is generally a feature 2642as it allows for quick recovery, 2643if this type of packet is carefully forged and sent 2644during an appropriate window it can be used for a DoS attack. 2645If you have active noticable problems with this type of DoS attack 2646then you should consider 2647disabling this option. 2648You can check your 2649.Cm peerstats 2650file for evidence of any of these attacks. 2651The 2652default for this flag is 2653.Ic enable . 2654.El 2655.It Ic includefile Ar includefile 2656This command allows additional configuration commands 2657to be included from a separate file. 2658Include files may 2659be nested to a depth of five; upon reaching the end of any 2660include file, command processing resumes in the previous 2661configuration file. 2662This option is useful for sites that run 2663.Xr ntpd 1ntpdmdoc 2664on multiple hosts, with (mostly) common options (e.g., a 2665restriction list). 2666.It Xo Ic interface 2667.Oo 2668.Cm listen | Cm ignore | Cm drop 2669.Oc 2670.Oo 2671.Cm all | Cm ipv4 | Cm ipv6 | Cm wildcard 2672.Ar name | Ar address 2673.Oo Cm / Ar prefixlen 2674.Oc 2675.Oc 2676.Xc 2677The 2678.Cm interface 2679directive controls which network addresses 2680.Xr ntpd 1ntpdmdoc 2681opens, and whether input is dropped without processing. 2682The first parameter determines the action for addresses 2683which match the second parameter. 2684The second parameter specifies a class of addresses, 2685or a specific interface name, 2686or an address. 2687In the address case, 2688.Ar prefixlen 2689determines how many bits must match for this rule to apply. 2690.Cm ignore 2691prevents opening matching addresses, 2692.Cm drop 2693causes 2694.Xr ntpd 1ntpdmdoc 2695to open the address and drop all received packets without examination. 2696Multiple 2697.Cm interface 2698directives can be used. 2699The last rule which matches a particular address determines the action for it. 2700.Cm interface 2701directives are disabled if any 2702.Fl I , 2703.Fl -interface , 2704.Fl L , 2705or 2706.Fl -novirtualips 2707command-line options are specified in the configuration file, 2708all available network addresses are opened. 2709The 2710.Cm nic 2711directive is an alias for 2712.Cm interface . 2713.It Ic leapfile Ar leapfile 2714This command loads the IERS leapseconds file and initializes the 2715leapsecond values for the next leapsecond event, leapfile expiration 2716time, and TAI offset. 2717The file can be obtained directly from the IERS at 2718.Li https://hpiers.obspm.fr/iers/bul/bulc/ntp/leap-seconds.list 2719or 2720.Li ftp://hpiers.obspm.fr/iers/bul/bulc/ntp/leap-seconds.list . 2721The 2722.Cm leapfile 2723is scanned when 2724.Xr ntpd 1ntpdmdoc 2725processes the 2726.Cm leapfile directive or when 2727.Cm ntpd detects that the 2728.Ar leapfile 2729has changed. 2730.Cm ntpd 2731checks once a day to see if the 2732.Ar leapfile 2733has changed. 2734The 2735.Xr update-leap 1update_leapmdoc 2736script can be run to see if the 2737.Ar leapfile 2738should be updated. 2739.It Ic leapsmearinterval Ar seconds 2740This EXPERIMENTAL option is only available if 2741.Xr ntpd 1ntpdmdoc 2742was built with the 2743.Cm --enable-leap-smear 2744option to the 2745.Cm configure 2746script. 2747It specifies the interval over which a leap second correction will be applied. 2748Recommended values for this option are between 27497200 (2 hours) and 86400 (24 hours). 2750.Sy DO NOT USE THIS OPTION ON PUBLIC-ACCESS SERVERS! 2751See http://bugs.ntp.org/2855 for more information. 2752.It Ic logconfig Ar configkeyword 2753This command controls the amount and type of output written to 2754the system 2755.Xr syslog 3 2756facility or the alternate 2757.Ic logfile 2758log file. 2759By default, all output is turned on. 2760All 2761.Ar configkeyword 2762keywords can be prefixed with 2763.Ql = , 2764.Ql + 2765and 2766.Ql - , 2767where 2768.Ql = 2769sets the 2770.Xr syslog 3 2771priority mask, 2772.Ql + 2773adds and 2774.Ql - 2775removes 2776messages. 2777.Xr syslog 3 2778messages can be controlled in four 2779classes 2780.Po 2781.Cm clock , 2782.Cm peer , 2783.Cm sys 2784and 2785.Cm sync 2786.Pc . 2787Within these classes four types of messages can be 2788controlled: informational messages 2789.Po 2790.Cm info 2791.Pc , 2792event messages 2793.Po 2794.Cm events 2795.Pc , 2796statistics messages 2797.Po 2798.Cm statistics 2799.Pc 2800and 2801status messages 2802.Po 2803.Cm status 2804.Pc . 2805.Pp 2806Configuration keywords are formed by concatenating the message class with 2807the event class. 2808The 2809.Cm all 2810prefix can be used instead of a message class. 2811A 2812message class may also be followed by the 2813.Cm all 2814keyword to enable/disable all 2815messages of the respective message class. 2816Thus, a minimal log configuration 2817could look like this: 2818.Bd -literal 2819logconfig =syncstatus +sysevents 2820.Ed 2821.Pp 2822This would just list the synchronizations state of 2823.Xr ntpd 1ntpdmdoc 2824and the major system events. 2825For a simple reference server, the 2826following minimum message configuration could be useful: 2827.Bd -literal 2828logconfig =syncall +clockall 2829.Ed 2830.Pp 2831This configuration will list all clock information and 2832synchronization information. 2833All other events and messages about 2834peers, system events and so on is suppressed. 2835.It Ic logfile Ar logfile 2836This command specifies the location of an alternate log file to 2837be used instead of the default system 2838.Xr syslog 3 2839facility. 2840This is the same operation as the 2841.Fl l 2842command line option. 2843.It Xo Ic mru 2844.Oo 2845.Cm maxdepth Ar count | Cm maxmem Ar kilobytes | 2846.Cm mindepth Ar count | Cm maxage Ar seconds | 2847.Cm initialloc Ar count | Cm initmem Ar kilobytes | 2848.Cm incalloc Ar count | Cm incmem Ar kilobytes 2849.Oc 2850.Xc 2851Controls size limite of the monitoring facility's Most Recently Used 2852(MRU) list 2853of client addresses, which is also used by the 2854rate control facility. 2855.Bl -tag -width indent 2856.It Ic maxdepth Ar count 2857.It Ic maxmem Ar kilobytes 2858Equivalent upper limits on the size of the MRU list, in terms of entries or kilobytes. 2859The acutal limit will be up to 2860.Cm incalloc 2861entries or 2862.Cm incmem 2863kilobytes larger. 2864As with all of the 2865.Cm mru 2866options offered in units of entries or kilobytes, if both 2867.Cm maxdepth 2868and 2869.Cm maxmem are used, the last one used controls. 2870The default is 1024 kilobytes. 2871.It Cm mindepth Ar count 2872Lower limit on the MRU list size. 2873When the MRU list has fewer than 2874.Cm mindepth 2875entries, existing entries are never removed to make room for newer ones, 2876regardless of their age. 2877The default is 600 entries. 2878.It Cm maxage Ar seconds 2879Once the MRU list has 2880.Cm mindepth 2881entries and an additional client is to ba added to the list, 2882if the oldest entry was updated more than 2883.Cm maxage 2884seconds ago, that entry is removed and its storage is reused. 2885If the oldest entry was updated more recently the MRU list is grown, 2886subject to 2887.Cm maxdepth / moxmem . 2888The default is 64 seconds. 2889.It Cm initalloc Ar count 2890.It Cm initmem Ar kilobytes 2891Initial memory allocation at the time the monitoringfacility is first enabled, 2892in terms of the number of entries or kilobytes. 2893The default is 4 kilobytes. 2894.It Cm incalloc Ar count 2895.It Cm incmem Ar kilobytes 2896Size of additional memory allocations when growing the MRU list, in entries or kilobytes. 2897The default is 4 kilobytes. 2898.El 2899.It Ic nonvolatile Ar threshold 2900Specify the 2901.Ar threshold 2902delta in seconds before an hourly change to the 2903.Cm driftfile 2904(frequency file) will be written, with a default value of 1e-7 (0.1 PPM). 2905The frequency file is inspected each hour. 2906If the difference between the current frequency and the last value written 2907exceeds the threshold, the file is written and the 2908.Cm threshold 2909becomes the new threshold value. 2910If the threshold is not exceeeded, it is reduced by half. 2911This is intended to reduce the number of file writes 2912for embedded systems with nonvolatile memory. 2913.It Ic phone Ar dial ... 2914This command is used in conjunction with 2915the ACTS modem driver (type 18) 2916or the JJY driver (type 40, mode 100 - 180). 2917For the ACTS modem driver (type 18), the arguments consist of 2918a maximum of 10 telephone numbers used to dial USNO, NIST, or European 2919time service. 2920For the JJY driver (type 40 mode 100 - 180), the argument is 2921one telephone number used to dial the telephone JJY service. 2922The Hayes command ATDT is normally prepended to the number. 2923The number can contain other modem control codes as well. 2924.It Xo Ic reset 2925.Oo 2926.Ic allpeers 2927.Oc 2928.Oo 2929.Ic auth 2930.Oc 2931.Oo 2932.Ic ctl 2933.Oc 2934.Oo 2935.Ic io 2936.Oc 2937.Oo 2938.Ic mem 2939.Oc 2940.Oo 2941.Ic sys 2942.Oc 2943.Oo 2944.Ic timer 2945.Oc 2946.Xc 2947Reset one or more groups of counters maintained by 2948.Cm ntpd 2949and exposed by 2950.Cm ntpq 2951and 2952.Cm ntpdc . 2953.It Xo Ic rlimit 2954.Oo 2955.Cm memlock Ar Nmegabytes | 2956.Cm stacksize Ar N4kPages 2957.Cm filenum Ar Nfiledescriptors 2958.Oc 2959.Xc 2960.Bl -tag -width indent 2961.It Cm memlock Ar Nmegabytes 2962Specify the number of megabytes of memory that should be 2963allocated and locked. 2964Probably only available under Linux, this option may be useful 2965when dropping root (the 2966.Fl i 2967option). 2968The default is 32 megabytes on non-Linux machines, and -1 under Linux. 2969-1 means "do not lock the process into memory". 29700 means "lock whatever memory the process wants into memory". 2971.It Cm stacksize Ar N4kPages 2972Specifies the maximum size of the process stack on systems with the 2973.Fn mlockall 2974function. 2975Defaults to 50 4k pages (200 4k pages in OpenBSD). 2976.It Cm filenum Ar Nfiledescriptors 2977Specifies the maximum number of file descriptors ntpd may have open at once. 2978Defaults to the system default. 2979.El 2980.It Ic saveconfigdir Ar directory_path 2981Specify the directory in which to write configuration snapshots 2982requested with 2983.Cm ntpq 's 2984.Cm saveconfig 2985command. 2986If 2987.Cm saveconfigdir 2988does not appear in the configuration file, 2989.Cm saveconfig 2990requests are rejected by 2991.Cm ntpd . 2992.It Ic saveconfig Ar filename 2993Write the current configuration, including any runtime 2994modifications given with 2995.Cm :config 2996or 2997.Cm config-from-file 2998to the 2999.Cm ntpd 3000host's 3001.Ar filename 3002in the 3003.Cm saveconfigdir . 3004This command will be rejected unless the 3005.Cm saveconfigdir 3006directive appears in 3007.Cm ntpd 's 3008configuration file. 3009.Ar filename 3010can use 3011.Xr strftime 3 3012format directives to substitute the current date and time, 3013for example, 3014.Cm saveconfig\ ntp-%Y%m%d-%H%M%S.conf . 3015The filename used is stored in the system variable 3016.Cm savedconfig . 3017Authentication is required. 3018.It Ic setvar Ar variable Op Cm default 3019This command adds an additional system variable. 3020These 3021variables can be used to distribute additional information such as 3022the access policy. 3023If the variable of the form 3024.Sm off 3025.Va name = Ar value 3026.Sm on 3027is followed by the 3028.Cm default 3029keyword, the 3030variable will be listed as part of the default system variables 3031.Po 3032.Xr ntpq 1ntpqmdoc 3033.Ic rv 3034command 3035.Pc ) . 3036These additional variables serve 3037informational purposes only. 3038They are not related to the protocol 3039other that they can be listed. 3040The known protocol variables will 3041always override any variables defined via the 3042.Ic setvar 3043mechanism. 3044There are three special variables that contain the names 3045of all variable of the same group. 3046The 3047.Va sys_var_list 3048holds 3049the names of all system variables. 3050The 3051.Va peer_var_list 3052holds 3053the names of all peer variables and the 3054.Va clock_var_list 3055holds the names of the reference clock variables. 3056.It Cm sysinfo 3057Display operational summary. 3058.It Cm sysstats 3059Show statistics counters maintained in the protocol module. 3060.It Xo Ic tinker 3061.Oo 3062.Cm allan Ar allan | 3063.Cm dispersion Ar dispersion | 3064.Cm freq Ar freq | 3065.Cm huffpuff Ar huffpuff | 3066.Cm panic Ar panic | 3067.Cm step Ar step | 3068.Cm stepback Ar stepback | 3069.Cm stepfwd Ar stepfwd | 3070.Cm stepout Ar stepout 3071.Oc 3072.Xc 3073This command can be used to alter several system variables in 3074very exceptional circumstances. 3075It should occur in the 3076configuration file before any other configuration options. 3077The 3078default values of these variables have been carefully optimized for 3079a wide range of network speeds and reliability expectations. 3080In 3081general, they interact in intricate ways that are hard to predict 3082and some combinations can result in some very nasty behavior. 3083Very 3084rarely is it necessary to change the default values; but, some 3085folks cannot resist twisting the knobs anyway and this command is 3086for them. 3087Emphasis added: twisters are on their own and can expect 3088no help from the support group. 3089.Pp 3090The variables operate as follows: 3091.Bl -tag -width indent 3092.It Cm allan Ar allan 3093The argument becomes the new value for the minimum Allan 3094intercept, which is a parameter of the PLL/FLL clock discipline 3095algorithm. 3096The value in log2 seconds defaults to 7 (1024 s), which is also the lower 3097limit. 3098.It Cm dispersion Ar dispersion 3099The argument becomes the new value for the dispersion increase rate, 3100normally .000015 s/s. 3101.It Cm freq Ar freq 3102The argument becomes the initial value of the frequency offset in 3103parts-per-million. 3104This overrides the value in the frequency file, if 3105present, and avoids the initial training state if it is not. 3106.It Cm huffpuff Ar huffpuff 3107The argument becomes the new value for the experimental 3108huff-n'-puff filter span, which determines the most recent interval 3109the algorithm will search for a minimum delay. 3110The lower limit is 3111900 s (15 m), but a more reasonable value is 7200 (2 hours). 3112There 3113is no default, since the filter is not enabled unless this command 3114is given. 3115.It Cm panic Ar panic 3116The argument is the panic threshold, normally 1000 s. 3117If set to zero, 3118the panic sanity check is disabled and a clock offset of any value will 3119be accepted. 3120.It Cm step Ar step 3121The argument is the step threshold, which by default is 0.128 s. 3122It can 3123be set to any positive number in seconds. 3124If set to zero, step 3125adjustments will never occur. 3126Note: The kernel time discipline is 3127disabled if the step threshold is set to zero or greater than the 3128default. 3129.It Cm stepback Ar stepback 3130The argument is the step threshold for the backward direction, 3131which by default is 0.128 s. 3132It can 3133be set to any positive number in seconds. 3134If both the forward and backward step thresholds are set to zero, step 3135adjustments will never occur. 3136Note: The kernel time discipline is 3137disabled if 3138each direction of step threshold are either 3139set to zero or greater than .5 second. 3140.It Cm stepfwd Ar stepfwd 3141As for stepback, but for the forward direction. 3142.It Cm stepout Ar stepout 3143The argument is the stepout timeout, which by default is 900 s. 3144It can 3145be set to any positive number in seconds. 3146If set to zero, the stepout 3147pulses will not be suppressed. 3148.El 3149.It Cm writevar Ar assocID\ name = value [,...] 3150Write (create or update) the specified variables. 3151If the 3152.Cm assocID 3153is zero, the variablea re from the 3154system variables 3155name space, otherwise they are from the 3156peer variables 3157name space. 3158The 3159.Cm assocID 3160is required, as the same name can occur in both name spaces. 3161.It Xo Ic trap Ar host_address 3162.Op Cm port Ar port_number 3163.Op Cm interface Ar interface_address 3164.Xc 3165This command configures a trap receiver at the given host 3166address and port number for sending messages with the specified 3167local interface address. 3168If the port number is unspecified, a value 3169of 18447 is used. 3170If the interface address is not specified, the 3171message is sent with a source address of the local interface the 3172message is sent through. 3173Note that on a multihomed host the 3174interface used may vary from time to time with routing changes. 3175.It Cm ttl Ar hop ... 3176This command specifies a list of TTL values in increasing order. 3177Up to 8 values can be specified. 3178In 3179.Cm manycast 3180mode these values are used in-turn in an expanding-ring search. 3181The default is eight multiples of 32 starting at 31. 3182.Pp 3183The trap receiver will generally log event messages and other 3184information from the server in a log file. 3185While such monitor 3186programs may also request their own trap dynamically, configuring a 3187trap receiver will ensure that no messages are lost when the server 3188is started. 3189.It Cm hop Ar ... 3190This command specifies a list of TTL values in increasing order, up to 8 3191values can be specified. 3192In manycast mode these values are used in turn in 3193an expanding-ring search. 3194The default is eight multiples of 32 starting at 319531. 3196.El 3197 _END_PROG_MDOC_DESCRIP; 3198}; 3199 3200doc-section = { 3201 ds-type = 'FILES'; 3202 ds-format = 'mdoc'; 3203 ds-text = <<- _END_MDOC_FILES 3204.Bl -tag -width /etc/ntp.drift -compact 3205.It Pa /etc/ntp.conf 3206the default name of the configuration file 3207.It Pa ntp.keys 3208private MD5 keys 3209.It Pa ntpkey 3210RSA private key 3211.It Pa ntpkey_ Ns Ar host 3212RSA public key 3213.It Pa ntp_dh 3214Diffie-Hellman agreement parameters 3215.El 3216 _END_MDOC_FILES; 3217}; 3218 3219doc-section = { 3220 ds-type = 'SEE ALSO'; 3221 ds-format = 'mdoc'; 3222 ds-text = <<- _END_MDOC_SEE_ALSO 3223.Xr ntpd 1ntpdmdoc , 3224.Xr ntpdc 1ntpdcmdoc , 3225.Xr ntpq 1ntpqmdoc 3226.Pp 3227In addition to the manual pages provided, 3228comprehensive documentation is available on the world wide web 3229at 3230.Li http://www.ntp.org/ . 3231A snapshot of this documentation is available in HTML format in 3232.Pa /usr/share/doc/ntp . 3233.Rs 3234.%A David L. Mills 3235.%T Network Time Protocol (Version 4) 3236.%O RFC5905 3237.Re 3238 _END_MDOC_SEE_ALSO; 3239}; 3240 3241doc-section = { 3242 ds-type = 'BUGS'; 3243 ds-format = 'mdoc'; 3244 ds-text = <<- _END_MDOC_BUGS 3245The syntax checking is not picky; some combinations of 3246ridiculous and even hilarious options and modes may not be 3247detected. 3248.Pp 3249The 3250.Pa ntpkey_ Ns Ar host 3251files are really digital 3252certificates. 3253These should be obtained via secure directory 3254services when they become universally available. 3255 _END_MDOC_BUGS; 3256}; 3257 3258doc-section = { 3259 ds-type = 'NOTES'; 3260 ds-format = 'mdoc'; 3261 ds-text = <<- _END_MDOC_NOTES 3262This document was derived from FreeBSD. 3263 _END_MDOC_NOTES; 3264}; 3265