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)
Tue, Sep 17, 5:44 AM
Unknown Object (File)
Fri, Sep 13, 12:28 AM
Unknown Object (File)
Fri, Aug 23, 2:17 AM
Unknown Object (File)
Mon, Aug 19, 2:11 PM
Unknown Object (File)
Aug 19 2024, 3:07 AM
Unknown Object (File)
Aug 18 2024, 11:52 PM
Unknown Object (File)
Aug 18 2024, 6:28 AM
Unknown Object (File)
Aug 2 2024, 4:49 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 Not Applicable
Unit
Tests Not Applicable

Event Timeline

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

Remove the extra () if you are fixing style

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

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
7567–7569

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
7567–7569

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). :(