Page MenuHomeFreeBSD

Disable the default of ntpd locking of pages in memory
ClosedPublic

Authored by cy on Sep 10 2019, 2:44 AM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 2, 7:16 PM
Unknown Object (File)
Mon, Dec 23, 4:24 PM
Unknown Object (File)
Mon, Dec 23, 3:08 PM
Unknown Object (File)
Thu, Dec 12, 1:16 AM
Unknown Object (File)
Dec 9 2024, 12:58 PM
Unknown Object (File)
Dec 9 2024, 12:57 AM
Unknown Object (File)
Dec 7 2024, 6:32 PM
Unknown Object (File)
Dec 7 2024, 5:20 AM
Subscribers
None

Details

Summary

As per the discussion on -current@ between Sept 6 - 9, disable ntpd mlock() of pages in memory by default. As ntpd can account for possible (though unlikely) jitter, the impact to ntpd is minimal.

Additionally, disabling ntpd's use of mlock() is default on Linux.

See the discussion on freebsd-current@.

A corresponding change will be made to ports/net/ntp and ports/net/ntp-devel.

Users may enable memory locking through the rlimit memlock statement in ntp.conf.

Test Plan

Testing has shown no effect so far.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped

Event Timeline

usr.sbin/ntp/ntpd/ntp.conf
110

'will result' seems to be too strong. Might be mention stack limit and stack gap randomization.

Or just say that rlimit 0 is incompatible with default settings for ASLR and enabled stack gap randomization.

This revision is now accepted and ready to land.Sep 10 2019, 5:23 PM

Reworded the result of rlimit memlock 0 a little less harshly.

This revision now requires review to proceed.Sep 10 2019, 8:34 PM
cy marked an inline comment as done.Sep 10 2019, 8:34 PM
ian added inline comments.
usr.sbin/ntp/ntpd/ntp.conf
110

Typo in the new text: "will may result". Also, that sentence needs a period.

This revision is now accepted and ready to land.Sep 10 2019, 8:38 PM
This revision now requires review to proceed.Sep 10 2019, 8:57 PM
This revision is now accepted and ready to land.Sep 11 2019, 4:44 AM

Does anyone think we need UPDATING or RELNOTES entries? Probably UPDATING. Not sure about RELNOTES.

In D21581#470863, @cy wrote:

Does anyone think we need UPDATING or RELNOTES entries? Probably UPDATING. Not sure about RELNOTES.

My feedback is to do both.

Added UPDATING and RELNOTES. RELNOTES will be committed separately in order to fill in a revision number.

This revision now requires review to proceed.Sep 12 2019, 3:04 AM

UPDATING and RELNOTES added. RELNOTES will be committed after a revision number for the main commit is known.

UPDATING
37 ↗(On Diff #61962)

I think this gives the misleading impression that locking ntpd into memory is required for high-stratum servers, and I don't believe that is true. I would prefer to see words that make that clear, something like

Locking ntpd into memory is not believed to be required for proper operation.  Administrators wishing to preserve the historic behavior can do so by adding 'rlimit memlock 32' to ntp.conf.  See the NTP chapter of the FreeBSD handbook for more details.

Then we should update the handbook with some details about all this, which is something I can do. I just now glanced at that section of the handbook, maybe for the first time in 25 years :) and it seems a bit thin to me, so I can look into updating it with some modern tips and best practices stuff.

UPDATING
37 ↗(On Diff #61962)

How about a compromise?

There are differences of opinion as noted in the email thread on -current@. Rather than making a judgement that it is believed or not believed to make a difference, let's simply leave the first sentence out.

ntpd no longer by default locks its pages in memory, allowing them to be paged out by the kernel. Use rlimit memlock to restore historic BSD behaviour. For example, adding "rlimit memlock 32" to ntp.conf to lock up to 32 MB of ntpd address space in memory.

Does this verbiage work for you? I don't want to make a judgement in the UPGRADING statement.

Agreed we should put something in the handbook.

Memory locking is historic BSD behaviour. Linux hasn't locked ntpd into memory for as long as I can remember. (This change brings us more in line with Linux behaviour.)

Reworded the UPDATING comment to only describe the change and how to restore historic BSD behaviour. No recommendation is made.

I do not think a reference to the handbook should be made here. However we do need to update the handbook. I think that is where we can work on recommendations and ntp best practices.

UPDATING
34 ↗(On Diff #62002)

I like this wording. Nits... needs to be indented. In the last sentence, s/adding/add/

cy marked an inline comment as done.Sep 13 2019, 8:06 PM

s/adding/add/ done.

This revision was not accepted when it landed; it landed in state Needs Review.Sep 13 2019, 8:20 PM
This revision was automatically updated to reflect the committed changes.