Page MenuHomeFreeBSD

amd64: Handle 1GB mappings in pmap_enter_quick_locked()
ClosedPublic

Authored by markj on Sep 22 2022, 11:08 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jan 13, 8:56 AM
Unknown Object (File)
Fri, Jan 3, 7:43 PM
Unknown Object (File)
Dec 4 2024, 7:37 PM
Unknown Object (File)
Dec 3 2024, 5:24 AM
Unknown Object (File)
Dec 2 2024, 7:10 PM
Unknown Object (File)
Nov 29 2024, 11:00 PM
Unknown Object (File)
Nov 17 2024, 11:14 AM
Unknown Object (File)
Nov 17 2024, 11:08 AM
Subscribers

Details

Summary

This code path can be triggered by applying MADV_WILLNEED to a 1GB
mapping.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 47497
Build 44384: arc lint + arc unit

Event Timeline

kib added inline comments.
sys/amd64/amd64/pmap.c
7548

Remove the extra () if you are fixing style

7567
This revision is now accepted and ready to land.Sep 22 2022, 11:53 PM
sys/amd64/amd64/pmap.c
7566

In the newly introduced if statement above, we already know whether pde is not NULL, but I'm pretty sure that the compiler can't infer that pmap_pdpe_to_pde(pdpe, va) cannot be NULL. For example, it doesn't know that physical page 0 is not allocatable. So, you could fold this if/else statement into the above and thereby eliminate the pde NULL check. The PHYS_TO_VM_PAGE line might be the only one that crosses 80 characters.

markj marked an inline comment as done.

Handle review comments

This revision now requires review to proceed.Sep 23 2022, 9:11 PM
sys/amd64/amd64/pmap.c
7566

I rewrote this fragment to avoid needless comparisons, but I can't see a way to do so that doesn't require adding either some code duplication or an ugly goto.

Shouldn't the same change be made on arm64?

sys/amd64/amd64/pmap.c
7566

In this case, I would expect the compiler to be able to deduplicate the generated code with no extra branches.

This revision is now accepted and ready to land.Sep 23 2022, 9:36 PM
In D36674#832879, @alc wrote:

Shouldn't the same change be made on arm64?

Yes, I simply haven't tested my arm64 patch yet.

As a side note, the existing regression tests for posix shared memory would have caught this if not for a bug in the test (largepage_madvise). :(